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
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
90  "the value does not belong to the domain of the variable");
91  }
92 
93 } /* namespace gum */
94 
95 #endif // DOXYGEN_SHOULD_SKIP_THIS
INLINE void emplace(Args &&... args)
Definition: set_tpl.h:669