aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
localSearchWithTabuList_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
48#ifndef DOXYGEN_SHOULD_SKIP_THIS
49
50namespace gum {
51
52 namespace learning {
53
60 GUM_CONSTRUCTOR(LocalSearchWithTabuList);
61 }
62
65 ApproximationScheme(from), _MaxNbDecreasing_(from._MaxNbDecreasing_) {
66 GUM_CONS_CPY(LocalSearchWithTabuList);
67 }
68
70 INLINE LocalSearchWithTabuList::LocalSearchWithTabuList(LocalSearchWithTabuList&& from) :
71 ApproximationScheme(std::move(from)), _MaxNbDecreasing_(std::move(from._MaxNbDecreasing_)) {
72 GUM_CONS_MOV(LocalSearchWithTabuList);
73 }
74
76 INLINE LocalSearchWithTabuList::~LocalSearchWithTabuList() {
77 GUM_DESTRUCTOR(LocalSearchWithTabuList);
78 }
79
81 INLINE LocalSearchWithTabuList&
82 LocalSearchWithTabuList::operator=(const LocalSearchWithTabuList& from) {
83 ApproximationScheme::operator=(from);
84 _MaxNbDecreasing_ = from._MaxNbDecreasing_;
85 return *this;
86 }
87
89 INLINE LocalSearchWithTabuList&
90 LocalSearchWithTabuList::operator=(LocalSearchWithTabuList&& from) {
91 ApproximationScheme::operator=(std::move(from));
92 _MaxNbDecreasing_ = std::move(from._MaxNbDecreasing_);
93 return *this;
94 }
95
98 INLINE void LocalSearchWithTabuList::setMaxNbDecreasingChanges(Size nb) {
99 _MaxNbDecreasing_ = nb;
100 }
101
103 INLINE ApproximationScheme& LocalSearchWithTabuList::approximationScheme() { return *this; }
104
105 } /* namespace learning */
106
107} /* namespace gum */
108
109#endif /* DOXYGEN_SHOULD_SKIP_THIS */
void disableMaxTime() override
Disable stopping criterion on timeout.
void disableEpsilon() override
Disable stopping criterion on epsilon.
void disableMinEpsilonRate() override
Disable stopping criterion on epsilon rate.
void disableMaxIter() override
Disable stopping criterion on max iterations.
The local search with tabu list learning algorithm (for directed graphs).
LocalSearchWithTabuList()
default constructor
include the inlined functions if necessary
Definition CSVParser.h:54
gum is the global namespace for all aGrUM entities
Definition agrum.h:46
STL namespace.