aGrUM
2.3.2
a C++ library for (probabilistic) graphical models
unconstrainedEliminationSequenceStrategy.cpp
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
41
50
51
#include <
agrum/base/graphs/algorithms/triangulations/eliminationStrategies/unconstrainedEliminationSequenceStrategy.h
>
52
53
namespace
gum
{
54
56
UnconstrainedEliminationSequenceStrategy::UnconstrainedEliminationSequenceStrategy
() {
57
GUM_CONSTRUCTOR(
UnconstrainedEliminationSequenceStrategy
);
58
}
59
61
UnconstrainedEliminationSequenceStrategy::UnconstrainedEliminationSequenceStrategy
(
62
UndiGraph
*
graph
,
63
const
NodeProperty< Size >
* dom_sizes) :
EliminationSequenceStrategy
(
graph
, dom_sizes) {
64
GUM_CONSTRUCTOR(
UnconstrainedEliminationSequenceStrategy
);
65
}
66
68
UnconstrainedEliminationSequenceStrategy::UnconstrainedEliminationSequenceStrategy
(
69
const
UnconstrainedEliminationSequenceStrategy
& from) :
EliminationSequenceStrategy
(from) {
70
GUM_CONS_CPY(
UnconstrainedEliminationSequenceStrategy
);
71
}
72
74
UnconstrainedEliminationSequenceStrategy::UnconstrainedEliminationSequenceStrategy
(
75
UnconstrainedEliminationSequenceStrategy
&& from) :
76
EliminationSequenceStrategy
(
std
::move(from)) {
77
GUM_CONS_MOV(
UnconstrainedEliminationSequenceStrategy
)
78
}
79
81
UnconstrainedEliminationSequenceStrategy::~UnconstrainedEliminationSequenceStrategy
() {
82
GUM_DESTRUCTOR(
UnconstrainedEliminationSequenceStrategy
);
83
}
84
85
}
/* namespace gum */
gum::EliminationSequenceStrategy::EliminationSequenceStrategy
EliminationSequenceStrategy()
default constructor
Definition
eliminationSequenceStrategy.cpp:78
gum::EliminationSequenceStrategy::graph
UndiGraph * graph() const noexcept
returns the current graph
Definition
eliminationSequenceStrategy_inl.h:56
gum::UnconstrainedEliminationSequenceStrategy::~UnconstrainedEliminationSequenceStrategy
virtual ~UnconstrainedEliminationSequenceStrategy()
destructor
Definition
unconstrainedEliminationSequenceStrategy.cpp:81
gum::UnconstrainedEliminationSequenceStrategy::UnconstrainedEliminationSequenceStrategy
UnconstrainedEliminationSequenceStrategy()
default constructor
Definition
unconstrainedEliminationSequenceStrategy.cpp:56
gum::UndiGraph
Base class for undirected graphs.
Definition
undiGraph.h:128
gum::NodeProperty
HashTable< NodeId, VAL > NodeProperty
Property on graph elements.
Definition
graphElements.h:395
gum
gum is the global namespace for all aGrUM entities
Definition
agrum.h:46
std
STL namespace.
unconstrainedEliminationSequenceStrategy.h
Base Class for all elimination sequence algorithms that require only the graph to be triangulated and...