-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCompareWithEpsilon.cpp
More file actions
38 lines (32 loc) · 945 Bytes
/
CompareWithEpsilon.cpp
File metadata and controls
38 lines (32 loc) · 945 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/*
* \file CompareWithEpsilon.cpp
* \brief
*/
#include <StdStream/StdStream.h>
#include <StdTest/StdTest.h>
#include <Stl.h>
//-------------------------------------------------------------------------------------------------
template<
typename T,
typename = typename std::enable_if<std::is_floating_point<T>::value, T>::type>
inline bool
isFloatEqual(
const T a,
const T b,
const T epsilon = std::numeric_limits<T>::epsilon()
) noexcept
{
return std::abs(a - b) <= epsilon;
}
//-------------------------------------------------------------------------------------------------
int main(int, char **)
{
STD_TEST(isFloatEqual(0.1, 0.1));
STD_TEST(isFloatEqual(0.3, 0.3));
STD_TEST(isFloatEqual(0.4, 0.1 + 0.3));
STD_TEST(isFloatEqual(0.5, 0.2 + 0.3));
return EXIT_SUCCESS;
}
//-------------------------------------------------------------------------------------------------
#if OUTPUT
#endif