Safe Haskell | Safe-Inferred |
---|---|
Language | GHC2021 |
NumHask.Algebra.Field
Description
Field classes
Synopsis
- type SemiField a = (Distributive a, Divisive a)
- type Field a = (Ring a, Divisive a)
- class Field a => ExpField a where
- class SemiField a => QuotientField a where
- infinity :: SemiField a => a
- negInfinity :: Field a => a
- nan :: SemiField a => a
- class Field a => TrigField a where
- half :: (Additive a, Divisive a) => a
Documentation
type SemiField a = (Distributive a, Divisive a) Source #
A Semifield is a field with no substraction.
Since: 0.12
type Field a = (Ring a, Divisive a) Source #
A Field is a set on which addition, subtraction, multiplication, and division are defined. It is also assumed that multiplication is distributive over addition.
A summary of the rules inherited from super-classes of Field:
zero + a == a a + zero == a ((a + b) + c) (a + (b + c)) a + b == b + a a - a == zero negate a == zero - a negate a + a == zero a + negate a == zero one * a == a a * one == a ((a * b) * c) == (a * (b * c)) (a * (b + c)) == (a * b + a * c) ((a + b) * c) == (a * c + b * c) a * zero == zero zero * a == zero a / a == one || a == zero recip a == one / a || a == zero recip a * a == one || a == zero a * recip a == one || a == zero
class Field a => ExpField a where Source #
A hyperbolic field class
\(a::Double) -> a < zero || (sqrt . (**2)) a == a
\(a::Double) -> a < zero || (log . exp) a ~= a
\(a::Double) (b::Double) -> (b < zero) || a <= zero || a == 1 || abs (a ** logBase a b - b) < 10 * epsilon
Methods
logBase :: a -> a -> a Source #
log to the base of
>>>
logBase 2 8
2.9999999999999996
square root
>>>
sqrt 4
2.0
Instances
ExpField Double Source # | |
ExpField Float Source # | |
(Ord a, TrigField a, ExpField a) => ExpField (EuclideanPair a) Source # | |
Defined in NumHask.Algebra.Metric Methods exp :: EuclideanPair a -> EuclideanPair a Source # log :: EuclideanPair a -> EuclideanPair a Source # (**) :: EuclideanPair a -> EuclideanPair a -> EuclideanPair a Source # logBase :: EuclideanPair a -> EuclideanPair a -> EuclideanPair a Source # sqrt :: EuclideanPair a -> EuclideanPair a Source # | |
(Ord a, TrigField a, ExpField a) => ExpField (Complex a) Source # | |
ExpField a => ExpField (Wrapped a) Source # | |
ExpField b => ExpField (a -> b) Source # | |
class SemiField a => QuotientField a where Source #
Minimal complete definition
Methods
properFraction :: a -> (Whole a, a) Source #
round :: a -> Whole a Source #
round to the nearest Int
Exact ties are managed by rounding down ties if the whole component is even.
>>>
round (1.5 :: Double)
2
>>>
round (2.5 :: Double)
2
default round :: (Subtractive a, Integral (Whole a), Eq (Whole a), Ord a, Subtractive (Whole a)) => a -> Whole a Source #
ceiling :: a -> Whole a Source #
supply the next upper whole component
>>>
ceiling (1.001 :: Double)
2
floor :: a -> Whole a Source #
supply the previous lower whole component
>>>
floor (1.001 :: Double)
1
default floor :: (Ord a, Subtractive (Whole a), Distributive (Whole a)) => a -> Whole a Source #
truncate :: a -> Whole a Source #
supply the whole component closest to zero
>>>
floor (-1.001 :: Double)
-2
>>>
truncate (-1.001 :: Double)
-1
Instances
negInfinity :: Field a => a Source #
negative infinity
>>>
negInfinity + infinity
NaN
nan :: SemiField a => a Source #
nan is defined as zero/zero
but note the (social) law:
>>>
nan == zero / zero
False
class Field a => TrigField a where Source #
Trigonometric Field
The list of laws is quite long: trigonometric identities
Methods