aGrUM
0.20.2
a C++ library for (probabilistic) graphical models
continuousVariable_inl.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
/** @file
23
* @brief The databases' cell translators for continuous variables
24
*
25
* @author Christophe GONZALES(@AMU) and Pierre-Henri WUILLEMIN(@LIP6)
26
*/
27
28
#
ifndef
DOXYGEN_SHOULD_SKIP_THIS
29
30
#
include
<
cctype
>
31
#
include
<
cstdlib
>
32
33
#
include
<
agrum
/
tools
/
variables
/
continuousVariable
.
h
>
34
35
namespace
gum
{
36
37
38
/// returns the GUM_SCALAR corresponding to a string, specialized for floats
39
template
<>
40
INLINE
float
41
ContinuousVariable
<
float
>::
operator
[](
const
std
::
string
&
str
)
const
{
42
float
value
;
43
std
::
size_t
pos
;
44
try
{
45
value
=
std
::
stof
(
str
, &
pos
);
46
}
catch
(
std
::
invalid_argument
&) {
47
GUM_ERROR
(
TypeError
,
"the value is not a number"
);
48
}
catch
(
std
::
out_of_range
&) {
49
GUM_ERROR
(
OutOfBounds
,
"the value is too huge"
);
50
}
51
52
// check whether there remains non-space unprocessed characters
53
for
(
auto
iter
=
str
.
begin
() +
pos
,
end
=
str
.
end
();
iter
!=
end
; ++
iter
) {
54
if
(!
std
::
isspace
(
static_cast
<
unsigned
char
>(*
iter
)))
55
GUM_ERROR
(
TypeError
,
"the value is not a number"
);
56
}
57
58
if
(
belongs
(
value
))
59
return
value
;
60
else
61
GUM_ERROR
(
OutOfBounds
,
62
"the value does not belong to the domain of the variable"
);
63
}
64
65
66
/// returns the GUM_SCALAR corresponding to a string, specialized for doubles
67
template
<>
68
INLINE
double
69
ContinuousVariable
<
double
>::
operator
[](
const
std
::
string
&
str
)
const
{
70
double
value
;
71
std
::
size_t
pos
;
72
try
{
73
value
=
std
::
stod
(
str
, &
pos
);
74
}
catch
(
std
::
invalid_argument
&) {
75
GUM_ERROR
(
TypeError
,
"the value is not a number"
);
76
}
catch
(
std
::
out_of_range
&) {
77
GUM_ERROR
(
OutOfBounds
,
"the value is too huge"
);
78
}
79
80
// check whether there remains non-space unprocessed characters
81
for
(
auto
iter
=
str
.
begin
() +
pos
,
end
=
str
.
end
();
iter
!=
end
; ++
iter
) {
82
if
(!
std
::
isspace
(
static_cast
<
unsigned
char
>(*
iter
)))
83
GUM_ERROR
(
TypeError
,
"the value is not a number"
);
84
}
85
86
if
(
belongs
(
value
))
87
return
value
;
88
else
89
GUM_ERROR
(
OutOfBounds
,
90
"the value does not belong to the domain of the variable"
);
91
}
92
93
}
/* namespace gum */
94
95
#
endif
// DOXYGEN_SHOULD_SKIP_THIS
gum::Set::emplace
INLINE void emplace(Args &&... args)
Definition:
set_tpl.h:669