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
INLINE void emplace(Args &&... args)
Definition: set_tpl.h:643