aGrUM
0.20.2
a C++ library for (probabilistic) graphical models
PRMClassElement_tpl.h
Go to the documentation of this file.
1
/**
2
*
3
* Copyright 2005-2020 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
/**
23
* @file
24
* @brief Inline implementation of gum::PRMClassElement
25
*
26
* @author Lionel TORTI and Pierre-Henri WUILLEMIN(@LIP6)
27
*/
28
#
include
<
agrum
/
PRM
/
elements
/
PRMClassElement
.
h
>
29
#
include
<
agrum
/
PRM
/
elements
/
PRMType
.
h
>
30
31
namespace
gum
{
32
namespace
prm
{
33
34
template
<
typename
GUM_SCALAR >
35
PRMClassElement< GUM_SCALAR >::PRMClassElement(
const
std::string& name) :
36
PRMObject(name) {
37
GUM_CONSTRUCTOR(PRMClassElement);
38
}
39
40
template
<
typename
GUM_SCALAR
>
41
PRMClassElement
<
GUM_SCALAR
>::
PRMClassElement
(
42
const
PRMClassElement
<
GUM_SCALAR
>&
source
) :
43
PRMObject
(
source
.
name
()),
44
id__
(
source
.
id
()) {
45
GUM_CONS_CPY
(
PRMClassElement
);
46
}
47
48
template
<
typename
GUM_SCALAR
>
49
PRMClassElement
<
GUM_SCALAR
>::~
PRMClassElement
() {
50
GUM_DESTRUCTOR
(
PRMClassElement
);
51
}
52
53
template
<
typename
GUM_SCALAR
>
54
INLINE
NodeId
PRMClassElement
<
GUM_SCALAR
>::
id
()
const
{
55
return
id__
;
56
}
57
58
template
<
typename
GUM_SCALAR
>
59
INLINE
PRMObject
::
prm_type
PRMClassElement
<
GUM_SCALAR
>::
obj_type
()
const
{
60
return
prm_type
::
CLASS_ELT
;
61
}
62
63
template
<
typename
GUM_SCALAR
>
64
INLINE
void
PRMClassElement
<
GUM_SCALAR
>::
setId
(
NodeId
id
) {
65
id__
=
id
;
66
}
67
68
template
<
typename
GUM_SCALAR
>
69
INLINE
const
std
::
string
&
PRMClassElement
<
GUM_SCALAR
>::
safeName
()
const
{
70
return
safeName_
;
71
}
72
73
template
<
typename
GUM_SCALAR
>
74
INLINE
std
::
string
75
PRMClassElement
<
GUM_SCALAR
>::
cast
(
const
PRMType
&
t
)
const
{
76
if
(
type
().
isSubTypeOf
(
t
)) {
77
return
PRMObject
::
LEFT_CAST
() +
t
.
name
() +
PRMObject
::
RIGHT_CAST
()
78
+
name
();
79
}
else
{
80
GUM_ERROR
(
OperationNotAllowed
,
"illegal cast"
);
81
}
82
}
83
84
}
/* namespace prm */
85
}
/* namespace gum */
gum::Set::emplace
INLINE void emplace(Args &&... args)
Definition:
set_tpl.h:669
gum::prm::ParamScopeData::ParamScopeData
ParamScopeData(const std::string &s, const PRMReferenceSlot< GUM_SCALAR > &ref, Idx d)
Definition:
PRMClass_tpl.h:1101