Order homomorphisms #
This file defines order homomorphisms, which are bundled monotone functions. A preorder
homomorphism f : α →o β is a function α → β along with a proof that ∀ x y, x ≤ y → f x ≤ f y.
Main definitions #
In this file we define the following bundled monotone maps:
- OrderHom α βa.k.a.- α →o β: Preorder homomorphism. An- OrderHom α βis a function- f : α → βsuch that- a₁ ≤ a₂ → f a₁ ≤ f a₂
- OrderEmbedding α βa.k.a.- α ↪o β: Relation embedding. An- OrderEmbedding α βis an embedding- f : α ↪ βsuch that- a ≤ b ↔ f a ≤ f b. Defined as an abbreviation of- @RelEmbedding α β (≤) (≤).
- OrderIso: Relation isomorphism. An- OrderIso α βis an equivalence- f : α ≃ βsuch that- a ≤ b ↔ f a ≤ f b. Defined as an abbreviation of- @RelIso α β (≤) (≤).
We also define many OrderHoms. In some cases we define two versions, one with ₘ suffix and
one without it (e.g., OrderHom.compₘ and OrderHom.comp). This means that the former
function is a "more bundled" version of the latter. We can't just drop the "less bundled" version
because the more bundled version usually does not work with dot notation.
- OrderHom.id: identity map as- α →o α;
- OrderHom.curry: an order isomorphism between- α × β →o γand- α →o β →o γ;
- OrderHom.comp: composition of two bundled monotone maps;
- OrderHom.compₘ: composition of bundled monotone maps as a bundled monotone map;
- OrderHom.const: constant function as a bundled monotone map;
- OrderHom.prod: combine- α →o βand- α →o γinto- α →o β × γ;
- OrderHom.prodₘ: a more bundled version of- OrderHom.prod;
- OrderHom.prodIso: order isomorphism between- α →o β × γand- (α →o β) × (α →o γ);
- OrderHom.diag: diagonal embedding of- αinto- α × αas a bundled monotone map;
- OrderHom.onDiag: restrict a monotone map- α →o α →o βto the diagonal;
- OrderHom.fst: projection- Prod.fst : α × β → αas a bundled monotone map;
- OrderHom.snd: projection- Prod.snd : α × β → βas a bundled monotone map;
- OrderHom.prodMap:- Prod.map f gas a bundled monotone map;
- Pi.evalOrderHom: evaluation of a function at a point- Function.eval ias a bundled monotone map;
- OrderHom.coeFnHom: coercion to function as a bundled monotone map;
- OrderHom.apply: application of an- OrderHomat a point as a bundled monotone map;
- OrderHom.pi: combine a family of monotone maps- f i : α →o π iinto a monotone map- α →o Π i, π i;
- OrderHom.piIso: order isomorphism between- α →o Π i, π iand- Π i, α →o π i;
- OrderHom.subtype.val: embedding- Subtype.val : Subtype p → αas a bundled monotone map;
- OrderHom.dual: reinterpret a monotone map- α →o βas a monotone map- αᵒᵈ →o βᵒᵈ;
- OrderHom.dualIso: order isomorphism between- α →o βand- (αᵒᵈ →o βᵒᵈ)ᵒᵈ;
- OrderHom.compl: order isomorphism- α ≃o αᵒᵈgiven by taking complements in a Boolean algebra;
We also define two functions to convert other bundled maps to α →o β:
- OrderEmbedding.toOrderHom: convert- α ↪o βto- α →o β;
- RelHom.toOrderHom: convert a- RelHombetween strict orders to an- OrderHom.
Tags #
monotone map, bundled morphism
Notation for an OrderHom.
Equations
- «term_→o_» = Lean.ParserDescr.trailingNode `«term_→o_» 25 26 (Lean.ParserDescr.binary `andthen (Lean.ParserDescr.symbol " →o ") (Lean.ParserDescr.cat `term 25))
Instances For
An order embedding is an embedding f : α ↪ β such that a ≤ b ↔ (f a) ≤ (f b).
This definition is an abbreviation of RelEmbedding (≤) (≤).
Instances For
Notation for an OrderEmbedding.
Equations
- «term_↪o_» = Lean.ParserDescr.trailingNode `«term_↪o_» 25 25 (Lean.ParserDescr.binary `andthen (Lean.ParserDescr.symbol " ↪o ") (Lean.ParserDescr.cat `term 26))
Instances For
An order isomorphism is an equivalence such that a ≤ b ↔ (f a) ≤ (f b).
This definition is an abbreviation of RelIso (≤) (≤).
Instances For
Notation for an OrderIso.
Equations
- «term_≃o_» = Lean.ParserDescr.trailingNode `«term_≃o_» 25 25 (Lean.ParserDescr.binary `andthen (Lean.ParserDescr.symbol " ≃o ") (Lean.ParserDescr.cat `term 26))
Instances For
OrderHomClass F α b asserts that F is a type of ≤-preserving morphisms.
Equations
- OrderHomClass F α β = RelHomClass F (fun (x1 x2 : α) => x1 ≤ x2) fun (x1 x2 : β) => x1 ≤ x2
Instances For
Turn an element of a type F satisfying OrderIsoClass F α β into an actual
OrderIso. This is declared as the default coercion from F to α ≃o β.
Instances For
Any type satisfying OrderIsoClass can be cast into OrderIso via
OrderIsoClass.toOrderIso.
Equations
Turn an element of a type F satisfying OrderHomClass F α β into an actual
OrderHom. This is declared as the default coercion from F to α →o β.
Instances For
Any type satisfying OrderHomClass can be cast into OrderHom via
OrderHomClass.toOrderHom.
Equations
Equations
- OrderHom.instFunLike = { coe := OrderHom.toFun, coe_injective' := ⋯ }
See Note [custom simps projection]. We give this manually so that we use toFun as the
projection directly instead.
Equations
- OrderHom.Simps.coe f = ⇑f
Instances For
One can lift an unbundled monotone function to a bundled one.
Equations
- OrderHom.instDecidableEqOfForall β a b = decidable_of_iff (a.toFun = b.toFun) ⋯
The identity function as bundled monotone function.
Equations
- OrderHom.id = { toFun := id, monotone' := ⋯ }
Instances For
Equations
- OrderHom.instInhabited = { default := OrderHom.id }
The preorder structure of α →o β is pointwise inequality: f ≤ g ↔ ∀ a, f a ≤ g a.
The composition of two bundled monotone functions, a fully bundled version.
Equations
- OrderHom.compₘ = OrderHom.curry { toFun := fun (f : (β →o γ) × (α →o β)) => f.1.comp f.2, monotone' := ⋯ }
Instances For
Given two bundled monotone maps f, g, f.prod g is the map x ↦ (f x, g x) bundled as a
OrderHom. This is a fully bundled version.
Equations
- OrderHom.prodₘ = OrderHom.curry { toFun := fun (f : (α →o β) × (α →o γ)) => f.1.prod f.2, monotone' := ⋯ }
Instances For
Restriction of f : α →o α →o β to the diagonal.
Equations
- f.onDiag = ((RelIso.symm OrderHom.curry) f).comp OrderHom.diag
Instances For
Order isomorphism between the space of monotone maps to β × γ and the product of the spaces
of monotone maps to β and γ.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Evaluation of an unbundled function at a point (Function.eval) as an OrderHom.
Equations
- Pi.evalOrderHom i = { toFun := Function.eval i, monotone' := ⋯ }
Instances For
Function application fun f => f a (for fixed a) is a monotone function from the
monotone function space α →o β to β. See also Pi.evalOrderHom.
Equations
Instances For
Construct a bundled monotone map α →o Π i, π i from a family of monotone maps
f i : α →o π i.
Equations
- OrderHom.pi f = { toFun := fun (x : α) (i : ι) => (f i) x, monotone' := ⋯ }
Instances For
Order isomorphism between bundled monotone maps α →o Π i, π i and families of bundled monotone
maps Π i, α →o π i.
Equations
- OrderHom.piIso = { toFun := fun (f : α →o (i : ι) → π i) (i : ι) => (Pi.evalOrderHom i).comp f, invFun := OrderHom.pi, left_inv := ⋯, right_inv := ⋯, map_rel_iff' := ⋯ }
Instances For
Subtype.val as a bundled monotone function.
Equations
- OrderHom.Subtype.val p = { toFun := Subtype.val, monotone' := ⋯ }
Instances For
Subtype.impEmbedding as an order embedding.
Equations
- Subtype.orderEmbedding h = { toEmbedding := Subtype.impEmbedding p q h, map_rel_iff' := ⋯ }
Instances For
There is a unique monotone map from a subsingleton to itself.
Equations
- OrderHom.unique = { default := OrderHom.id, uniq := ⋯ }
OrderHom.dual as an order isomorphism.
Equations
- OrderHom.dualIso α β = { toEquiv := OrderHom.dual.trans OrderDual.toDual, map_rel_iff' := ⋯ }
Instances For
Embeddings of partial orders that preserve < also preserve ≤.
Equations
- f.orderEmbeddingOfLTEmbedding = { toEmbedding := f.toEmbedding, map_rel_iff' := ⋯ }
Instances For
< is preserved by order embeddings of preorders.
Equations
- f.ltEmbedding = { toEmbedding := f.toEmbedding, map_rel_iff' := ⋯ }
Instances For
A preorder which embeds into a well-founded preorder is itself well-founded.
A preorder which embeds into a preorder in which (· > ·) is well-founded
also has (· > ·) well-founded.
To define an order embedding from a partial order to a preorder it suffices to give a function
together with a proof that it satisfies f a ≤ f b ↔ a ≤ b.
Equations
Instances For
A strictly monotone map from a linear order is an order embedding.
Equations
Instances For
Embedding of a subtype into the ambient type as an OrderEmbedding.
Equations
- OrderEmbedding.subtype p = { toEmbedding := Function.Embedding.subtype p, map_rel_iff' := ⋯ }
Instances For
Convert an OrderEmbedding to an OrderHom.
Equations
- f.toOrderHom = { toFun := ⇑f, monotone' := ⋯ }
Instances For
The trivial embedding from an empty preorder to another preorder
Equations
- OrderEmbedding.ofIsEmpty = { toFun := fun (a : α) => isEmptyElim a, inj' := ⋯, map_rel_iff' := ⋯ }
Instances For
If the images by an order embedding of two elements are disjoint, then they are themselves disjoint.
If the images by an order embedding of two elements are codisjoint, then they are themselves codisjoint.
If the images by an order embedding of two elements are complements, then they are themselves complements.
A bundled expression of the fact that a map between partial orders that is strictly monotone is weakly monotone.
Equations
- f.toOrderHom = { toFun := ⇑f, monotone' := ⋯ }
Instances For
Reinterpret an order isomorphism as an order embedding.
Equations
Instances For
Identity order isomorphism.
Equations
- OrderIso.refl α = RelIso.refl fun (x1 x2 : α) => x1 ≤ x2
Instances For
An order isomorphism between the domains and codomains of two prosets of order homomorphisms gives an order isomorphism between the two function prosets.
Equations
Instances For
The order isomorphism between a type and its double dual.
Equations
Instances For
Alias of the reverse direction of OrderIso.le_iff_le.
Alias of the reverse direction of OrderIso.lt_iff_lt.
Converts a RelIso (<) (<) into an OrderIso.
Equations
- OrderIso.ofRelIsoLT e = { toEquiv := e.toEquiv, map_rel_iff' := ⋯ }
Instances For
To show that f : α → β, g : β → α make up an order isomorphism of linear orders,
it suffices to prove cmp a (g b) = cmp (f a) b.
Equations
- OrderIso.ofCmpEqCmp f g h = { toFun := f, invFun := g, left_inv := ⋯, right_inv := ⋯, map_rel_iff' := ⋯ }
Instances For
To show that f : α →o β and g : β →o α make up an order isomorphism it is enough to show
that g is the inverse of f.
Equations
- OrderIso.ofHomInv f g h₁ h₂ = { toFun := ⇑f, invFun := ⇑g, left_inv := ⋯, right_inv := ⋯, map_rel_iff' := ⋯ }
Instances For
Order isomorphism between α → β and β, where α has a unique element.
Equations
- OrderIso.funUnique α β = { toEquiv := Equiv.funUnique α β, map_rel_iff' := ⋯ }
Instances For
The order isomorphism α ≃o β when α and β are preordered types
containing unique elements.
Equations
- OrderIso.ofUnique α β = { toEquiv := Equiv.ofUnique α β, map_rel_iff' := ⋯ }
Instances For
If e is an equivalence with monotone forward and inverse maps, then e is an
order isomorphism.
Equations
- e.toOrderIso h₁ h₂ = { toEquiv := e, map_rel_iff' := ⋯ }
Instances For
A strictly monotone function with a right inverse is an order isomorphism.
Equations
- StrictMono.orderIsoOfRightInverse f h_mono g hg = { toFun := f, invFun := g, left_inv := ⋯, right_inv := hg, map_rel_iff' := ⋯ }
Instances For
Note that this goal could also be stated (Disjoint on f) a b
Note that this goal could also be stated (Codisjoint on f) a b