aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
structuralConstraintTabuList_inl.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#pragma once
41
42
49#ifndef DOXYGEN_SHOULD_SKIP_THIS
50
51namespace gum {
52
53 namespace learning {
54
56 INLINE
58 if (new_size == _TabuList_changes_.size()) return;
59
60 if (_TabuList_changes_.size() > new_size) {
61 // remove the oldest elements, so that only newsize elements remain
62 while (_TabuList_changes_.size() > new_size) {
65 }
66 } else {
67 // add dummy elements
68 while (_TabuList_changes_.size() < new_size) {
70 _TabuList_changes_.insert(
71 ArcAddition(std::numeric_limits< NodeId >::max() - _TabuList_offset_,
72 std::numeric_limits< NodeId >::max()),
74 }
75 }
76 }
77
79 INLINE void StructuralConstraintTabuList::setGraphAlone(const DiGraph& graph) {}
80
83 return !_TabuList_changes_.existsFirst(ArcDeletion(x, y))
84 && !_TabuList_changes_.existsFirst(ArcAddition(x, y));
85 }
86
89 return !_TabuList_changes_.existsFirst(ArcAddition(x, y))
90 && !_TabuList_changes_.existsFirst(ArcDeletion(x, y));
91 }
92
95 return !_TabuList_changes_.existsFirst(ArcReversal(y, x))
96 && !_TabuList_changes_.existsFirst(ArcReversal(x, y));
97 }
98
100 INLINE bool
102 return checkArcAdditionAlone(change.node1(), change.node2());
103 }
104
106 INLINE bool
108 return checkArcDeletionAlone(change.node1(), change.node2());
109 }
110
112 INLINE bool
114 return checkArcReversalAlone(change.node1(), change.node2());
115 }
116
118 INLINE bool
120 switch (change.type()) {
122 return checkArcAdditionAlone(change.node1(), change.node2());
123
125 return checkArcDeletionAlone(change.node1(), change.node2());
126
128 return checkArcReversalAlone(change.node1(), change.node2());
129
130 default :
131 GUM_ERROR(OperationNotAllowed,
132 "edge modifications are not "
133 "supported by StructuralConstraintTabuList");
134 }
135 }
136
142 }
143
149 }
150
156 }
157
160 switch (change.type()) {
162 modifyGraphAlone(static_cast< const ArcAddition& >(change));
163 break;
164
166 modifyGraphAlone(static_cast< const ArcDeletion& >(change));
167 break;
168
170 modifyGraphAlone(static_cast< const ArcReversal& >(change));
171 break;
172
173 default :
174 GUM_ERROR(OperationNotAllowed,
175 "edge modifications are not supported by digraph constraint")
176 }
177 }
178
181 return false;
182 }
183
184// include all the methods applicable to the whole class hierarchy
185# define GUM_CONSTRAINT_CLASS_NAME StructuralConstraintTabuList
187# undef GUM_CONSTRAINT_CLASS_NAME
188
189 } /* namespace learning */
190
191} /* namespace gum */
192
193#endif /* DOXYGEN_SHOULD_SKIP_THIS */
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.
void modifyGraphAlone(const ArcAddition &change)
notify the constraint of a modification of the graph
void setTabuListSize(Size new_size)
sets the size of the tabu list
bool checkArcDeletionAlone(NodeId x, NodeId y) const
checks whether the constraints enable to remove arc (x,y)
bool checkModificationAlone(const GraphChange &change) const
checks whether the constraints enable to perform a graph change
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
NodeId _TabuList_offset_
the index of the oldest element
void setGraphAlone(const DiGraph &graph)
sets a new graph from which we will perform checkings
bool checkArcReversalAlone(NodeId x, NodeId y) const
checks whether the constraints enable to reverse arc (x,y)
Bijection< GraphChange, NodeId > _TabuList_changes_
the tabu list
#define GUM_ERROR(type, msg)
Definition exceptions.h:72
std::size_t Size
In aGrUM, hashed values are unsigned long int.
Definition types.h:74
Size NodeId
Type for node ids.
include the inlined functions if necessary
Definition CSVParser.h:54
gum is the global namespace for all aGrUM entities
Definition agrum.h:46