aGrUM
0.20.3
a C++ library for (probabilistic) graphical models
continuousVariable_inl.h
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
/** @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
ContinuousVariable
<
float
>::
operator
[](
const
std
::
string
&
str
)
const
{
41
float
value
;
42
std
::
size_t
pos
;
43
try
{
44
value
=
std
::
stof
(
str
, &
pos
);
45
}
catch
(
std
::
invalid_argument
&) {
46
GUM_ERROR
(
TypeError
,
"the value is not a number"
)
47
}
catch
(
std
::
out_of_range
&) {
GUM_ERROR
(
OutOfBounds
,
"the value is too huge"
) }
48
49
// check whether there remains non-space unprocessed characters
50
for
(
auto
iter
=
str
.
begin
() +
pos
,
end
=
str
.
end
();
iter
!=
end
; ++
iter
) {
51
if
(!
std
::
isspace
(
static_cast
<
unsigned
char
>(*
iter
)))
52
GUM_ERROR
(
TypeError
,
"the value is not a number"
)
53
}
54
55
if
(
belongs
(
value
))
56
return
value
;
57
else
58
GUM_ERROR
(
OutOfBounds
,
"the value does not belong to the domain of the variable"
)
59
}
60
61
62
/// returns the GUM_SCALAR corresponding to a string, specialized for doubles
63
template
<>
64
INLINE
double
ContinuousVariable
<
double
>::
operator
[](
const
std
::
string
&
str
)
const
{
65
double
value
;
66
std
::
size_t
pos
;
67
try
{
68
value
=
std
::
stod
(
str
, &
pos
);
69
}
catch
(
std
::
invalid_argument
&) {
70
GUM_ERROR
(
TypeError
,
"the value is not a number"
)
71
}
catch
(
std
::
out_of_range
&) {
GUM_ERROR
(
OutOfBounds
,
"the value is too huge"
) }
72
73
// check whether there remains non-space unprocessed characters
74
for
(
auto
iter
=
str
.
begin
() +
pos
,
end
=
str
.
end
();
iter
!=
end
; ++
iter
) {
75
if
(!
std
::
isspace
(
static_cast
<
unsigned
char
>(*
iter
)))
76
GUM_ERROR
(
TypeError
,
"the value is not a number"
)
77
}
78
79
if
(
belongs
(
value
))
80
return
value
;
81
else
82
GUM_ERROR
(
OutOfBounds
,
"the value does not belong to the domain of the variable"
)
83
}
84
85
}
/* namespace gum */
86
87
#
endif
// DOXYGEN_SHOULD_SKIP_THIS
gum::Set::emplace
INLINE void emplace(Args &&... args)
Definition:
set_tpl.h:643