natural-arithmetic-0.2.1.0: Arithmetic of natural numbers
Safe HaskellSafe-Inferred
LanguageHaskell2010

Arithmetic.Lte

Synopsis

Special Inequalities

zero :: 0 <= a Source #

Zero is less-than-or-equal-to any number.

reflexive :: a <= a Source #

Any number is less-than-or-equal-to itself.

reflexive# :: (# #) -> a <=# a Source #

Substitution

substituteL :: (b :=: c) -> (b <= a) -> c <= a Source #

Replace the left-hand side of a strict inequality with an equal number.

substituteR :: (b :=: c) -> (a <= b) -> a <= c Source #

Replace the right-hand side of a strict inequality with an equal number.

Increment

incrementL :: forall (c :: Nat) (a :: Nat) (b :: Nat). (a <= b) -> (c + a) <= (c + b) Source #

Add a constant to the left-hand side of both sides of the inequality.

incrementL# :: forall (c :: Nat) (a :: Nat) (b :: Nat). (a <=# b) -> (c + a) <=# (c + b) Source #

incrementR :: forall (c :: Nat) (a :: Nat) (b :: Nat). (a <= b) -> (a + c) <= (b + c) Source #

Add a constant to the right-hand side of both sides of the inequality.

incrementR# :: forall (c :: Nat) (a :: Nat) (b :: Nat). (a <=# b) -> (a + c) <=# (b + c) Source #

Decrement

decrementL :: forall (c :: Nat) (a :: Nat) (b :: Nat). ((c + a) <= (c + b)) -> a <= b Source #

Subtract a constant from the left-hand side of both sides of the inequality. This is the opposite of incrementL.

decrementL# :: forall (c :: Nat) (a :: Nat) (b :: Nat). ((c + a) <=# (c + b)) -> a <=# b Source #

decrementR :: forall (c :: Nat) (a :: Nat) (b :: Nat). ((a + c) <= (b + c)) -> a <= b Source #

Subtract a constant from the right-hand side of both sides of the inequality. This is the opposite of incrementR.

decrementR# :: forall (c :: Nat) (a :: Nat) (b :: Nat). ((a + c) <=# (b + c)) -> a <=# b Source #

Weaken

weakenL :: forall (c :: Nat) (a :: Nat) (b :: Nat). (a <= b) -> a <= (c + b) Source #

Add a constant to the left-hand side of the right-hand side of the inequality.

weakenL# :: forall (c :: Nat) (a :: Nat) (b :: Nat). (a <=# b) -> a <=# (c + b) Source #

weakenR :: forall (c :: Nat) (a :: Nat) (b :: Nat). (a <= b) -> a <= (b + c) Source #

Add a constant to the right-hand side of the right-hand side of the inequality.

weakenR# :: forall (c :: Nat) (a :: Nat) (b :: Nat). (a <=# b) -> a <=# (b + c) Source #

Composition

transitive :: (a <= b) -> (b <= c) -> a <= c Source #

Compose two inequalities using transitivity.

transitive# :: (a <=# b) -> (b <=# c) -> a <=# c Source #

plus :: (a <= b) -> (c <= d) -> (a + c) <= (b + d) Source #

Add two inequalities.

plus# :: (a <=# b) -> (c <=# d) -> (a + c) <=# (b + d) Source #

Convert Strict Inequality

fromStrict :: (a < b) -> a <= b Source #

Weaken a strict inequality to a non-strict inequality.

fromStrict# :: (a <# b) -> a <=# b Source #

fromStrictSucc :: (a < b) -> (a + 1) <= b Source #

Weaken a strict inequality to a non-strict inequality, incrementing the right-hand argument by one.

fromStrictSucc# :: (a <# b) -> (a + 1) <=# b Source #

Integration with GHC solver

constant :: forall a b. IsLte (CmpNat a b) ~ 'True => a <= b Source #

Use GHC's built-in type-level arithmetic to prove that one number is less-than-or-equal-to another. The type-checker only reduces CmpNat if both arguments are constants.

Lift and Unlift

lift :: (a <=# b) -> a <= b Source #

unlift :: (a <= b) -> a <=# b Source #