aGrUM
0.20.3
a C++ library for (probabilistic) graphical models
UGmodel.cpp
Go to the documentation of this file.
1
/**
2
*
3
* Copyright (c) 2005-2021 by Pierre-Henri WUILLEMIN(@LIP6) & Christophe GONZALES(@AMU)
4
* info_at_agrum_dot_org
5
*
6
* This library is free software: you can redistribute it and/or modify
7
* it under the terms of the GNU Lesser General Public License as published by
8
* the Free Software Foundation, either version 3 of the License, or
9
* (at your option) any later version.
10
*
11
* This library is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
* GNU Lesser General Public License for more details.
15
*
16
* You should have received a copy of the GNU Lesser General Public License
17
* along with this library. If not, see <http://www.gnu.org/licenses/>.
18
*
19
*/
20
21
22
#
include
<
agrum
/
tools
/
graphicalModels
/
UGmodel
.
h
>
23
24
#
ifdef
GUM_NO_INLINE
25
#
include
<
agrum
/
tools
/
graphicalModels
/
UGmodel_inl
.
h
>
26
#
endif
/* GUM_NO_INLINE */
27
28
namespace
gum
{
29
UGmodel
::
UGmodel
() {
30
GUM_CONSTRUCTOR
(
UGmodel
);
31
;
32
}
33
34
UGmodel
::
UGmodel
(
const
UGmodel
&
from
) :
graph_
(
from
.
graph_
) {
GUM_CONS_CPY
(
UGmodel
); }
35
36
UGmodel
::~
UGmodel
() {
37
GUM_DESTRUCTOR
(
UGmodel
);
38
;
39
}
40
41
UGmodel
&
UGmodel
::
operator
=(
const
UGmodel
&
source
) {
42
if
(
this
!= &
source
) {
43
GraphicalModel
::
operator
=(
source
);
44
graph_
=
source
.
graph_
;
45
}
46
47
return
*
this
;
48
}
49
50
bool
UGmodel
::
hasSameStructure
(
const
UGmodel
&
other
) {
51
if
(
this
== &
other
)
return
true
;
52
53
if
(
size
() !=
other
.
size
())
return
false
;
54
55
if
(
sizeEdges
() !=
other
.
sizeEdges
())
return
false
;
56
57
for
(
const
auto
&
nid
:
nodes
()) {
58
try
{
59
other
.
idFromName
(
variable
(
nid
).
name
());
60
}
catch
(
NotFound
) {
return
false
; }
61
}
62
63
for
(
const
auto
&
edge
:
edges
()) {
64
if
(!
other
.
edges
().
exists
(
Edge
(
other
.
idFromName
(
variable
(
edge
.
first
()).
name
()),
65
other
.
idFromName
(
variable
(
edge
.
second
()).
name
()))))
66
return
false
;
67
}
68
69
return
true
;
70
}
71
}
// namespace gum
gum::Set::emplace
INLINE void emplace(Args &&... args)
Definition:
set_tpl.h:643