![]() |
OR-Tools
8.0
|
Specialization of LocalSearchOperator built from an array of IntVars which specifies the scope of the operator.
This class also takes care of storing current variable values in Start(), keeps track of changes done by the operator and builds the delta. The Deactivate() method can be used to perform Large Neighborhood Search.
Definition at line 1032 of file constraint_solveri.h.
Public Member Functions | |
| IntVarLocalSearchOperator () | |
| IntVarLocalSearchOperator (const std::vector< IntVar * > &vars, bool keep_inverse_values=false) | |
| ~IntVarLocalSearchOperator () override | |
| bool | MakeNextNeighbor (Assignment *delta, Assignment *deltadelta) override |
| Redefines MakeNextNeighbor to export a simpler interface. More... | |
| bool | HoldsDelta () const override |
| virtual bool | HoldsDelta () const |
| void | Start (const Assignment *assignment) override |
| This method should not be overridden. More... | |
| virtual bool | IsIncremental () const |
| int | Size () const |
| const int64 & | Value (int64 index) const |
| Returns the value in the current assignment of the variable of given index. More... | |
| IntVar * | Var (int64 index) const |
| Returns the variable of given index. More... | |
| virtual bool | SkipUnchanged (int index) const |
| const int64 & | OldValue (int64 index) const |
| void | SetValue (int64 index, const int64 &value) |
| bool | Activated (int64 index) const |
| void | Activate (int64 index) |
| void | Deactivate (int64 index) |
| bool | ApplyChanges (Assignment *delta, Assignment *deltadelta) const |
| void | RevertChanges (bool incremental) |
| void | AddVars (const std::vector< IntVar * > &vars) |
| virtual void | OnStart () |
| Called by Start() after synchronizing the operator with the current assignment. More... | |
| virtual void | Reset () |
| virtual const LocalSearchOperator * | Self () const |
| virtual bool | HasFragments () const |
Protected Member Functions | |
| virtual bool | MakeOneNeighbor () |
| Creates a new neighbor. More... | |
| bool | IsInverseValue (int64 index) const |
| int64 | InverseValue (int64 index) const |
| int64 | OldInverseValue (int64 index) const |
| void | SetInverseValue (int64 index, int64 value) |
| void | SetOldInverseValue (int64 index, int64 value) |
| void | MarkChange (int64 index) |
| OnStart() should really be protected, but then SWIG doesn't see it. More... | |
Protected Attributes | |
| std::vector< IntVar * > | vars_ |
| std::vector< int64 > | values_ |
| std::vector< int64 > | old_values_ |
| std::vector< int64 > | prev_values_ |
| std::vector< int > | assignment_indices_ |
| Bitset64 | activated_ |
| Bitset64 | was_activated_ |
| SparseBitset | changes_ |
| SparseBitset | delta_changes_ |
| bool | cleared_ |
| IntVarLocalSearchHandler | var_handler_ |
|
inline |
Definition at line 1035 of file constraint_solveri.h.
|
inlineexplicit |
Definition at line 1039 of file constraint_solveri.h.
|
inlineoverride |
Definition at line 1054 of file constraint_solveri.h.
|
inlineinherited |
Definition at line 863 of file constraint_solveri.h.
|
inlineinherited |
Definition at line 862 of file constraint_solveri.h.
|
inlineinherited |
Definition at line 908 of file constraint_solveri.h.
|
inlineinherited |
Definition at line 871 of file constraint_solveri.h.
|
inlineinherited |
Definition at line 867 of file constraint_solveri.h.
|
inlinevirtualinherited |
Reimplemented in PathLns, BaseLns, SwigDirector_PathOperator, SwigDirector_ChangeValue, SwigDirector_BaseLns, SwigDirector_SequenceVarLocalSearchOperator, SwigDirector_IntVarLocalSearchOperator, SwigDirector_LocalSearchOperator, SwigDirector_ChangeValue, SwigDirector_BaseLns, SwigDirector_IntVarLocalSearchOperator, SwigDirector_LocalSearchOperator, SwigDirector_PathOperator, SwigDirector_ChangeValue, SwigDirector_BaseLns, SwigDirector_SequenceVarLocalSearchOperator, SwigDirector_IntVarLocalSearchOperator, and SwigDirector_LocalSearchOperator.
Definition at line 815 of file constraint_solveri.h.
|
inlinevirtualinherited |
Reimplemented in NeighborhoodLimit, VarLocalSearchOperator< V, Val, Handler >, SwigDirector_PathOperator, SwigDirector_ChangeValue, SwigDirector_BaseLns, SwigDirector_SequenceVarLocalSearchOperator, SwigDirector_IntVarLocalSearchOperator, SwigDirector_LocalSearchOperator, SwigDirector_ChangeValue, SwigDirector_BaseLns, SwigDirector_IntVarLocalSearchOperator, SwigDirector_LocalSearchOperator, SwigDirector_PathOperator, SwigDirector_ChangeValue, SwigDirector_BaseLns, SwigDirector_SequenceVarLocalSearchOperator, SwigDirector_IntVarLocalSearchOperator, and SwigDirector_LocalSearchOperator.
Definition at line 816 of file constraint_solveri.h.
|
inlineoverrideinherited |
Definition at line 830 of file constraint_solveri.h.
Definition at line 1077 of file constraint_solveri.h.
|
inlinevirtualinherited |
Definition at line 846 of file constraint_solveri.h.
|
inlineprotected |
Definition at line 1072 of file constraint_solveri.h.
|
overridevirtual |
Redefines MakeNextNeighbor to export a simpler interface.
The calls to ApplyChanges() and RevertChanges() are factored in this method, hiding both delta and deltadelta from subclasses which only need to override MakeOneNeighbor(). Therefore this method should not be overridden. Override MakeOneNeighbor() instead.
Implements LocalSearchOperator.
Reimplemented in PairNodeSwapActiveOperator< swap_first >, IndexPairSwapActiveOperator, and SwapIndexPairOperator.
Definition at line 74 of file local_search.cc.
|
protectedvirtual |
Creates a new neighbor.
It returns false when the neighborhood is completely explored. MakeNextNeighbor() in a subclass of IntVarLocalSearchOperator.
Reimplemented in TSPLns, PathOperator, ChangeValue, BaseLns, BaseInactiveNodeToPathOperator, RelocateExpensiveChain, MakePairActiveOperator, SwigDirector_PathOperator, SwigDirector_ChangeValue, SwigDirector_IntVarLocalSearchOperator, SwigDirector_ChangeValue, SwigDirector_IntVarLocalSearchOperator, SwigDirector_PathOperator, SwigDirector_ChangeValue, and SwigDirector_IntVarLocalSearchOperator.
Definition at line 95 of file local_search.cc.
|
inlineprotectedinherited |
OnStart() should really be protected, but then SWIG doesn't see it.
So we make it public, but only subclasses should access to it (to override it).
Definition at line 932 of file constraint_solveri.h.
Definition at line 1079 of file constraint_solveri.h.
Definition at line 857 of file constraint_solveri.h.
|
inlinevirtualinherited |
Called by Start() after synchronizing the operator with the current assignment.
Should be overridden instead of Start() to avoid calling VarLocalSearchOperator::Start explicitly.
Reimplemented in SwapIndexPairOperator, SwigDirector_PathOperator, SwigDirector_ChangeValue, SwigDirector_IntVarLocalSearchOperator, SwigDirector_ChangeValue, SwigDirector_IntVarLocalSearchOperator, SwigDirector_PathOperator, SwigDirector_ChangeValue, and SwigDirector_IntVarLocalSearchOperator.
Definition at line 927 of file constraint_solveri.h.
|
inlinevirtualinherited |
Reimplemented in PathOperator, SwigDirector_PathOperator, SwigDirector_ChangeValue, SwigDirector_BaseLns, SwigDirector_SequenceVarLocalSearchOperator, SwigDirector_IntVarLocalSearchOperator, SwigDirector_LocalSearchOperator, SwigDirector_ChangeValue, SwigDirector_BaseLns, SwigDirector_IntVarLocalSearchOperator, SwigDirector_LocalSearchOperator, SwigDirector_PathOperator, SwigDirector_ChangeValue, SwigDirector_BaseLns, SwigDirector_SequenceVarLocalSearchOperator, SwigDirector_IntVarLocalSearchOperator, and SwigDirector_LocalSearchOperator.
Definition at line 811 of file constraint_solveri.h.
|
inlineinherited |
Definition at line 895 of file constraint_solveri.h.
|
inlinevirtualinherited |
Definition at line 813 of file constraint_solveri.h.
Definition at line 1083 of file constraint_solveri.h.
Definition at line 1087 of file constraint_solveri.h.
|
inlineinherited |
Definition at line 858 of file constraint_solveri.h.
|
inlineinherited |
Definition at line 847 of file constraint_solveri.h.
|
inlinevirtualinherited |
Reimplemented in PathOperator, SwigDirector_PathOperator, SwigDirector_ChangeValue, SwigDirector_IntVarLocalSearchOperator, SwigDirector_ChangeValue, SwigDirector_IntVarLocalSearchOperator, SwigDirector_PathOperator, SwigDirector_ChangeValue, and SwigDirector_IntVarLocalSearchOperator.
Definition at line 856 of file constraint_solveri.h.
|
inlineoverridevirtualinherited |
This method should not be overridden.
Override OnStart() instead which is called before exiting this method.
Implements LocalSearchOperator.
Definition at line 833 of file constraint_solveri.h.
Returns the value in the current assignment of the variable of given index.
Definition at line 850 of file constraint_solveri.h.
|
inlineinherited |
Returns the variable of given index.
Definition at line 855 of file constraint_solveri.h.
|
protectedinherited |
Definition at line 942 of file constraint_solveri.h.
|
mutableprotectedinherited |
Definition at line 941 of file constraint_solveri.h.
|
protectedinherited |
Definition at line 944 of file constraint_solveri.h.
|
protectedinherited |
Definition at line 946 of file constraint_solveri.h.
|
protectedinherited |
Definition at line 945 of file constraint_solveri.h.
|
protectedinherited |
Definition at line 939 of file constraint_solveri.h.
|
protectedinherited |
Definition at line 940 of file constraint_solveri.h.
|
protectedinherited |
Definition at line 938 of file constraint_solveri.h.
|
protectedinherited |
Definition at line 947 of file constraint_solveri.h.
|
protectedinherited |
Definition at line 937 of file constraint_solveri.h.
|
protectedinherited |
Definition at line 943 of file constraint_solveri.h.