Library of Assembled Shared Sources
floating_point_comparison.h
Go to the documentation of this file.
1/** @file
2 * @author Bram de Greve (bram@cocamware.com)
3 * @author Tom De Muer (tom@cocamware.com)
4 *
5 * *** BEGIN LICENSE INFORMATION ***
6 *
7 * The contents of this file are subject to the Common Public Attribution License
8 * Version 1.0 (the "License"); you may not use this file except in compliance with
9 * the License. You may obtain a copy of the License at
10 * http://lass.sourceforge.net/cpal-license. The License is based on the
11 * Mozilla Public License Version 1.1 but Sections 14 and 15 have been added to cover
12 * use of software over a computer network and provide for limited attribution for
13 * the Original Developer. In addition, Exhibit A has been modified to be consistent
14 * with Exhibit B.
15 *
16 * Software distributed under the License is distributed on an "AS IS" basis, WITHOUT
17 * WARRANTY OF ANY KIND, either express or implied. See the License for the specific
18 * language governing rights and limitations under the License.
19 *
20 * The Original Code is LASS - Library of Assembled Shared Sources.
21 *
22 * The Initial Developer of the Original Code is Bram de Greve and Tom De Muer.
23 * The Original Developer is the Initial Developer.
24 *
25 * All portions of the code written by the Initial Developer are:
26 * Copyright (C) 2004-2011 the Initial Developer.
27 * All Rights Reserved.
28 *
29 * Contributor(s):
30 *
31 * Alternatively, the contents of this file may be used under the terms of the
32 * GNU General Public License Version 2 or later (the GPL), in which case the
33 * provisions of GPL are applicable instead of those above. If you wish to allow use
34 * of your version of this file only under the terms of the GPL and not to allow
35 * others to use your version of this file under the CPAL, indicate your decision by
36 * deleting the provisions above and replace them with the notice and other
37 * provisions required by the GPL License. If you do not delete the provisions above,
38 * a recipient may use your version of this file under either the CPAL or the GPL.
39 *
40 * *** END LICENSE INFORMATION ***
41 */
42
43
44
45#ifndef LASS_GUARDIAN_OF_INCLUSION_NUM_TOLERANCE_COMPARISON_H
46#define LASS_GUARDIAN_OF_INCLUSION_NUM_TOLERANCE_COMPARISON_H
47
48#include "num_common.h"
49#include "basic_ops.h"
50
51namespace lass
52{
53namespace num
54{
55
56template <typename T>
57bool almostEqual(T iA, T iB, T iRelativeTolerance)
58{
59 return iA == iB || num::abs(iA - iB) < iRelativeTolerance * std::max(num::abs(iA), num::abs(iB));
60}
61
62template <typename T>
63bool notAlmostEqual(T iA, T iB, T iRelativeTolerance)
64{
65 return !almostEqual(iA, iB, iRelativeTolerance);
66}
67
68template <typename T>
69bool almostLess(T iA, T iB, T iRelativeTolerance)
70{
71 return iA < iB && !almostEqual(iA, iB, iRelativeTolerance);
72}
73
74template <typename T>
75bool almostGreater(T iA, T iB, T iRelativeTolerance)
76{
77 return iA > iB && !almostEqual(iA, iB, iRelativeTolerance);
78}
79
80template <typename T>
81bool almostLessOrEqual(T iA, T iB, T iRelativeTolerance)
82{
83 return iA <= iB || almostEqual(iA, iB, iRelativeTolerance);
84}
85
86template <typename T>
87bool almostGreaterOrEqual(T iA, T iB, T iRelativeTolerance)
88{
89 return iA >= iB || almostEqual(iA, iB, iRelativeTolerance);
90}
91
92template <typename T>
93bool almostInOpenRange(T iA, T iMin, T iMax, T iRelativeTolerance)
94{
95 return almostGreater(iA, iMin, iRelativeTolerance) &&
96 almostLess(iA, iMax, iRelativeTolerance);
97}
98
99template <typename T>
100bool almostInClosedRange(T iA, T iMin, T iMax, T iRelativeTolerance)
101{
102 return almostGreaterOrEqual(iA, iMin, iRelativeTolerance) &&
103 almostLessOrEqual(iA, iMax, iRelativeTolerance);
104}
105
106}
107
108}
109
110#endif
T abs(const T &x)
if x < 0 return -x, else return x.
Definition basic_ops.h:145
numeric types and traits.
Definition basic_ops.h:70
Library for Assembled Shared Sources.
Definition config.h:53