]> gitweb.michael.orlitzky.com - spline3.git/blobdiff - src/Comparisons.hs
Add the theta tolerance and nearly_equals, nearly_ge comparisons.
[spline3.git] / src / Comparisons.hs
index f4462a083222b4000a42faeb58dadbbdb171b719..4a8144469415668327567717239844a4b1c85a22 100644 (file)
@@ -1,10 +1,54 @@
+-- | Functions for comparing 'Double' values.
 module Comparisons
 where
 
+-- | epsilon is the value that will be used in all tests that require
+--   some measure of \"closeness.\" Increasing it will make those
+--   tests more tolerant.
+epsilon :: Double
+epsilon = 0.0001
 
+-- | A tiny margin of error.
+theta :: Double
+theta = 0.00000000000001
+
+-- | x almost equals y if x is within 'theta' of y.
+nearly_equals :: Double -> Double -> Bool
+nearly_equals x y = (abs (x - y)) < theta
+
+-- | Nearly greater-than or equal-to.
+nearly_ge :: Double -> Double -> Bool
+x `nearly_ge` y = (x > y) || (x `nearly_equals` y)
+
+-- | x almost equals y if x is within 'epsilon' of y.
 almost_equals :: Double -> Double -> Bool
-almost_equals x y = (abs (x - y)) < 0.0001
+almost_equals x y = (abs (x - y)) < epsilon
 
 infix 4 ~=
 (~=) :: Double -> Double -> Bool
 (~=) = almost_equals
+
+
+-- | Like 'almost_equals', except much more tolerant. The difference
+--   between the two arguments must be less than one percent of the sum
+--   of their magnitudes.
+kinda_equals :: Double -> Double -> Bool
+kinda_equals x y =
+    (abs (x - y)) < threshold
+    where
+      threshold = ((abs x) + (abs y)) / 100.0
+
+infix 4 ~~=
+(~~=) :: Double -> Double -> Bool
+(~~=) = kinda_equals
+
+
+-- | x is very positive if it is 'epsilon' greater than zero.
+very_positive :: Double -> Bool
+very_positive x =  x - epsilon > 0
+
+
+-- | Takes a list of 'Double' and returns the ones which are not very
+--   positive.
+non_very_positive_entries :: [Double] -> [Double]
+non_very_positive_entries = filter (not . very_positive)