module Order.Instances.LexicalSum where
Lexicographic sum of posets🔗
Let be a partial order and be a family of partial orders indexed by the underlying set of We can equip the with a lexicographic partial order:
We avoid the more traditional formulation that uses the strict order:
The reason is that naturally involves when we take the non-strict order as the primitive notion. Negated types carry less information and usually work less well in constructive settings.
Given the dependency of on the comparison between and only makes sense when they lie in the same fibre, that is, when there is evidence We can then transport across to obtain a value in which can then be compared against
The concerns of defining the ordering in each fibre, and then defining the ordering on the entire total space, are mostly orthogonal. Indeed, these can be handled in a modular way: the construction we’re interested in naturally arises as the total (thin) category of a particular displayed order over the base poset
: Displayed _ _ I
Lexical-sum-over .D.Ob[_] = ⌞F⌟
Lexical-sum-over .D.Rel[_] {i} {j} _ x y = (p : i ≡ᵢ j) → substᵢ ⌞F⌟ p x F.≤ y Lexical-sum-over
: Poset _ _
Lexical-sum = ∫ Lexical-sum-over Lexical-sum
The fibre in a lexical sum over
is essentially
In fact, their underlying types are judgementally equal in the current
construction. We do not express the sameness using isomorphisms in the
category of posets (Posets
) due to
technical reasons: their universe levels do not match and we would need
ugly lifting to compensate for the differences.
lexical-sum-fibre-equiv: (i : ⌞ I ⌟) → ⌞ Fibre (Lexical-sum-over I F) i ⌟ ≃ ⌞ F i ⌟
= _ , id-equiv
lexical-sum-fibre-equiv i
lexical-sum-fibre-equiv-is-order-embedding: ∀ i → is-order-embedding (Fibre (Lexical-sum-over I F) i) (F i) (λ x → x)
=
lexical-sum-fibre-equiv-is-order-embedding i
prop-ext!(λ x≤y → x≤y reflᵢ)
(λ x≤y p → subst (F._≤ _) (substᵢ-filler-set ⌞F⌟ (hlevel 2) p _) x≤y)
We can also define injections from
which are the generic injections fibre-injᵖ
(for general displayed posets)
precomposed with the inverse of the above equivalence lexical-sum-fibre-equiv
.
: (i : ⌞ I ⌟) → Monotone (F i) (Lexical-sum I F)
lexical-sum-injᵖ .hom x = i , x
lexical-sum-injᵖ i .pres-≤ x≤y = I.≤-refl , λ p →
lexical-sum-injᵖ i (F._≤ _) (substᵢ-filler-set ⌞F⌟ (hlevel 2) p _) x≤y
subst
lexical-sum-injᵖ-is-order-embedding: ∀ i → is-order-embedding (F i) (Lexical-sum I F) (apply (lexical-sum-injᵖ i))
=
lexical-sum-injᵖ-is-order-embedding i (lexical-sum-injᵖ i .pres-≤) λ (_ , q) → q reflᵢ prop-ext!
The name Lexical-sum
is
justified by the observation that it is the maximum poset with
the given index
and fibres
Its mapping-in universal property is: given another poset
displayed over
and a collection a fibrewise map
there exists a (unique!) index-preserving map from the total space of
into the lexical sum such that it commutes with
splitᵖ: ∀ {o ℓ} (G : Displayed o ℓ I)
→ (∀ i → Monotone (Fibre G i) (F i))
→ Monotone (∫ G) (Lexical-sum I F)
.hom (i , x) = i , cases i # x
splitᵖ G cases .pres-≤ (i≤j , x≤y) = i≤j , λ i=ᵢj → lemma-pres-≤ i=ᵢj i≤j x≤y splitᵖ G cases
The categorical definition of lexicographic sums is given by Reinhard Börger, Walter Tholen and Anna Tozzi in their paper Lexicographic sums and fibre-faithful maps.