votca
2024.2-dev
Loading...
Searching...
No Matches
tools
include
votca
tools
floatingpointcomparison.h
Go to the documentation of this file.
1
/*
2
* Copyright 2009-2020 The VOTCA Development Team
3
* (http://www.votca.org)
4
*
5
* Licensed under the Apache License, Version 2.0 (the "License")
6
*
7
* You may not use this file except in compliance with the License.
8
* You may obtain a copy of the License at
9
*
10
* http://www.apache.org/licenses/LICENSE-2.0
11
*
12
* Unless required by applicable law or agreed to in writing, software
13
* distributed under the License is distributed on an "AS IS" BASIS,
14
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
* See the License for the specific language governing permissions and
16
* limitations under the License.
17
*
18
*/
19
20
#ifndef VOTCA_TOOLS_FLOATINGPOINTCOMPARISON_H
21
#define VOTCA_TOOLS_FLOATINGPOINTCOMPARISON_H
22
23
// Standard includes
24
#include <algorithm>
25
#include <cmath>
26
38
// Standard includes
39
#include <cstdlib>
40
41
namespace
votca
{
42
namespace
tools {
43
44
template
<
typename
T>
45
static
bool
isApproximatelyEqual
(T a, T b, T tolerance) {
46
T diff = std::abs(a - b);
47
if
(diff <= tolerance) {
48
return
true
;
49
}
50
51
if
(diff < std::max(std::abs(a), std::abs(b)) * tolerance) {
52
return
true
;
53
}
54
return
false
;
55
}
56
57
}
// namespace tools
58
}
// namespace votca
59
#endif
// VOTCA_TOOLS_FLOATINGPOINTCOMPARISON_H
votca::tools::isApproximatelyEqual
static bool isApproximatelyEqual(T a, T b, T tolerance)
Definition
floatingpointcomparison.h:45
votca
base class for all analysis tools
Definition
basebead.h:33
Generated by
1.12.0