Data.Lattice
- Package
- purescript-colehaus-lattice
- Repository
- colehaus/purescript-lattice
#JoinSemilattice Source
class JoinSemilattice a where
A JoinSemilattice
must satisfy the following laws:
- Associativity of join: forall a b c, join a (join b c) == join (join a b) c
- Commutativity of join: forall a b, join a b == join b a
- Idempotency of join: forall a, join a a == a
Join semilattices capture the notion of sets with a "least upper bound".
Members
join :: a -> a -> a
Instances
#MeetSemilattice Source
class MeetSemilattice a where
A MeetSemilattice
must satisfy the following laws:
- Associativity of meet: forall a b c, meet a (meet b c) == meet (meet a b) c
- Commutativity of meet: forall a b, meet a b == meet b a
- Idempotency of meet: forall a, meet a a == a
Meet semilattices capture the notion of sets with a "greatest lower bound".
Members
meet :: a -> a -> a
Instances
#BoundedJoinSemilattice Source
class (JoinSemilattice a) <= BoundedJoinSemilattice a where
A BoundedJoinSemilattice
must satisfy the following laws in addition to
JoinSemilattice
laws:
Bottom (Unitary Element): forall a, join a bottom == a
Join semilattices capture the notion of sets with a "least upper bound" equipped with a "bottom" element.
Members
bottom :: a
Instances
#BoundedMeetSemilattice Source
class (MeetSemilattice a) <= BoundedMeetSemilattice a where
A BoundedMeetSemilattice
must satisfy the following laws in addition to
MeetSemilattice
laws:
- Top (Unitary Element): forall a, meet a top == a
Meet semilattices capture the notion of sets with a "greatest lower bound" equipped with a "top" element.
Members
top :: a
Instances
#Lattice Source
class (JoinSemilattice a, MeetSemilattice a) <= Lattice a
A Lattice
must satisfy the following in addition to JoinSemilattice
and MeetSemilattice
laws:
- Absorbtion laws for meet and join: forall a b, meet a (join a b) == a forall a b, join a (meet a b) == a
Instances
#BoundedLattice Source
class (BoundedJoinSemilattice a, BoundedMeetSemilattice a) <= BoundedLattice a
A BoundedLattice
must satisfy the following in addition to
BoundedMeetSemilattice
and BoundedJoinSemilattice
laws:
- Absorbtion laws for meet and join: forall a b, meet a (join a b) == a forall a b, join a (meet a b) == a
Instances
- Modules
- Data.
Lattice - Data.
Lattice. Verify