Go to the documentation of this file.
3 #ifndef DUNE_COMMON_FLOAT_CMP_HH
4 #define DUNE_COMMON_FLOAT_CMP_HH
127 template<
class T>
struct EpsilonType;
135 template<
class T, CmpStyle style = defaultCmpStyle>
155 bool eq(
const T &first,
168 bool ne(
const T &first,
184 bool gt(
const T &first,
200 bool lt(
const T &first,
216 bool ge(
const T &first,
232 bool le(
const T &first,
385 #endif //DUNE_COMMON_FLOAT_CMP_HH
@ relativeWeak
|a-b|/|a| <= epsilon || |a-b|/|b| <= epsilon
Definition: float_cmp.hh:104
static EpsilonType< T >::Type value()
Returns the default epsilon for the given value type and compare style.
I trunc(const T &val, typename EpsilonType< T >::Type epsilon)
truncate using epsilon
Definition: float_cmp.cc:405
bool eq(const T &first, const T &second, typename EpsilonType< T >::Type epsilon)
test for equality using epsilon
Definition: float_cmp.cc:142
T ValueType
Type of the values to compare.
Definition: float_cmp.hh:297
bool lt(const T &first, const T &second, typename EpsilonType< T >::Type epsilon)
test if first lesser than second
Definition: float_cmp.cc:163
Class encapsulating a default epsilon.
Definition: float_cmp.hh:286
@ towardZero
always round toward 0
Definition: float_cmp.hh:116
RoundingStyle
Definition: float_cmp.hh:114
bool ne(const T &first, const T &second, typename EpsilonType< T >::Type epsilon)
test for inequality using epsilon
Definition: float_cmp.cc:149
CmpStyle
Definition: float_cmp.hh:102
@ towardInf
always round away from 0
Definition: float_cmp.hh:118
bool ge(const ValueType &first, const ValueType &second) const
test if first greater or equal second
Definition: float_cmp.cc:477
FloatCmp::EpsilonType< T >::Type EpsilonType
Type of the epsilon.
Definition: float_cmp.hh:302
bool eq(const ValueType &first, const ValueType &second) const
test for equality using epsilon
Definition: float_cmp.cc:449
I trunc(const ValueType &val) const
truncate using epsilon
Definition: float_cmp.cc:501
@ upward
round toward
Definition: float_cmp.hh:122
static const CmpStyle cstyle
How comparisons are done.
Definition: float_cmp.hh:293
@ downward
round toward
Definition: float_cmp.hh:120
bool le(const ValueType &first, const ValueType &second) const
test if first lesser or equal second
Definition: float_cmp.cc:484
EpsilonType epsilon() const
return the current epsilon
Definition: float_cmp.cc:434
@ relativeStrong
|a-b|/|a| <= epsilon && |a-b|/|b| <= epsilon
Definition: float_cmp.hh:106
mapping from a value type and a compare style to a default epsilon
Definition: float_cmp.hh:136
I round(const T &val, typename EpsilonType< T >::Type epsilon)
round using epsilon
Definition: float_cmp.cc:309
bool lt(const ValueType &first, const ValueType &second) const
test if first lesser than second
Definition: float_cmp.cc:470
bool le(const T &first, const T &second, typename EpsilonType< T >::Type epsilon)
test if first lesser or equal second
Definition: float_cmp.cc:177
@ defaultCmpStyle
the global default compare style (relative_weak)
Definition: float_cmp.hh:110
I round(const ValueType &val) const
round using epsilon
Definition: float_cmp.cc:493
bool gt(const T &first, const T &second, typename EpsilonType< T >::Type epsilon)
test if first greater than second
Definition: float_cmp.cc:156
bool gt(const ValueType &first, const ValueType &second) const
test if first greater than second
Definition: float_cmp.cc:463
bool ge(const T &first, const T &second, typename EpsilonType< T >::Type epsilon)
test if first greater or equal second
Definition: float_cmp.cc:170
bool ne(const ValueType &first, const ValueType &second) const
test for inequality using epsilon
Definition: float_cmp.cc:456
@ absolute
|a-b| <= epsilon
Definition: float_cmp.hh:108
@ defaultRoundingStyle
the global default rounding style (toward_zero)
Definition: float_cmp.hh:124
static const RoundingStyle rstyle
How rounding is done.
Definition: float_cmp.hh:295
T Type
The epsilon type corresponding to value type T.
Definition: float_cmp.cc:23
Dune namespace.
Definition: alignedallocator.hh:13
FloatCmpOps(EpsilonType epsilon=DefaultEpsilon::value())
construct an operations object
Definition: float_cmp.cc:429