58#ifndef GUM_LEARNING_STRUCTURAL_CONSTRAINT_SLICE_ORDER_H
59#define GUM_LEARNING_STRUCTURAL_CONSTRAINT_SLICE_ORDER_H
238#ifndef DOXYGEN_SHOULD_SKIP_THIS
242# define GUM_CONSTRAINT_CLASS_NAME StructuralConstraintSliceOrder
244# undef GUM_CONSTRAINT_CLASS_NAME
Base class for all oriented graphs.
The class for notifying learning algorithms of new arc additions.
The class for notifying learning algorithms of arc removals.
The class for notifying learning algorithms of arc reversals.
StructuralConstraintSetStatic()
bool checkModificationAlone(const ArcReversal &change) const
checks whether the constraints enable to reverse an arc
void modifyGraphAlone(const ArcDeletion &change)
notify the constraint of a modification of the graph
bool checkModificationAlone(const ArcDeletion &change) const
checks whether the constraints enable to remove an arc
NodeProperty< NodeId > _SliceOrder_order_
slices to which belong the nodes
void modifyGraphAlone(const ArcAddition &change)
notify the constraint of a modification of the graph
bool checkArcDeletionAlone(NodeId x, NodeId y) const
checks whether the constraints enable to remove arc (x,y)
void setDefaultSlice(NodeId slice)
assign a given slice to all the nodes specified in the partial order
bool checkModificationAlone(const ArcAddition &change) const
checks whether the constraints enable to add an arc
void modifyGraphAlone(const ArcReversal &change)
notify the constraint of a modification of the graph
void setGraphAlone(const DiGraph &graph)
sets a new graph from which we will perform checkings
bool checkArcAdditionAlone(NodeId x, NodeId y) const
checks whether the constraints enable to add arc (x,y)
bool isAlwaysInvalidAlone(const GraphChange &change) const
indicates whether a change will always violate the constraint
bool checkModificationAlone(const GraphChange &change) const
checks whether the constraints enable to perform a graph change
const NodeProperty< NodeId > & sliceOrder() const
returns the current slice order
StructuralConstraintSliceOrder & operator=(const StructuralConstraintSliceOrder &from)
copy operator
StructuralConstraintSliceOrder()
default constructor
virtual ~StructuralConstraintSliceOrder()
destructor
void setSliceOrder(const NodeProperty< NodeId > &slice)
sets the time slices of all the nodes in the property
void modifyGraphAlone(const GraphChange &change)
notify the constraint of a modification of the graph
bool checkArcReversalAlone(NodeId x, NodeId y) const
checks whether the constraints enable to reverse arc (x,y)
void addNode(NodeId node, NodeId slice)
adds a new node in the slice order
Size NodeId
Type for node ids.
HashTable< NodeId, VAL > NodeProperty
Property on graph elements.
include the inlined functions if necessary
gum is the global namespace for all aGrUM entities
the base class for structural constraints used by learning algorithms that learn a directed graph str...
the structural constraint imposing a partial order over nodes