Loading [MathJax]/jax/output/HTML-CSS/jax.js

rings-0.0.2.1: Rings, semirings, and dioids.

Safe HaskellSafe
LanguageHaskell2010

Data.Semiring.Property

Contents

Synopsis

Properties of pre-semirings & semirings

neutral_addition_on :: Semigroup r => Rel r -> r -> r -> Bool Source #

aR:(z+a)a

A (pre-)semiring with a right-neutral additive sunit must satisfy:

neutral_addition mempty ~~ const True

Or, equivalently:

mempty <> r ~~ r

This is a required property.

neutral_multiplication_on :: Semiring r => Rel r -> r -> r -> Bool Source #

aR:(oa)a

A (pre-)semiring with a right-neutral multiplicative sunit must satisfy:

neutral_multiplication sunit ~~ const True

Or, equivalently:

sunit >< r ~~ r

This is a required property.

associative_addition_on :: Semigroup r => Rel r -> r -> r -> r -> Bool Source #

a,b,cR:(a+b)+ca+(b+c)

R must right-associate addition.

This should be verified by the underlying Semigroup instance, but is included here for completeness.

This is a required property.

associative_multiplication_on :: Semiring r => Rel r -> r -> r -> r -> Bool Source #

a,b,cR:(ab)ca(bc)

R must right-associate multiplication.

This is a required property.

distributive_on :: Semiring r => Rel r -> r -> r -> r -> Bool Source #

a,b,cR:(a+b)c(ac)+(bc)

R must right-distribute multiplication.

When R is a functor and the semiring structure is derived from Alternative, this translates to:

(a <|> b) *> c = (a *> c) <|> (b *> c)

See https://en.wikibooks.org/wiki/Haskell/Alternative_and_MonadPlus.

This is a required property.

Properties of non-unital (near-)semirings

nonunital_on :: (Monoid r, Semiring r) => Rel r -> r -> r -> Bool Source #

a,bR:abab+b

If R is non-unital (i.e. sunit is not distinct from mempty) then it will instead satisfy a right-absorbtion property.

This follows from right-neutrality and right-distributivity.

Compare codistributive and closed_stable.

When R is also left-distributive we get: a,bR:ab=a+ab+b

See also Warning and https://blogs.ncl.ac.uk/andreymokhov/united-monoids/#whatif.

Properties of unital semirings

annihilative_multiplication_on :: (Monoid r, Semiring r) => Rel r -> r -> Bool Source #

aR:(za)u

A R is unital then its addititive sunit must be right-annihilative, i.e.:

mempty >< a ~~ mempty

For Alternative instances this property translates to:

empty *> a ~~ empty

All right semirings must have a right-absorbative addititive sunit, however note that depending on the Prd instance this does not preclude IEEE754-mandated behavior such as:

mempty >< NaN ~~ NaN

This is a required property.

homomorphism_boolean :: forall r. (Eq r, Monoid r, Semiring r) => Bool -> Bool -> Bool Source #

fromBoolean must be a semiring homomorphism into R.

This is a required property.

Properties of cancellative semirings

cancellative_addition_on :: Semigroup r => Rel r -> r -> r -> r -> Bool Source #

a,b,cR:b+ac+ab=c

If R is right-cancellative wrt addition then for all a the section (a <>) is injective.

cancellative_multiplication_on :: Semiring r => Rel r -> r -> r -> r -> Bool Source #

a,b,cR:bacab=c

If R is right-cancellative wrt multiplication then for all a the section (a ><) is injective.

Properties of commutative semirings

commutative_addition_on :: Semigroup r => Rel r -> r -> r -> Bool Source #

a,bR:a+bb+a

commutative_multiplication_on :: Semiring r => Rel r -> r -> r -> Bool Source #

a,bR:abba

Properties of distributive semirings

distributive_finite_on :: (Monoid r, Semiring r) => Rel r -> [r] -> r -> Bool Source #

M0;a1aM,bR:(Mi=1ai)bMi=1aib

R must right-distribute multiplication between finite sums.

For types with exact arithmetic this follows from distributive & neutral_multiplication.

distributive_finite1_on :: Semiring r => Rel r -> NonEmpty r -> r -> Bool Source #

M1;a1aM,bR:(Mi=1ai)bMi=1aib

R must right-distribute multiplication over finite (non-empty) sums.

For types with exact arithmetic this follows from distributive and the universality of fold1.

distributive_cross_on :: (Monoid r, Semiring r) => Rel r -> [r] -> [r] -> Bool Source #

M,N0;a1aM,b1bNR:(Mi=1ai)(Nj=1bj)i=Mj=Ni=1j=1aibj

If R is also left-distributive then it supports cross-multiplication.

distributive_cross1_on :: Semiring r => Rel r -> NonEmpty r -> NonEmpty r -> Bool Source #

M,N1;a1aM,b1bNR:(Mi=1ai)(Nj=1bj)=i=Mj=Ni=1j=1aibj

If R is also left-distributive then it supports (non-empty) cross-multiplication.