aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
diGraph.h
Go to the documentation of this file.
1/****************************************************************************
2 * This file is part of the aGrUM/pyAgrum library. *
3 * *
4 * Copyright (c) 2005-2025 by *
5 * - Pierre-Henri WUILLEMIN(_at_LIP6) *
6 * - Christophe GONZALES(_at_AMU) *
7 * *
8 * The aGrUM/pyAgrum library is free software; you can redistribute it *
9 * and/or modify it under the terms of either : *
10 * *
11 * - the GNU Lesser General Public License as published by *
12 * the Free Software Foundation, either version 3 of the License, *
13 * or (at your option) any later version, *
14 * - the MIT license (MIT), *
15 * - or both in dual license, as here. *
16 * *
17 * (see https://agrum.gitlab.io/articles/dual-licenses-lgplv3mit.html) *
18 * *
19 * This aGrUM/pyAgrum library is distributed in the hope that it will be *
20 * useful, but WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, *
21 * INCLUDING BUT NOT LIMITED TO THE WARRANTIES MERCHANTABILITY or FITNESS *
22 * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
23 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
24 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, *
25 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR *
26 * OTHER DEALINGS IN THE SOFTWARE. *
27 * *
28 * See LICENCES for more details. *
29 * *
30 * SPDX-FileCopyrightText: Copyright 2005-2025 *
31 * - Pierre-Henri WUILLEMIN(_at_LIP6) *
32 * - Christophe GONZALES(_at_AMU) *
33 * SPDX-License-Identifier: LGPL-3.0-or-later OR MIT *
34 * *
35 * Contact : info_at_agrum_dot_org *
36 * homepage : http://agrum.gitlab.io *
37 * gitlab : https://gitlab.com/agrumery/agrum *
38 * *
39 ****************************************************************************/
40
41
47#ifndef GUM_DIGRAPH_H
48#define GUM_DIGRAPH_H
49
50#include <iostream>
51#include <sstream>
52#include <utility>
53
54#include <agrum/agrum.h>
55
59
60namespace gum {
61
62 /* ===========================================================================
63 */
64 /* === BASE CLASS FOR MANIPULATING ALL DIRECTED GRAPHS ===
65 */
66 /* ===========================================================================
67 */
128 /* ===========================================================================
129 */
130 class DiGraph: public virtual NodeGraphPart, public ArcGraphPart {
131 public:
132 // ############################################################################
134 // ############################################################################
136
138
142 explicit DiGraph(Size nodes_size = HashTableConst::default_size,
143 bool nodes_resize_policy = true,
145 bool arcs_resize_policy = true);
146
148
149 DiGraph(const DiGraph& g);
150
152 virtual ~DiGraph();
153
159 static DiGraph completeGraph(int n);
160
162
163 // ############################################################################
165 // ############################################################################
167
169
170 DiGraph& operator=(const DiGraph& g);
171
173
174 // not virtual : it is a feature !!! :)
175 bool operator==(const DiGraph& g) const;
176
178
179 // not virtual : it is a feature !!! :)
180 // bool operator!=(const DiGraph& g) const;
181
183
184 // ############################################################################
186 // ############################################################################
188
190
195 virtual void addArc(const NodeId tail, const NodeId head);
196
198
201 virtual void eraseNode(const NodeId id);
202
204 virtual void clear();
205
207 virtual std::string toString() const;
208
210
212 virtual std::string toDot() const;
213
221
231 bool hasDirectedPath(NodeId from, NodeId to);
232 };
233
235 std::ostream& operator<<(std::ostream&, const DiGraph&);
236
237} /* namespace gum */
238
239#ifndef GUM_NO_INLINE
241#endif // GU%_NO_INLINE
242
243#endif /* GUM_DIGRAPH_H */
ArcGraphPart(Size arcs_size=HashTableConst::default_size, bool arcs_resize_policy=true)
default constructor
Base class for all oriented graphs.
Definition diGraph.h:130
virtual void eraseNode(const NodeId id)
remove a node and its adjacent arcs from the graph
Definition diGraph_inl.h:79
bool hasDirectedPath(NodeId from, NodeId to)
checks whether there exists a directed path from from to to
Definition diGraph.cpp:151
virtual void clear()
removes all the nodes and arcs from the graph
Definition diGraph_inl.h:63
static DiGraph completeGraph(int n)
Build a complete DiGraph with n nodes.
Definition diGraph.cpp:57
virtual std::string toDot() const
to friendly display the content of the graph in the DOT syntax
Definition diGraph.cpp:88
DiGraph & operator=(const DiGraph &g)
copy operator
Definition diGraph_inl.h:68
DiGraph(Size nodes_size=HashTableConst::default_size, bool nodes_resize_policy=true, Size arcs_size=HashTableConst::default_size, bool arcs_resize_policy=true)
default constructor
Definition diGraph.cpp:69
bool operator==(const DiGraph &g) const
tests whether two DiGraphs are identical (same nodes, same arcs)
Definition diGraph_inl.h:89
virtual void addArc(const NodeId tail, const NodeId head)
insert a new arc into the directed graph
Definition diGraph_inl.h:55
Sequence< NodeId > topologicalOrder() const
Build and return a topological order.
Definition diGraph.cpp:111
virtual ~DiGraph()
destructor
Definition diGraph.cpp:79
virtual std::string toString() const
to friendly display the content of the graph
Definition diGraph.cpp:81
NodeGraphPart(Size holes_size=HashTableConst::default_size, bool holes_resize_policy=true)
default constructor
Inline implementation of Base classes for oriented graphs.
std::size_t Size
In aGrUM, hashed values are unsigned long int.
Definition types.h:74
Size NodeId
Type for node ids.
gum is the global namespace for all aGrUM entities
Definition agrum.h:46
std::ostream & operator<<(std::ostream &stream, const AVLTree< Val, Cmp > &tree)
display the content of a tree
Definition AVLTree.h:913
Base node set class for graphs.
Header file of gum::Sequence, a class for storing (ordered) sequences of objects.
static constexpr Size default_size
The default number of slots in hashtables.
Definition hashTable.h:101