17 #ifndef _GAZEBO_MATH_FUNCTIONS_HH_
18 #define _GAZEBO_MATH_FUNCTIONS_HH_
20 #include <boost/math/special_functions/fpclassify.hpp>
21 #include <boost/math/special_functions/round.hpp>
30 #define GZ_DBL_MAX std::numeric_limits<double>::max()
33 #define GZ_DBL_MIN std::numeric_limits<double>::min()
36 #define GZ_FLT_MAX std::numeric_limits<float>::max()
39 #define GZ_FLT_MIN std::numeric_limits<float>::min()
42 #define GZ_UINT32_MAX std::numeric_limits<uint32_t>::max()
45 #define GZ_UINT32_MIN std::numeric_limits<uint32_t>::min()
58 static const double NAN_D = std::numeric_limits<double>::quiet_NaN();
61 static const int NAN_I = std::numeric_limits<int>::quiet_NaN();
68 inline T
clamp(T _v, T _min, T _max)
94 return isnan(_v) || std::isinf(_v) ? 0.0f : _v;
102 return isnan(_v) || std::isinf(_v) ? 0.0 : _v;
109 inline T
mean(
const std::vector<T> &_values)
112 for (
unsigned int i = 0; i < _values.size(); ++i)
114 return sum / _values.size();
123 T avg = mean<T>(_values);
126 for (
unsigned int i = 0; i < _values.size(); ++i)
127 sum += (_values[i] - avg) * (_values[i] - avg);
128 return sum / _values.size();
135 inline T
max(
const std::vector<T> &_values)
138 for (
unsigned int i = 0; i < _values.size(); ++i)
139 if (_values[i] > max)
148 inline T
min(
const std::vector<T> &_values)
151 for (
unsigned int i = 0; i < _values.size(); ++i)
152 if (_values[i] < min)
162 inline bool equal(
const T &_a,
const T &_b,
163 const T &_epsilon = 1e-6)
165 return std::fabs(_a - _b) <= _epsilon;
173 inline T
precision(
const T &_a,
const unsigned int &_precision)
175 return boost::math::round(_a * pow(10, _precision)) / pow(10, _precision);
183 return ((_x != 0) && ((_x & (~_x + 1)) == _x));
191 const char *p = _input.c_str();
192 if (!*p || *p ==
'?')
206 while (*p >=
'0' && *p <=
'9')
207 acc = acc * 10 + *p++ -
'0';
211 std::cerr <<
"Invalid int numeric format[" << _input <<
"]\n";
224 const char *p = _input.c_str();
225 if (!*p || *p ==
'?')
238 while (*p >=
'0' && *p <=
'9')
239 acc = acc * 10 + *p++ -
'0';
245 while (*p >=
'0' && *p <=
'9')
247 acc += (*p++ -
'0') * k;
266 while (*p >=
'0' && *p <=
'9')
267 f = f * 10 + *p++ -
'0';
269 acc *= pow(10, f*es);
274 std::cerr <<
"Invalid double numeric format[" << _input <<
"]\n";