![]() |
aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
|
Base class for all oriented graphs. More...
#include <diGraph.h>
Public Types | |
| using | NodeIterator = NodeGraphPartIterator |
| using | NodeConstIterator = NodeGraphPartIterator |
| using | NodeIteratorSafe = NodeGraphPartIteratorSafe |
| using | NodeConstIteratorSafe = NodeGraphPartIteratorSafe |
| using | ArcIterator = ArcSetIterator |
| using | node_iterator = NodeGraphPartIterator |
| types for STL compliance | |
| using | node_const_iterator = NodeGraphPartIterator |
| types for STL compliance | |
| using | node_iterator_safe = NodeGraphPartIteratorSafe |
| types for STL compliance | |
| using | node_const_iterator_safe = NodeGraphPartIteratorSafe |
| types for STL compliance | |
Public Member Functions | |||
| bool | hasDirectedPath (NodeId from, NodeId to) | ||
| checks whether there exists a directed path from from to to | |||
Operators | |||
| DiGraph & | operator= (const DiGraph &g) | ||
| copy operator | |||
| bool | operator== (const DiGraph &g) const | ||
| tests whether two DiGraphs are identical (same nodes, same arcs) | |||
Accessors/Modifiers | |||
tests whether two DiGraphs are different
| |||
| virtual void | addArc (const NodeId tail, const NodeId head) | ||
| insert a new arc into the directed graph | |||
| virtual void | eraseNode (const NodeId id) | ||
| remove a node and its adjacent arcs from the graph | |||
| virtual void | clear () | ||
| removes all the nodes and arcs from the graph | |||
| virtual std::string | toString () const | ||
| to friendly display the content of the graph | |||
| virtual std::string | toDot () const | ||
| to friendly display the content of the graph in the DOT syntax | |||
| Sequence< NodeId > | topologicalOrder () const | ||
| Build and return a topological order. | |||
Operators | |||
| bool | operator== (const NodeGraphPart &p) const | ||
| check whether two NodeGraphParts contain the same nodes | |||
| bool | operator!= (const NodeGraphPart &p) const | ||
| check whether two NodeGraphParts contain different nodes | |||
Accessors/Modifiers | |||
| void | populateNodes (const NodeGraphPart &s) | ||
| populateNodes clears *this and fills it with the same nodes as "s" | |||
| template<typename T> | |||
| void | populateNodesFromProperty (const NodeProperty< T > &h) | ||
| populateNodesFromProperty clears *this and fills it with the keys of "h" | |||
| NodeId | nextNodeId () const | ||
| returns a new node id, not yet used by any node | |||
| virtual NodeId | addNode () | ||
| insert a new node and return its id | |||
| std::vector< NodeId > | addNodes (Size n) | ||
| insert n nodes | |||
| virtual void | addNodeWithId (const NodeId id) | ||
| try to insert a node with the given id | |||
| bool | existsNode (const NodeId id) const | ||
| returns true iff the NodeGraphPart contains the given nodeId | |||
| bool | exists (const NodeId id) const | ||
| alias for existsNode | |||
| bool | emptyNodes () const | ||
| indicates whether there exists nodes in the NodeGraphPart | |||
| bool | empty () const | ||
| alias for emptyNodes | |||
| virtual void | clearNodes () | ||
| remove all the nodes from the NodeGraphPart | |||
| Size | sizeNodes () const | ||
| returns the number of nodes in the NodeGraphPart | |||
| Size | size () const | ||
| alias for sizeNodes | |||
| NodeId | bound () const | ||
| returns a number n such that all node ids are strictly lower than n | |||
| NodeSet | asNodeSet () const | ||
| returns a copy of the set of nodes represented by the NodeGraphPart | |||
| const NodeGraphPart & | nodes () const | ||
| return *this as a NodeGraphPart | |||
| node_iterator_safe | beginSafe () const | ||
| a begin iterator to parse the set of nodes contained in the NodeGraphPart | |||
| const node_iterator_safe & | endSafe () const noexcept | ||
| the end iterator to parse the set of nodes contained in the NodeGraphPart | |||
| node_iterator | begin () const noexcept | ||
| a begin iterator to parse the set of nodes contained in the NodeGraphPart | |||
| const node_iterator & | end () const noexcept | ||
| the end iterator to parse the set of nodes contained in the NodeGraphPart | |||
| template<typename VAL> | |||
| NodeProperty< VAL > | nodesPropertyFromFunction (VAL(*f)(const NodeId &), Size size=0) const | ||
| a method to create a HashTable with key:NodeId and value:VAL | |||
| template<typename VAL> | |||
| NodeProperty< VAL > | nodesPropertyFromVal (const VAL &a, Size size=0) const | ||
| a method to create a hashMap with key:NodeId and value:VAL | |||
| template<typename VAL> | |||
| List< VAL > | listMapNodes (VAL(*f)(const NodeId &)) const | ||
| a method to create a list of VAL from a set of nodes (using for every nodee, say x, the VAL f(x)) | |||
Operators | |||
| bool | operator== (const ArcGraphPart &p) const | ||
| tests whether two ArcGraphParts contain the same arcs | |||
Accessors/Modifiers | |||
| virtual void | eraseArc (const Arc &arc) | ||
| removes an arc from the ArcGraphPart | |||
| bool | existsArc (const Arc &arc) const | ||
| indicates whether a given arc exists | |||
| bool | existsArc (NodeId tail, NodeId head) const | ||
| indicates whether a given arc exists | |||
| bool | emptyArcs () const | ||
| indicates wether the ArcGraphPart contains any arc | |||
| void | clearArcs () | ||
| removes all the arcs from the ArcGraphPart | |||
| Size | sizeArcs () const | ||
| indicates the number of arcs stored within the ArcGraphPart | |||
| const ArcSet & | arcs () const | ||
| returns the set of arcs stored within the ArcGraphPart | |||
| const NodeSet & | parents (NodeId id) const | ||
| returns the set of nodes with arc ingoing to a given node | |||
| NodeSet | parents (const NodeSet &ids) const | ||
| returns the set of parents of a set of nodes | |||
| NodeSet | family (NodeId id) const | ||
| returns the set of nodes which consists in the node and its parents | |||
| NodeSet | family (const NodeSet &ids) const | ||
| returns the set of family nodes of a set of nodes | |||
| NodeSet | descendants (NodeId id) const | ||
| returns the set of nodes with directed path outgoing from a given node | |||
| NodeSet | ancestors (NodeId id) const | ||
| returns the set of nodes with directed path ingoing to a given node | |||
| NodeSet | children (const NodeSet &ids) const | ||
| returns the set of children of a set of nodes | |||
| const NodeSet & | children (NodeId id) const | ||
| returns the set of nodes with arc outgoing from a given node | |||
| void | eraseParents (NodeId id) | ||
| erase all the parents of a given node | |||
| void | unvirtualizedEraseParents (NodeId id) | ||
| same function as eraseParents but without any virtual call to an erase | |||
| void | eraseChildren (NodeId id) | ||
| removes all the children of a given node | |||
| void | unvirtualizedEraseChildren (NodeId id) | ||
| same function as eraseChildren but without any virtual call to an erase | |||
| template<typename VAL> | |||
| ArcProperty< VAL > | arcsProperty (VAL(*f)(const Arc &), Size size=0) const | ||
| a method to create a hashMap of VAL from a set of arcs (using for every arc, say x, the VAL f(x)) | |||
| template<typename VAL> | |||
| ArcProperty< VAL > | arcsProperty (const VAL &a, Size size=0) const | ||
| a method to create a hashMap of VAL from a set of arcs (using for every arc, say x, the VAL a) | |||
| template<typename VAL> | |||
| List< VAL > | listMapArcs (VAL(*f)(const Arc &)) const | ||
| a method to create a list of VAL from a set of arcs (using for every arc, say x, the VAL f(x)) | |||
| std::vector< NodeId > | directedPath (NodeId node1, NodeId node2) const | ||
| returns a directed path from node1 to node2 belonging to the set of arcs | |||
| std::vector< NodeId > | directedUnorientedPath (NodeId node1, NodeId node2) const | ||
| returns an unoriented (directed) path from node1 to node2 in the arc set | |||
Public Attributes | |
| Signaler1< NodeId > | onNodeAdded |
| Signaler1< NodeId > | onNodeDeleted |
| Signaler2< NodeId, NodeId > | onArcAdded |
| Signaler2< NodeId, NodeId > | onArcDeleted |
Protected Member Functions | |
| void | eraseSetOfArcs_ (const ArcSet &set) |
| a (virtualized) function to remove a given set of arcs | |
| void | unvirtualizedEraseSetOfArcs_ (const ArcSet &set) |
| similar to eraseSetOfArcs_ except that it is unvirtualized | |
Private Member Functions | |
| void | _updateEndIteratorSafe_ () |
| updating endIterator (always at max+1) | |
| void | _clearNodes_ () |
| code for clearing nodes (called twice) | |
| void | _eraseHole_ (NodeId id) |
| to delete hole. | |
| void | _addHole_ (NodeId id) |
| to add a hole. | |
| void | _checkParents_ (NodeId id) |
| when the ArcGraphPart contains no arc ingoing into a given node, this function adds an empty set entry to parents[id] | |
| void | _checkChildren_ (NodeId id) |
| when the ArcGraphPart contains no arc outgoing from a given node, this function adds an empty set entry to children[id] | |
Introspection | |
| bool | _inHoles_ (NodeId id) const |
| Size | _sizeHoles_ () const |
Private Attributes | |
| NodeSet * | _holes_ |
| the set of nodes not contained in the NodeGraphPart in the interval 1. | |
| Size | _holes_size_ |
| value for holes configuration | |
| bool | _holes_resize_policy_ |
| value for holes configuration | |
| NodeGraphPartIteratorSafe | _endIteratorSafe_ |
| the end iterator (used to speed-up parsings of the NodeGraphPart) | |
| NodeId | _boundVal_ |
| the id below which NodeIds may belong to the NodeGraphPart | |
| Set< Arc > | _arcs_ |
| the set of all the arcs contained within the ArcGraphPart | |
| NodeProperty< NodeSet * > | _parents_ |
| for each arc, the sets of its parents | |
| NodeProperty< NodeSet * > | _children_ |
| for each arc, the set of its children | |
Constructors / Destructors | |
| 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 | |
| DiGraph (const DiGraph &g) | |
| copy constructor | |
| virtual | ~DiGraph () |
| destructor | |
| static DiGraph | completeGraph (int n) |
| Build a complete DiGraph with n nodes. | |
Base class for all oriented graphs.
This is the base class for graphs containing directed edges (so-called arcs)
|
inherited |
Definition at line 100 of file arcGraphPart.h.
|
inherited |
types for STL compliance
Definition at line 276 of file nodeGraphPart.h.
|
inherited |
types for STL compliance
Definition at line 278 of file nodeGraphPart.h.
|
inherited |
types for STL compliance
Definition at line 275 of file nodeGraphPart.h.
|
inherited |
types for STL compliance
Definition at line 277 of file nodeGraphPart.h.
|
inherited |
Definition at line 285 of file nodeGraphPart.h.
|
inherited |
Definition at line 287 of file nodeGraphPart.h.
|
inherited |
Definition at line 284 of file nodeGraphPart.h.
|
inherited |
Definition at line 286 of file nodeGraphPart.h.
|
explicit |
default constructor
| nodes_size | the size of the hash table used to store all the nodes |
| nodes_resize_policy | the resizing policy of this hash table |
| arcs_size | the size of the hash table used to store all the arcs |
| arcs_resize_policy | the resizing policy of this hash table |
Definition at line 69 of file diGraph.cpp.
References gum::ArcGraphPart::ArcGraphPart(), DiGraph(), and gum::NodeGraphPart::NodeGraphPart().
Referenced by gum::DAG::DAG(), gum::DAG::DAG(), DiGraph(), DiGraph(), gum::MixedGraph::MixedGraph(), gum::MixedGraph::MixedGraph(), gum::MixedGraph::MixedGraph(), gum::MixedGraph::MixedGraph(), gum::prm::gspan::Pattern::Pattern(), gum::prm::gspan::Pattern::Pattern(), ~DiGraph(), completeGraph(), operator=(), and operator==().
| gum::DiGraph::DiGraph | ( | const DiGraph & | g | ) |
copy constructor
| g | the DiGraph to copy |
Definition at line 77 of file diGraph.cpp.
References gum::ArcGraphPart::ArcGraphPart(), DiGraph(), and gum::NodeGraphPart::NodeGraphPart().
|
virtual |
destructor
Definition at line 79 of file diGraph.cpp.
References DiGraph().
|
privateinherited |
to add a hole.
Definition at line 96 of file nodeGraphPart.cpp.
References _boundVal_, _holes_, _holes_resize_policy_, _holes_size_, and _updateEndIteratorSafe_().
Referenced by eraseNode(), and gum_tests::NodeGraphPartTestSuite.
|
privateinherited |
when the ArcGraphPart contains no arc outgoing from a given node, this function adds an empty set entry to children[id]
| id | the node whose children[id] is checked |
Definition at line 71 of file arcGraphPart_inl.h.
References _children_.
Referenced by addArc().
|
privateinherited |
when the ArcGraphPart contains no arc ingoing into a given node, this function adds an empty set entry to parents[id]
| id | the node whose parents[id] is checked |
Definition at line 67 of file arcGraphPart_inl.h.
References _parents_.
Referenced by addArc().
|
privateinherited |
code for clearing nodes (called twice)
Definition at line 174 of file nodeGraphPart.cpp.
References _boundVal_, _holes_, _inHoles_(), _updateEndIteratorSafe_(), bound(), GUM_EMIT1, and onNodeDeleted.
Referenced by clear(), clearNodes(), and gum_tests::NodeGraphPartTestSuite.
|
privateinherited |
to delete hole.
Definition at line 244 of file nodeGraphPart_inl.h.
References _holes_.
Referenced by addNode(), addNodeWithId(), and gum_tests::NodeGraphPartTestSuite.
Definition at line 372 of file nodeGraphPart_inl.h.
References _holes_.
Referenced by _clearNodes_(), addNodeWithId(), asNodeSet(), existsNode(), gum_tests::NodeGraphPartTestSuite, and toString().
|
privateinherited |
Definition at line 375 of file nodeGraphPart_inl.h.
References _holes_.
Referenced by gum_tests::NodeGraphPartTestSuite.
|
privateinherited |
updating endIterator (always at max+1)
Definition at line 327 of file nodeGraphPart_inl.h.
References _boundVal_, and _endIteratorSafe_.
Referenced by NodeGraphPart(), NodeGraphPart(), _addHole_(), _clearNodes_(), addNode(), addNodeWithId(), gum_tests::NodeGraphPartTestSuite, and populateNodes().
insert a new arc into the directed graph
| tail | the id of the tail of the new inserted arc |
| head | the id of the head of the new inserted arc |
| InvalidNode | if head or tail does not belong to the graph nodes |
Reimplemented from gum::ArcGraphPart.
Reimplemented in gum::DAG, gum::PDAG, and gum::prm::gspan::Pattern.
Definition at line 55 of file diGraph_inl.h.
References gum::ArcGraphPart::addArc(), gum::NodeGraphPart::exists(), and GUM_ERROR.
Referenced by gum::MeekRules::_applyMeekRules_(), gum::EssentialGraph::_buildEssentialGraph_(), gum::learning::Miic::_orientingVstructureMiic_(), gum::learning::SimpleMiic::_orientingVstructureMiic_(), gum::MeekRules::_propagatesOrientationInChainOfRemainingEdges_(), gum::learning::Miic::_propagatingOrientationMiic_(), gum::learning::SimpleMiic::_propagatingOrientationMiic_(), gum::DAG::addArc(), gum::PDAG::addArc(), gum::prm::gspan::Pattern::addArc(), completeGraph(), gum::learning::SimpleMiic::learnPDAG(), gum::learning::SimpleMiic::learnStructure(), gum::learning::SimpleMiic::orientationLatents_(), gum::learning::Miic::orientationMiic_(), gum::learning::SimpleMiic::orientationMiic_(), gum::learning::IBNLearner::prepareMiic_(), gum::learning::SimpleMiic::propagatesOrientationInChainOfRemainingEdges_(), and gum::learning::SimpleMiic::propagatesRemainingOrientableEdges_().
|
virtualinherited |
insert a new node and return its id
Reimplemented in gum::CliqueGraph.
Definition at line 258 of file nodeGraphPart_inl.h.
References _boundVal_, _eraseHole_(), _holes_, _updateEndIteratorSafe_(), GUM_EMIT1, and onNodeAdded.
Referenced by gum::prm::gspan::DFSTree< GUM_SCALAR >::_addChild_(), gum::prm::StructuredInference< GUM_SCALAR >::_addEdgesInReducedGraph_(), gum::prm::gspan::StrictSearch< GUM_SCALAR >::_buildPatternGraph_(), gum::prm::StructuredInference< GUM_SCALAR >::_buildPatternGraph_(), gum::prm::ClusteredLayerGenerator< GUM_SCALAR >::_generateClassDag_(), gum::prm::LayerGenerator< GUM_SCALAR >::_generateClassDag_(), and gum::prm::gspan::DFSTree< GUM_SCALAR >::addRoot().
insert n nodes
| n | the number of nodes to add |
Definition at line 276 of file nodeGraphPart_inl.h.
Referenced by gum::DiGraph::completeGraph(), and gum::UndiGraph::completeGraph().
|
virtualinherited |
try to insert a node with the given id
| DuplicateElement | exception if the id already exists |
Reimplemented in gum::CliqueGraph.
Definition at line 151 of file nodeGraphPart.cpp.
References _boundVal_, _eraseHole_(), _holes_, _holes_resize_policy_, _holes_size_, _inHoles_(), _updateEndIteratorSafe_(), GUM_EMIT1, GUM_ERROR, and onNodeAdded.
Referenced by gum::learning::StructuralConstraintDAG::StructuralConstraintDAG(), gum::EssentialGraph::_buildEssentialGraph_(), gum::prm::GSpan< GUM_SCALAR >::_sortPatterns_(), gum::prm::gspan::Pattern::addNodeWithLabel(), gum::learning::IBNLearner::learnDag_(), gum::learning::SimpleMiic::learnStructure(), gum::InfluenceDiagram< GUM_SCALAR >::moralGraph_(), gum::DAG::moralizedAncestralGraph(), gum::PDAG::moralizedAncestralGraph(), gum::UndiGraph::partialUndiGraph(), gum::learning::IBNLearner::prepareMiic_(), gum::MeekRules::propagateToCPDAG(), gum::MeekRules::propagateToDAG(), gum::rec_ancestral(), and gum::EssentialGraph::skeleton().
returns the set of nodes with directed path ingoing to a given node
Note that the set of nodes returned may be empty if no path within the ArcGraphPart is ingoing to the given node.
| id | the node which is the head of a directed path with the returned nodes |
Definition at line 191 of file arcGraphPart.cpp.
References gum::Set< Key >::begin(), gum::Set< Key >::contains(), gum::Set< Key >::empty(), gum::Set< Key >::erase(), gum::Set< Key >::insert(), and parents().
Referenced by gum::DAGmodel::ancestors().
|
inherited |
returns the set of arcs stored within the ArcGraphPart
Definition at line 59 of file arcGraphPart_inl.h.
References _arcs_.
Referenced by gum::EssentialGraph::_buildEssentialGraph_(), gum::prm::ClassBayesNet< GUM_SCALAR >::_init_(), gum::prm::gspan::Pattern::arcs(), gum::learning::SimpleMiic::learnStructure(), gum::DAG::moralGraph(), gum::PDAG::moralGraph(), gum::MeekRules::propagateToCPDAG(), gum::MeekRules::propagateToDAG(), and gum::DiGraph::toDot().
|
inherited |
a method to create a hashMap of VAL from a set of arcs (using for every arc, say x, the VAL a)
| a | the default value assigned to each arc in the returned Property |
| size | an optional parameter enabling to fine-tune the returned Property. Roughly speaking, it is a good practice to have a size equal to half the number of arcs. If you do not specify this parameter, the method will assign it for you. |
|
inherited |
a method to create a hashMap of VAL from a set of arcs (using for every arc, say x, the VAL f(x))
| f | a function assigning a VAL to any arc |
| size | an optional parameter enabling to fine-tune the returned Property. Roughly speaking, it is a good practice to have a size equal to half the number of arcs. If you do not specify this parameter, the method will assign it for you. |
|
inherited |
returns a copy of the set of nodes represented by the NodeGraphPart
Definition at line 356 of file nodeGraphPart_inl.h.
References _boundVal_, _inHoles_(), empty(), gum::Set< Key >::insert(), and sizeNodes().
Referenced by gum::MarginalTargetedInference< GUM_SCALAR >::MarginalTargetedInference(), gum::MarginalTargetedMRFInference< GUM_SCALAR >::MarginalTargetedMRFInference(), and gum::ImportanceSampling< GUM_SCALAR >::unsharpenBN_().
|
noexceptinherited |
a begin iterator to parse the set of nodes contained in the NodeGraphPart
Definition at line 333 of file nodeGraphPart_inl.h.
References NodeGraphPartIterator, and gum::NodeGraphPartIterator::validate_().
Referenced by gum::Estimator< GUM_SCALAR >::Estimator(), populateNodesFromProperty(), and gum::Estimator< GUM_SCALAR >::setFromBN().
|
inherited |
a begin iterator to parse the set of nodes contained in the NodeGraphPart
Definition at line 321 of file nodeGraphPart_inl.h.
References NodeGraphPartIteratorSafe, and gum::NodeGraphPartIterator::validate_().
|
inherited |
returns a number n such that all node ids are strictly lower than n
Definition at line 310 of file nodeGraphPart_inl.h.
References _boundVal_.
Referenced by _clearNodes_().
returns the set of children of a set of nodes
Definition at line 86 of file arcGraphPart_inl.h.
References children().
Referenced by ArcGraphPart(), gum::prm::ClassDependencyGraph< GUM_SCALAR >::_addArcs_(), gum::EssentialGraph::_buildEssentialGraph_(), gum::prm::gspan::Pattern::_expandCodeIsMinimal_(), gum::prm::SVE< GUM_SCALAR >::_initElimOrder_(), gum::prm::SVED< GUM_SCALAR >::_initElimOrder_(), gum::DAG::_minimalCondSetVisitDn_(), gum::DAG::_minimalCondSetVisitUp_(), gum::prm::gspan::Pattern::_not_rec_(), gum::MeekRules::_propagatesOrientationInChainOfRemainingEdges_(), gum::prm::gspan::Pattern::_rec_(), gum::BarrenNodesFinder::barrenNodes(), gum::MixedGraph::boundary(), children(), descendants(), directedUnorientedPath(), eraseChildren(), gum::DiGraph::hasDirectedPath(), gum::PDAG::hasMixedReallyOrientedPath(), gum::credal::CNLoopyPropagation< GUM_SCALAR >::initialize_(), gum::prm::PRMClassElementContainer< double >::isInputNode(), gum::prm::gspan::Pattern::isMinimal(), gum::credal::CNLoopyPropagation< GUM_SCALAR >::makeInferenceNodeToNeighbours_(), gum::DAG::minimalCondSet(), gum::MixedGraph::mixedUnorientedPath(), gum::learning::SimpleMiic::propagatesOrientationInChainOfRemainingEdges_(), gum::rec_hasMixedReallyOrientedPath(), gum::BayesBall::relevantTensors(), gum::dSeparationAlgorithm::relevantTensors(), gum::prm::gspan::Pattern::remove(), gum::BayesBall::requisiteNodes(), gum::dSeparationAlgorithm::requisiteNodes(), gum::DAGCycleDetector::setDAG(), gum::MixedGraph::toDot(), gum::PDAG::toDot(), and unvirtualizedEraseChildren().
returns the set of nodes with arc outgoing from a given node
Note that the set of arcs returned may be empty if no arc within the ArcGraphPart is outgoing from the given node.
| id | the node which is the tail of the arcs returned |
Definition at line 109 of file arcGraphPart_inl.h.
References _children_, and gum::emptyNodeSet.
|
virtual |
removes all the nodes and arcs from the graph
Reimplemented from gum::NodeGraphPart.
Reimplemented in gum::MixedGraph.
Definition at line 63 of file diGraph_inl.h.
References gum::ArcGraphPart::clearArcs(), and gum::NodeGraphPart::clearNodes().
Referenced by operator=().
|
inherited |
removes all the arcs from the ArcGraphPart
Definition at line 98 of file arcGraphPart.cpp.
References _arcs_, _children_, _parents_, GUM_EMIT2, and onArcDeleted.
Referenced by ~ArcGraphPart(), gum::DiGraph::clear(), gum::MixedGraph::clear(), operator=(), and gum::MixedGraph::operator=().
|
virtualinherited |
remove all the nodes from the NodeGraphPart
Definition at line 312 of file nodeGraphPart_inl.h.
References _clearNodes_().
Referenced by gum::DiGraph::clear(), gum::MixedGraph::clear(), gum::UndiGraph::clear(), and gum::MixedGraph::operator=().
|
static |
Build a complete DiGraph with n nodes.
| int | n |
Definition at line 57 of file diGraph.cpp.
References DiGraph(), addArc(), and gum::NodeGraphPart::addNodes().
returns the set of nodes with directed path outgoing from a given node
Note that the set of nodes returned may be empty if no path within the ArcGraphPart is outgoing from the given node.
| id | the node which is the tail of a directed path with the returned nodes |
Definition at line 174 of file arcGraphPart.cpp.
References gum::Set< Key >::begin(), children(), gum::Set< Key >::contains(), gum::Set< Key >::empty(), gum::Set< Key >::erase(), and gum::Set< Key >::insert().
Referenced by gum::DAGmodel::descendants().
|
inherited |
returns a directed path from node1 to node2 belonging to the set of arcs
| node1 | the id from which the path begins |
| node2 | the id to which the path ends |
| NotFound | exception is raised if no path can be found between the two nodes |
Definition at line 208 of file arcGraphPart.cpp.
References gum::List< Val >::empty(), gum::HashTable< Key, Val >::exists(), gum::List< Val >::front(), GUM_ERROR, gum::HashTable< Key, Val >::insert(), parents(), gum::List< Val >::popFront(), and gum::List< Val >::pushBack().
Referenced by gum::learning::SimpleMiic::orientationLatents_().
|
inherited |
returns an unoriented (directed) path from node1 to node2 in the arc set
| node1 | the id from which the path begins |
| node2 | the id to which the path ends |
| NotFound | exception is raised if no path can be found between the two nodes |
Definition at line 249 of file arcGraphPart.cpp.
References children(), gum::List< Val >::empty(), gum::HashTable< Key, Val >::exists(), gum::List< Val >::front(), GUM_ERROR, gum::HashTable< Key, Val >::insert(), parents(), gum::List< Val >::popFront(), and gum::List< Val >::pushBack().
|
inherited |
alias for emptyNodes
Definition at line 308 of file nodeGraphPart_inl.h.
References emptyNodes().
Referenced by asNodeSet(), gum::PDAG::cSeparation(), gum::DAG::dSeparation(), gum::prm::gspan::Pattern::remove(), and gum::PDAG::toDot().
|
inherited |
indicates wether the ArcGraphPart contains any arc
Definition at line 55 of file arcGraphPart_inl.h.
References _arcs_.
|
inherited |
indicates whether there exists nodes in the NodeGraphPart
Definition at line 306 of file nodeGraphPart_inl.h.
References sizeNodes().
Referenced by empty().
|
noexceptinherited |
the end iterator to parse the set of nodes contained in the NodeGraphPart
Definition at line 339 of file nodeGraphPart_inl.h.
References _endIteratorSafe_, and NodeGraphPartIterator.
Referenced by gum::Estimator< GUM_SCALAR >::Estimator(), populateNodesFromProperty(), and gum::Estimator< GUM_SCALAR >::setFromBN().
|
noexceptinherited |
the end iterator to parse the set of nodes contained in the NodeGraphPart
Definition at line 329 of file nodeGraphPart_inl.h.
References _endIteratorSafe_, and NodeGraphPartIteratorSafe.
|
virtualinherited |
removes an arc from the ArcGraphPart
| arc | the arc to be removed |
Definition at line 126 of file arcGraphPart_inl.h.
References _arcs_, _children_, _parents_, existsArc(), GUM_EMIT2, gum::Arc::head(), onArcDeleted, and gum::Arc::tail().
Referenced by gum::EssentialGraph::_buildEssentialGraph_(), gum::prm::ClusteredLayerGenerator< GUM_SCALAR >::_generateClassDag_(), gum::prm::LayerGenerator< GUM_SCALAR >::_generateClassDag_(), gum::MeekRules::_orientDoubleHeadedArcs_(), gum::BarrenNodesFinder::barrenNodes(), eraseChildren(), eraseParents(), eraseSetOfArcs_(), gum::learning::IBNLearner::learnDag_(), gum::learning::GreedyHillClimbing::learnStructure(), gum::learning::LocalSearchWithTabuList::learnStructure(), gum::learning::SimpleMiic::learnStructure(), gum::learning::SimpleMiic::orientationLatents_(), gum::learning::Miic::orientationMiic_(), gum::learning::SimpleMiic::orientationMiic_(), gum::learning::Miic::orientDoubleHeadedArcs_(), gum::prm::gspan::Pattern::pop_back(), unvirtualizedEraseChildren(), unvirtualizedEraseParents(), and unvirtualizedEraseSetOfArcs_().
|
inherited |
removes all the children of a given node
| id | the node all the children of which will be removed |
Definition at line 158 of file arcGraphPart_inl.h.
References _children_, children(), and eraseArc().
|
virtual |
remove a node and its adjacent arcs from the graph
| id | the id of the node to be removed |
Reimplemented from gum::NodeGraphPart.
Reimplemented in gum::MixedGraph.
Definition at line 79 of file diGraph_inl.h.
References gum::NodeGraphPart::eraseNode(), gum::ArcGraphPart::unvirtualizedEraseChildren(), and gum::ArcGraphPart::unvirtualizedEraseParents().
Referenced by gum::BarrenNodesFinder::barrenNodes(), gum::prm::gspan::Pattern::pop_back(), and gum::prm::gspan::Pattern::remove().
|
inherited |
erase all the parents of a given node
| id | the node all the parents of which will be removed |
Definition at line 144 of file arcGraphPart_inl.h.
References _parents_, eraseArc(), and parents().
|
protectedinherited |
a (virtualized) function to remove a given set of arcs
Definition at line 139 of file arcGraphPart_inl.h.
References eraseArc().
alias for existsNode
Definition at line 296 of file nodeGraphPart_inl.h.
References existsNode().
Referenced by gum::prm::StructuredInference< GUM_SCALAR >::_removeNode_(), gum::DiGraph::addArc(), gum::prm::gspan::Pattern::addArc(), gum::UndiGraph::addEdge(), gum::prm::gspan::Pattern::exists(), gum::DiGraph::hasDirectedPath(), gum::learning::IBNLearner::learnDag_(), and gum::DAG::moralizedAncestralGraph().
indicates whether a given arc exists
| arc | the arc we test whether or not it belongs to the ArcGraphPart |
Definition at line 61 of file arcGraphPart_inl.h.
References _arcs_.
Referenced by gum::learning::Miic::_existsDirectedPath_(), gum::learning::SimpleMiic::_existsDirectedPath_(), gum::MeekRules::_existsDirectedPath_(), gum::learning::Miic::_existsNonTrivialDirectedPath_(), gum::learning::SimpleMiic::_existsNonTrivialDirectedPath_(), gum::prm::ClusteredLayerGenerator< GUM_SCALAR >::_generateClassDag_(), gum::prm::LayerGenerator< GUM_SCALAR >::_generateClassDag_(), gum::prm::gspan::Pattern::_not_rec_(), gum::learning::Miic::_orientingVstructureMiic_(), gum::learning::SimpleMiic::_orientingVstructureMiic_(), gum::MeekRules::_propagatesOrientationInChainOfRemainingEdges_(), gum::prm::gspan::Pattern::_rec_(), gum::EssentialGraph::_strongly_protected_(), eraseArc(), gum::prm::gspan::Pattern::exists(), gum::learning::SimpleMiic::orientationLatents_(), gum::learning::Miic::updateProbaTriples_(), and gum::learning::SimpleMiic::updateProbaTriples_().
indicates whether a given arc exists
| tail | the tail of the arc we test the existence in the ArcGraphPart |
| head | the head of the arc we test the existence in the ArcGraphPart |
Definition at line 63 of file arcGraphPart_inl.h.
References _parents_.
returns true iff the NodeGraphPart contains the given nodeId
Definition at line 290 of file nodeGraphPart_inl.h.
References _boundVal_, and _inHoles_().
Referenced by eraseNode(), exists(), gum::PDAG::moralizedAncestralGraph(), gum::UndiGraph::partialUndiGraph(), and gum::rec_ancestral().
returns the set of family nodes of a set of nodes
Definition at line 102 of file arcGraphPart_inl.h.
References family().
returns the set of nodes which consists in the node and its parents
Note that the set of nodes returned may be empty if no path within the ArcGraphPart is outgoing from the given node.
| id | the node which is the tail of a directed path with the returned nodes |
Definition at line 80 of file arcGraphPart_inl.h.
References parents().
Referenced by family().
checks whether there exists a directed path from from to to
If from==to, this function checks if a directed cycle containing from exists.
| from | |
| to |
Definition at line 151 of file diGraph.cpp.
References gum::ArcGraphPart::children(), gum::Set< Key >::contains(), gum::List< Val >::empty(), gum::NodeGraphPart::exists(), gum::List< Val >::front(), gum::Set< Key >::insert(), gum::List< Val >::popFront(), and gum::List< Val >::pushBack().
Referenced by gum::DAG::addArc(), and gum::PDAG::addArc().
|
inherited |
a method to create a list of VAL from a set of arcs (using for every arc, say x, the VAL f(x))
| f | a function assigning a VAL to any arc |
|
inherited |
a method to create a list of VAL from a set of nodes (using for every nodee, say x, the VAL f(x))
| f | a function assigning a VAL to any node |
References listMapNodes().
Referenced by listMapNodes().
|
inherited |
returns a new node id, not yet used by any node
Definition at line 232 of file nodeGraphPart_inl.h.
References _boundVal_, and _holes_.
|
inherited |
return *this as a NodeGraphPart
Definition at line 368 of file nodeGraphPart_inl.h.
References NodeGraphPart().
Referenced by gum::MeekRules::_complete_(), gum::prm::ClusteredLayerGenerator< GUM_SCALAR >::_generateClassDag_(), gum::prm::LayerGenerator< GUM_SCALAR >::_generateClassDag_(), gum::prm::ClassBayesNet< GUM_SCALAR >::_init_(), gum::prm::SVE< GUM_SCALAR >::_initElimOrder_(), gum::prm::SVED< GUM_SCALAR >::_initElimOrder_(), gum::prm::SVE< GUM_SCALAR >::_initLiftedNodes_(), gum::MeekRules::_orientDoubleHeadedArcs_(), gum::MeekRules::_propagates_(), gum::prm::GSpan< GUM_SCALAR >::_sortPatterns_(), gum::prm::PRMFactory< GUM_SCALAR >::addAttribute(), gum::UndiGraph::hasUndirectedCycle(), gum::DAG::moralGraph(), gum::PDAG::moralGraph(), gum::DAG::moralizedAncestralGraph(), gum::PDAG::moralizedAncestralGraph(), gum::prm::gspan::Pattern::nodes(), gum::UndiGraph::nodes2ConnectedComponent(), gum::learning::Miic::orientDoubleHeadedArcs_(), gum::UndiGraph::partialUndiGraph(), gum::learning::IBNLearner::prepareMiic_(), gum::MeekRules::propagateToDAG(), gum::DiGraph::toDot(), gum::MixedGraph::toDot(), gum::PDAG::toDot(), and gum::UndiGraph::toDot().
|
inherited |
a method to create a HashTable with key:NodeId and value:VAL
VAL are computed from the nodes using for all node x, VAL f(x). This method is a wrapper of the same method in HashTable.
| f | a function assigning a VAL to any node |
| size | an optional parameter enabling to fine-tune the returned Property. Roughly speaking, it is a good practice to have a size equal to half the number of nodes. If you do not specify this parameter, the method will assign it for you. |
References nodesPropertyFromFunction(), and size().
Referenced by nodesPropertyFromFunction().
|
inherited |
a method to create a hashMap with key:NodeId and value:VAL
for all nodes, the value stored is a. This method is a wrapper of the same method in HashTable.
| a | the default value assigned to each edge in the returned Property |
| size | an optional parameter enabling to fine-tune the returned Property. Roughly speaking, it is a good practice to have a size equal to half the number of nodes. If you do not specify this parameter, the method will assign it for you. |
References nodesPropertyFromVal(), and size().
Referenced by gum::BinaryJoinTreeConverterDefault::convert(), gum::UndiGraph::hasUndirectedCycle(), and nodesPropertyFromVal().
|
inherited |
check whether two NodeGraphParts contain different nodes
| p | the NodeGraphPart to be compared with "this" |
Definition at line 354 of file nodeGraphPart_inl.h.
References NodeGraphPart(), and operator==().
copy operator
| g | the DiGraph to copy |
Definition at line 68 of file diGraph_inl.h.
References DiGraph(), clear(), gum::ArcGraphPart::operator=(), and gum::NodeGraphPart::operator=().
Referenced by gum::DAG::operator=().
|
inherited |
tests whether two ArcGraphParts contain the same arcs
| p | the ArcGraphPart that we compare with this |
Definition at line 201 of file arcGraphPart_inl.h.
References ArcGraphPart(), and _arcs_.
Referenced by gum::DiGraph::operator==(), and gum::MixedGraph::operator==().
tests whether two DiGraphs are identical (same nodes, same arcs)
| g | the DiGraph with which "this" is compared |
Definition at line 89 of file diGraph_inl.h.
References DiGraph(), gum::ArcGraphPart::operator==(), and gum::NodeGraphPart::operator==().
|
inherited |
check whether two NodeGraphParts contain the same nodes
| p | the NodeGraphPart to be compared with "this" |
Definition at line 343 of file nodeGraphPart_inl.h.
References NodeGraphPart(), _boundVal_, and _holes_.
Referenced by operator!=(), gum::DiGraph::operator==(), gum::MixedGraph::operator==(), and gum::UndiGraph::operator==().
returns the set of parents of a set of nodes
Definition at line 94 of file arcGraphPart_inl.h.
References parents().
returns the set of nodes with arc ingoing to a given node
Note that the set of arcs returned may be empty if no arc within the ArcGraphPart is ingoing into the given node.
| id | the node toward which the arcs returned are pointing |
Definition at line 75 of file arcGraphPart_inl.h.
References _parents_, and gum::emptyNodeSet.
Referenced by gum::MeekRules::_complete_(), gum::MeekRules::_critereMinParents_(), gum::learning::Miic::_existsDirectedPath_(), gum::learning::SimpleMiic::_existsDirectedPath_(), gum::MeekRules::_existsDirectedPath_(), gum::learning::Miic::_existsNonTrivialDirectedPath_(), gum::learning::SimpleMiic::_existsNonTrivialDirectedPath_(), gum::prm::gspan::Pattern::_expandCodeIsMinimal_(), gum::prm::ClusteredLayerGenerator< GUM_SCALAR >::_generateClass_(), gum::prm::ClusteredLayerGenerator< GUM_SCALAR >::_generateClassDag_(), gum::prm::LayerGenerator< GUM_SCALAR >::_generateClassDag_(), gum::prm::LayerGenerator< GUM_SCALAR >::_generateClasses_(), gum::prm::ClusteredLayerGenerator< GUM_SCALAR >::_generateCluster_(), gum::prm::SVE< GUM_SCALAR >::_initElimOrder_(), gum::prm::SVED< GUM_SCALAR >::_initElimOrder_(), gum::prm::SVE< GUM_SCALAR >::_initLiftedNodes_(), gum::prm::SVED< GUM_SCALAR >::_initLiftedNodes_(), gum::MeekRules::_isOrientable_(), gum::DAG::_minimalCondSetVisitDn_(), gum::DAG::_minimalCondSetVisitUp_(), gum::prm::gspan::Pattern::_not_rec_(), gum::MeekRules::_orientDoubleHeadedArcs_(), gum::MeekRules::_propagates_(), gum::learning::Miic::_propagatingOrientationMiic_(), gum::learning::SimpleMiic::_propagatingOrientationMiic_(), gum::prm::gspan::Pattern::_rec_(), gum::EssentialGraph::_strongly_protected_(), ancestors(), gum::BarrenNodesFinder::barrenNodes(), gum::MixedGraph::boundary(), directedPath(), directedUnorientedPath(), eraseParents(), family(), gum::MixedGraph::hasMixedOrientedPath(), gum::credal::CNLoopyPropagation< GUM_SCALAR >::initialize_(), gum::prm::PRMClassElementContainer< double >::isInputNode(), gum::learning::Miic::isMaxIndegree_(), gum::prm::gspan::Pattern::isMinimal(), gum::learning::SimpleMiic::isOrientable_(), gum::learning::SimpleMiic::learnPDAG(), gum::learning::SimpleMiic::learnStructure(), gum::credal::CNLoopyPropagation< GUM_SCALAR >::makeInferenceNodeToNeighbours_(), gum::DAG::minimalCondSet(), gum::MixedGraph::mixedOrientedPath(), gum::MixedGraph::mixedUnorientedPath(), gum::DAG::moralGraph(), gum::PDAG::moralGraph(), gum::DAG::moralizedAncestralGraph(), gum::learning::Miic::orientDoubleHeadedArcs_(), gum::prm::gspan::DFSTree< GUM_SCALAR >::parent(), gum::prm::gspan::DFSTree< GUM_SCALAR >::parent(), parents(), gum::rec_ancestral(), gum::BayesBall::relevantTensors(), gum::dSeparationAlgorithm::relevantTensors(), gum::prm::gspan::Pattern::remove(), gum::BayesBall::requisiteNodes(), gum::dSeparationAlgorithm::requisiteNodes(), gum::prm::gspan::Pattern::rightmostPath(), gum::DAGCycleDetector::setDAG(), and unvirtualizedEraseParents().
|
inherited |
populateNodes clears *this and fills it with the same nodes as "s"
populateNodes should basically be the preferred way to insert nodes with IDs not selected by the internal idFactory.
| s | the NodeGraphPart to be copied |
Definition at line 83 of file nodeGraphPart.cpp.
References NodeGraphPart(), _boundVal_, _holes_, _holes_resize_policy_, _holes_size_, _updateEndIteratorSafe_(), and clear().
Referenced by gum::DAG::moralGraph(), gum::PDAG::moralGraph(), and operator=().
|
inherited |
populateNodesFromProperty clears *this and fills it with the keys of "h"
populateNodes should basically be the preferred way to insert nodes with IDs not selected by the internal idFactory.
References NodeGraphPart(), begin(), end(), and toString().
|
inherited |
alias for sizeNodes
Definition at line 288 of file nodeGraphPart_inl.h.
References sizeNodes().
Referenced by gum::StaticTriangulation::StaticTriangulation(), gum::prm::gspan::DFSTree< GUM_SCALAR >::_addChild_(), gum::StaticTriangulation::_triangulate_(), gum::learning::GreedyHillClimbing::learnStructure(), gum::learning::LocalSearchWithTabuList::learnStructure(), nodesPropertyFromFunction(), nodesPropertyFromVal(), gum::BayesBall::relevantTensors(), gum::dSeparationAlgorithm::relevantTensors(), gum::BayesBall::requisiteNodes(), gum::dSeparationAlgorithm::requisiteNodes(), gum::StaticTriangulation::setGraph(), gum::DAGmodel::size(), gum::prm::gspan::Pattern::size(), gum::UGmodel::size(), and gum::UndiGraph::toDot().
|
inherited |
indicates the number of arcs stored within the ArcGraphPart
Definition at line 57 of file arcGraphPart_inl.h.
References _arcs_.
Referenced by gum::prm::gspan::Pattern::sizeArcs().
|
inherited |
returns the number of nodes in the NodeGraphPart
Definition at line 284 of file nodeGraphPart_inl.h.
References _boundVal_, and _holes_.
Referenced by gum::BinaryJoinTreeConverterDefault::_markConnectedComponent_(), asNodeSet(), gum::BinaryJoinTreeConverterDefault::convert(), emptyNodes(), and size().
|
virtual |
to friendly display the content of the graph in the DOT syntax
| name | The graph name in the dot syntax. Default is G. |
Reimplemented in gum::MixedGraph, gum::PDAG, and gum::prm::gspan::Pattern.
Definition at line 88 of file diGraph.cpp.
References gum::ArcGraphPart::arcs(), and gum::NodeGraphPart::nodes().
Build and return a topological order.
| InvalidDirectedCycle | Raised if this DiGraph contains cycles. |
Definition at line 111 of file diGraph.cpp.
References GUM_ERROR, and topologicalOrder().
Referenced by gum::IBayesNet< double >::arcs(), gum::learning::SimpleMiic::learnPDAG(), gum::learning::SimpleMiic::learnStructure(), and topologicalOrder().
|
virtual |
to friendly display the content of the graph
Reimplemented from gum::NodeGraphPart.
Reimplemented in gum::MixedGraph.
Definition at line 81 of file diGraph.cpp.
References gum::ArcGraphPart::toString(), and gum::NodeGraphPart::toString().
Referenced by gum::operator<<().
|
inherited |
same function as eraseChildren but without any virtual call to an erase
| id | the node whose outgoing arcs will be removed |
Definition at line 189 of file arcGraphPart_inl.h.
References _children_, children(), and eraseArc().
Referenced by gum::DiGraph::eraseNode(), and gum::MixedGraph::eraseNode().
|
inherited |
same function as eraseParents but without any virtual call to an erase
| id | the node whose ingoing arcs will be removed |
Definition at line 177 of file arcGraphPart_inl.h.
References _parents_, eraseArc(), and parents().
Referenced by gum::DiGraph::eraseNode(), and gum::MixedGraph::eraseNode().
|
protectedinherited |
similar to eraseSetOfArcs_ except that it is unvirtualized
Definition at line 172 of file arcGraphPart_inl.h.
References eraseArc().
the set of all the arcs contained within the ArcGraphPart
Definition at line 316 of file arcGraphPart.h.
Referenced by ArcGraphPart(), ArcGraphPart(), addArc(), arcs(), clearArcs(), emptyArcs(), eraseArc(), existsArc(), operator=(), operator==(), sizeArcs(), and toString().
|
privateinherited |
the id below which NodeIds may belong to the NodeGraphPart
Definition at line 528 of file nodeGraphPart.h.
Referenced by NodeGraphPart(), NodeGraphPart(), _addHole_(), _clearNodes_(), _updateEndIteratorSafe_(), addNode(), addNodeWithId(), asNodeSet(), bound(), existsNode(), nextNodeId(), operator==(), populateNodes(), sizeNodes(), and toString().
|
privateinherited |
for each arc, the set of its children
Definition at line 322 of file arcGraphPart.h.
Referenced by ArcGraphPart(), _checkChildren_(), addArc(), children(), clearArcs(), eraseArc(), eraseChildren(), operator=(), and unvirtualizedEraseChildren().
|
privateinherited |
the end iterator (used to speed-up parsings of the NodeGraphPart)
Definition at line 525 of file nodeGraphPart.h.
Referenced by NodeGraphPart(), NodeGraphPart(), _updateEndIteratorSafe_(), end(), and endSafe().
|
privateinherited |
the set of nodes not contained in the NodeGraphPart in the interval 1.
. max
Definition at line 516 of file nodeGraphPart.h.
Referenced by NodeGraphPart(), NodeGraphPart(), ~NodeGraphPart(), _addHole_(), _clearNodes_(), _eraseHole_(), _inHoles_(), _sizeHoles_(), addNode(), addNodeWithId(), nextNodeId(), operator==(), populateNodes(), and sizeNodes().
|
privateinherited |
value for holes configuration
Definition at line 522 of file nodeGraphPart.h.
Referenced by NodeGraphPart(), NodeGraphPart(), _addHole_(), addNodeWithId(), and populateNodes().
|
privateinherited |
value for holes configuration
Definition at line 519 of file nodeGraphPart.h.
Referenced by NodeGraphPart(), NodeGraphPart(), _addHole_(), addNodeWithId(), and populateNodes().
|
privateinherited |
for each arc, the sets of its parents
Definition at line 319 of file arcGraphPart.h.
Referenced by ArcGraphPart(), _checkParents_(), addArc(), clearArcs(), eraseArc(), eraseParents(), existsArc(), operator=(), parents(), and unvirtualizedEraseParents().
Definition at line 102 of file arcGraphPart.h.
Referenced by ArcGraphPart(), addArc(), and operator=().
Definition at line 103 of file arcGraphPart.h.
Referenced by clearArcs(), and eraseArc().
|
inherited |
Definition at line 289 of file nodeGraphPart.h.
Referenced by addNode(), and addNodeWithId().
|
inherited |
Definition at line 290 of file nodeGraphPart.h.
Referenced by _clearNodes_(), and eraseNode().