Bounded order homomorphisms #
This file defines (bounded) order homomorphisms.
We use the DFunLike
design, so each type of morphisms has a companion typeclass which is meant to
be satisfied by itself and all stricter types.
Types of morphisms #
TopHom
: Maps which preserve⊤
.BotHom
: Maps which preserve⊥
.BoundedOrderHom
: Bounded order homomorphisms. Monotone maps which preserve⊤
and⊥
.
Typeclasses #
The type of ⊤
-preserving functions from α
to β
.
- toFun : α → β
The underlying function. The preferred spelling is
DFunLike.coe
. The function preserves the top element. The preferred spelling is
map_top
.
Instances For
The type of ⊥
-preserving functions from α
to β
.
- toFun : α → β
The underlying function. The preferred spelling is
DFunLike.coe
. The function preserves the bottom element. The preferred spelling is
map_bot
.
Instances For
The type of bounded order homomorphisms from α
to β
.
- toFun : α → β
- monotone' : Monotone self.toFun
The function preserves the top element. The preferred spelling is
map_top
.The function preserves the bottom element. The preferred spelling is
map_bot
.
Instances For
TopHomClass F α β
states that F
is a type of ⊤
-preserving morphisms.
You should extend this class when you extend TopHom
.
A
TopHomClass
morphism preserves the top element.
Instances
BotHomClass F α β
states that F
is a type of ⊥
-preserving morphisms.
You should extend this class when you extend BotHom
.
A
BotHomClass
morphism preserves the bottom element.
Instances
BoundedOrderHomClass F α β
states that F
is a type of bounded order morphisms.
You should extend this class when you extend BoundedOrderHom
.
Morphisms preserve the top element. The preferred spelling is
_root_.map_top
.Morphisms preserve the bottom element. The preferred spelling is
_root_.map_bot
.
Instances
Equations
- (_ : TopHomClass F α β) = (_ : TopHomClass F α β)
Equations
- (_ : BotHomClass F α β) = (_ : BotHomClass F α β)
Equations
- (_ : TopHomClass F α β) = (_ : TopHomClass F α β)
Equations
- (_ : BotHomClass F α β) = (_ : BotHomClass F α β)
Equations
- (_ : BoundedOrderHomClass F α β) = (_ : BoundedOrderHomClass F α β)
Turn an element of a type F
satisfying TopHomClass F α β
into an actual
TopHom
. This is declared as the default coercion from F
to TopHom α β
.
Instances For
Turn an element of a type F
satisfying BotHomClass F α β
into an actual
BotHom
. This is declared as the default coercion from F
to BotHom α β
.
Instances For
Turn an element of a type F
satisfying BoundedOrderHomClass F α β
into an actual
BoundedOrderHom
. This is declared as the default coercion from F
to BoundedOrderHom α β
.
Equations
Instances For
Equations
- instCoeTCBoundedOrderHom = { coe := BoundedOrderHomClass.toBoundedOrderHom }
Top homomorphisms #
Equations
- (_ : TopHomClass (TopHom α β) α β) = (_ : TopHomClass (TopHom α β) α β)
Equations
- TopHom.instPartialOrderTopHom = PartialOrder.lift (fun (f : TopHom α β) => ⇑f) (_ : Function.Injective fun (f : TopHom α β) => ⇑f)
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Bot homomorphisms #
Equations
- (_ : BotHomClass (BotHom α β) α β) = (_ : BotHomClass (BotHom α β) α β)
Equations
- BotHom.instPartialOrderBotHom = PartialOrder.lift (fun (f : BotHom α β) => ⇑f) (_ : Function.Injective fun (f : BotHom α β) => ⇑f)
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Bounded order homomorphisms #
Reinterpret a BoundedOrderHom
as a TopHom
.
Equations
- BoundedOrderHom.toTopHom f = { toFun := f.toFun, map_top' := (_ : f.toOrderHom.toFun ⊤ = ⊤) }
Instances For
Reinterpret a BoundedOrderHom
as a BotHom
.
Equations
- BoundedOrderHom.toBotHom f = { toFun := f.toFun, map_bot' := (_ : f.toOrderHom.toFun ⊥ = ⊥) }
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
- (_ : BoundedOrderHomClass (BoundedOrderHom α β) α β) = (_ : BoundedOrderHomClass (BoundedOrderHom α β) α β)
Copy of a BoundedOrderHom
with a new toFun
equal to the old one. Useful to fix
definitional equalities.
Equations
- One or more equations did not get rendered due to their size.
Instances For
id
as a BoundedOrderHom
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- BoundedOrderHom.instInhabitedBoundedOrderHom α = { default := BoundedOrderHom.id α }
Composition of BoundedOrderHom
s as a BoundedOrderHom
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Dual homs #
Reinterpret a bounded order homomorphism as a bounded order homomorphism between the dual orders.
Equations
- One or more equations did not get rendered due to their size.