![]() |
aGrUM
0.16.0
|
The class imposing a N-sized tabu list as a structural constraints for learning algorithms. More...
#include <structuralConstraintTabuList.h>
Public Member Functions | |
Constructors / Destructors | |
StructuralConstraintTabuList () | |
default constructor More... | |
StructuralConstraintTabuList (const DiGraph &graph) | |
constructor starting with a given graph More... | |
StructuralConstraintTabuList (const StructuralConstraintTabuList &from) | |
copy constructor More... | |
StructuralConstraintTabuList (StructuralConstraintTabuList &&from) | |
move constructor More... | |
virtual | ~StructuralConstraintTabuList () |
destructor More... | |
Operators | |
StructuralConstraintTabuList & | operator= (const StructuralConstraintTabuList &from) |
copy operator More... | |
StructuralConstraintTabuList & | operator= (StructuralConstraintTabuList &&from) |
move operator More... | |
Specific Accessors / Modifiers | |
void | setTabuListSize (Size new_size) |
sets the size of the tabu list More... | |
void | setGraphAlone (const DiGraph &graph) |
sets a new graph from which we will perform checkings More... | |
void | modifyGraphAlone (const ArcAddition &change) |
notify the constraint of a modification of the graph More... | |
void | modifyGraphAlone (const ArcDeletion &change) |
notify the constraint of a modification of the graph More... | |
void | modifyGraphAlone (const ArcReversal &change) |
notify the constraint of a modification of the graph More... | |
void | modifyGraphAlone (const GraphChange &change) |
notify the constraint of a modification of the graph More... | |
bool | isAlwaysInvalidAlone (const GraphChange &change) const |
indicates whether a change will always violate the constraint More... | |
bool | checkArcAdditionAlone (NodeId x, NodeId y) const |
checks whether the constraints enable to add arc (x,y) More... | |
bool | checkArcDeletionAlone (NodeId x, NodeId y) const |
checks whether the constraints enable to remove arc (x,y) More... | |
bool | checkArcReversalAlone (NodeId x, NodeId y) const |
checks whether the constraints enable to reverse arc (x,y) More... | |
bool | checkModificationAlone (const GraphChange &change) const |
checks whether the constraints enable to perform a graph change More... | |
bool | checkModificationAlone (const ArcAddition &change) const |
checks whether the constraints enable to add an arc More... | |
bool | checkModificationAlone (const ArcDeletion &change) const |
checks whether the constraints enable to remove an arc More... | |
bool | checkModificationAlone (const ArcReversal &change) const |
checks whether the constraints enable to reverse an arc More... | |
Public Types | |
using | allConstraints = __ConstraintSet< void > |
Protected Attributes | |
Bijection< GraphChange, NodeId > | _TabuList__changes |
the tabu list More... | |
NodeId | _TabuList__offset {0} |
the index of the oldest element More... | |
The class imposing a N-sized tabu list as a structural constraints for learning algorithms.
By default, the size of the tabu list is 2, but it can be changed by the user using method setTabuSize (). Each time you modify the graph you learn, the inverse change is put into the tabu list. For instance, if the learning algorithm adds an arc (X, Y), then the "Deletion of Arc (X,Y)" operation is inserted into the tabu list. If the operation performed is an arc (X,Y) reversal, then the "Reversal of Arc (Y,X)" operation is added to the tabu list.
Definition at line 69 of file structuralConstraintTabuList.h.
|
inherited |
Definition at line 42 of file structuralConstraint.h.
gum::learning::StructuralConstraintTabuList::StructuralConstraintTabuList | ( | ) |
default constructor
Definition at line 42 of file structuralConstraintTabuList.cpp.
References _TabuList__changes, and GUM_STRUCTURAL_CONSTRAINT_TABU_LIST_DEFAULT_SIZE.
gum::learning::StructuralConstraintTabuList::StructuralConstraintTabuList | ( | const DiGraph & | graph | ) |
constructor starting with a given graph
Definition at line 58 of file structuralConstraintTabuList.cpp.
References _TabuList__changes, and GUM_STRUCTURAL_CONSTRAINT_TABU_LIST_DEFAULT_SIZE.
gum::learning::StructuralConstraintTabuList::StructuralConstraintTabuList | ( | const StructuralConstraintTabuList & | from | ) |
copy constructor
Definition at line 75 of file structuralConstraintTabuList.cpp.
gum::learning::StructuralConstraintTabuList::StructuralConstraintTabuList | ( | StructuralConstraintTabuList && | from | ) |
move constructor
Definition at line 83 of file structuralConstraintTabuList.cpp.
|
virtual |
destructor
Definition at line 91 of file structuralConstraintTabuList.cpp.
References operator=().
bool gum::learning::StructuralConstraintTabuList::checkArcAdditionAlone | ( | NodeId | x, |
NodeId | y | ||
) | const |
checks whether the constraints enable to add arc (x,y)
an arc can be added if and only if its extremal nodes belong to the graph and the arc does not already exist.
bool gum::learning::StructuralConstraintTabuList::checkArcDeletionAlone | ( | NodeId | x, |
NodeId | y | ||
) | const |
checks whether the constraints enable to remove arc (x,y)
an arc can be removed if and only if the arc exists.
bool gum::learning::StructuralConstraintTabuList::checkArcReversalAlone | ( | NodeId | x, |
NodeId | y | ||
) | const |
checks whether the constraints enable to reverse arc (x,y)
an arc can be reversed if and only if it exists and arc (y,x) does not.
bool gum::learning::StructuralConstraintTabuList::checkModificationAlone | ( | const GraphChange & | change | ) | const |
checks whether the constraints enable to perform a graph change
An arc can be added if and only if its extremal nodes belong to the graph and the arc does not already exist. An arc can be removed if and only if the arc exists. An arc (x,y) can be reversed if and only if it exists and arc (y,x) does not.
bool gum::learning::StructuralConstraintTabuList::checkModificationAlone | ( | const ArcAddition & | change | ) | const |
checks whether the constraints enable to add an arc
an arc can be added if and only if its extremal nodes belong to the graph and the arc does not already exist.
bool gum::learning::StructuralConstraintTabuList::checkModificationAlone | ( | const ArcDeletion & | change | ) | const |
checks whether the constraints enable to remove an arc
an arc can be removed if and only if the arc exists.
bool gum::learning::StructuralConstraintTabuList::checkModificationAlone | ( | const ArcReversal & | change | ) | const |
checks whether the constraints enable to reverse an arc
an arc (x,y) can be reversed if and only if it exists and arc (y,x) does not.
bool gum::learning::StructuralConstraintTabuList::isAlwaysInvalidAlone | ( | const GraphChange & | change | ) | const |
indicates whether a change will always violate the constraint
Some learning algorithms need examine several times whether a given graph change can be applied. For instance, the first time arc (X,Y) addition is considered, the learning algorithm may discard this change because it violates the structural constraint (e.g., if the latter enforces a DAG structure, this arc addition might induce a directed cycle), but, later on, other arc removal may induce that the arc addition is now possible. Such change is thus not always invalid. Conversely, there are changes that can be discarded once and for all. For instance, in a 2TBN structure, it is always impossible to add a backward-time arc. Such graph changes are always invalid and are therefore tagged as such by the isAlwaysInvalid method.
void gum::learning::StructuralConstraintTabuList::modifyGraphAlone | ( | const ArcAddition & | change | ) |
notify the constraint of a modification of the graph
InvalidNode | exception is thrown if an arc (x,y) is added and x or y does not belong to the graph nodes |
void gum::learning::StructuralConstraintTabuList::modifyGraphAlone | ( | const ArcDeletion & | change | ) |
notify the constraint of a modification of the graph
void gum::learning::StructuralConstraintTabuList::modifyGraphAlone | ( | const ArcReversal & | change | ) |
notify the constraint of a modification of the graph
InvalidNode | exception is thrown if at least one extremity of the arc does not belong to the graph nodes |
void gum::learning::StructuralConstraintTabuList::modifyGraphAlone | ( | const GraphChange & | change | ) |
notify the constraint of a modification of the graph
InvalidNode | exception is thrown if an arc (x,y) is added and x or y does not belong to the graph nodes |
StructuralConstraintTabuList & gum::learning::StructuralConstraintTabuList::operator= | ( | const StructuralConstraintTabuList & | from | ) |
copy operator
Definition at line 97 of file structuralConstraintTabuList.cpp.
References _TabuList__changes, and _TabuList__offset.
Referenced by ~StructuralConstraintTabuList().
StructuralConstraintTabuList & gum::learning::StructuralConstraintTabuList::operator= | ( | StructuralConstraintTabuList && | from | ) |
move operator
Definition at line 107 of file structuralConstraintTabuList.cpp.
References _TabuList__changes, and _TabuList__offset.
void gum::learning::StructuralConstraintTabuList::setGraphAlone | ( | const DiGraph & | graph | ) |
sets a new graph from which we will perform checkings
void gum::learning::StructuralConstraintTabuList::setTabuListSize | ( | Size | new_size | ) |
sets the size of the tabu list
Referenced by gum::learning::genericBNLearner::useLocalSearchWithTabuList().
|
protected |
the tabu list
Definition at line 209 of file structuralConstraintTabuList.h.
Referenced by operator=(), and StructuralConstraintTabuList().
|
protected |
the index of the oldest element
Definition at line 212 of file structuralConstraintTabuList.h.
Referenced by operator=().