Library UniMath.SubstitutionSystems.FromBindingSigsToMonads_Summary
Require Import UniMath.Foundations.NaturalNumbers.
Require Import UniMath.CategoryTheory.Core.Categories.
Require Import UniMath.CategoryTheory.Core.Isos.
Require Import UniMath.CategoryTheory.Core.Univalence.
Require Import UniMath.CategoryTheory.Core.Functors.
Require Import UniMath.CategoryTheory.FunctorAlgebras.
Require Import UniMath.CategoryTheory.FunctorCategory.
Require Import UniMath.CategoryTheory.categories.HSET.Core.
Require Import UniMath.CategoryTheory.categories.HSET.Colimits.
Require Import UniMath.CategoryTheory.categories.HSET.Limits.
Require Import UniMath.CategoryTheory.categories.HSET.Structures.
Require Import UniMath.CategoryTheory.limits.graphs.colimits.
Require Import UniMath.CategoryTheory.limits.initial.
Require Import UniMath.CategoryTheory.limits.binproducts.
Require Import UniMath.CategoryTheory.limits.products.
Require Import UniMath.CategoryTheory.limits.bincoproducts.
Require Import UniMath.CategoryTheory.limits.coproducts.
Require Import UniMath.CategoryTheory.limits.terminal.
Require Import UniMath.CategoryTheory.Chains.All.
Require Import UniMath.CategoryTheory.Adjunctions.Core.
Require Import UniMath.CategoryTheory.ProductCategory.
Require Import UniMath.CategoryTheory.exponentials.
Require Import UniMath.CategoryTheory.whiskering.
Require Import UniMath.CategoryTheory.Monads.Monads.
Require Import UniMath.SubstitutionSystems.SignatureCategory.
Require Import UniMath.SubstitutionSystems.SubstitutionSystems.
Require Import UniMath.SubstitutionSystems.BindingSigToMonad.
Require Import UniMath.SubstitutionSystems.LiftingInitial_alt.
Local Open Scope cat.
Local Notation "[ C , D , hsD ]" := (functor_precategory C D hsD).
Definition 1: Binding signature 
Definition BindingSig : UU :=
@UniMath.SubstitutionSystems.BindingSigToMonad.BindingSig.
@UniMath.SubstitutionSystems.BindingSigToMonad.BindingSig.
Definition 4: Signatures with strength 
Definition Signature : ∏ C : precategory, has_homsets C →
∏ D : precategory, has_homsets D → UU :=
@UniMath.SubstitutionSystems.Signatures.Signature.
∏ D : precategory, has_homsets D → UU :=
@UniMath.SubstitutionSystems.Signatures.Signature.
Definition 5: Morphism of signatures with strength 
Definition SignatureMor :
∏ C D : category,
Signatures.Signature C (homset_property C) D (homset_property D)
→ Signatures.Signature C (homset_property C) D (homset_property D) → UU :=
@UniMath.SubstitutionSystems.SignatureCategory.SignatureMor.
∏ C D : category,
Signatures.Signature C (homset_property C) D (homset_property D)
→ Signatures.Signature C (homset_property C) D (homset_property D) → UU :=
@UniMath.SubstitutionSystems.SignatureCategory.SignatureMor.
Definition 6: Coproduct of signatures with strength 
Definition Sum_of_Signatures :
∏ (I : UU) (C : precategory) (hsC : has_homsets C)
(D : precategory) (hsD : has_homsets D), Coproducts I D
→ (I → Signature C hsC D hsD) → Signature C hsC D hsD :=
@UniMath.SubstitutionSystems.SumOfSignatures.Sum_of_Signatures.
∏ (I : UU) (C : precategory) (hsC : has_homsets C)
(D : precategory) (hsD : has_homsets D), Coproducts I D
→ (I → Signature C hsC D hsD) → Signature C hsC D hsD :=
@UniMath.SubstitutionSystems.SumOfSignatures.Sum_of_Signatures.
Definition 7: Binary product of signatures with strength 
Definition BinProduct_of_Signatures :
∏ (C : precategory) (hsC : has_homsets C)
(D : precategory) (hsD : has_homsets D), BinProducts D →
Signature C hsC D hsD → Signature C hsC D hsD → Signature C hsC D hsD :=
@UniMath.SubstitutionSystems.BinProductOfSignatures.BinProduct_of_Signatures.
∏ (C : precategory) (hsC : has_homsets C)
(D : precategory) (hsD : has_homsets D), BinProducts D →
Signature C hsC D hsD → Signature C hsC D hsD → Signature C hsC D hsD :=
@UniMath.SubstitutionSystems.BinProductOfSignatures.BinProduct_of_Signatures.
Problem 8: Signatures with strength from binding signatures 
Definition BindingSigToSignature :
∏ {C : precategory} (hsC : has_homsets C),
BinProducts C → BinCoproducts C → Terminal C
→ ∏ sig : BindingSig, Coproducts (BindingSigIndex sig) C →
Signature C hsC C hsC :=
@UniMath.SubstitutionSystems.BindingSigToMonad.BindingSigToSignature.
∏ {C : precategory} (hsC : has_homsets C),
BinProducts C → BinCoproducts C → Terminal C
→ ∏ sig : BindingSig, Coproducts (BindingSigIndex sig) C →
Signature C hsC C hsC :=
@UniMath.SubstitutionSystems.BindingSigToMonad.BindingSigToSignature.
Definition 10 and Lemma 11 and 12: see UniMath/SubstitutionSystems/SignatureExamples.v 
 
 Definition 15: Graph 
Definition graph : UU := @UniMath.CategoryTheory.limits.graphs.colimits.graph.
Definition 16: Diagram 
Definition diagram : graph → precategory → UU :=
@UniMath.CategoryTheory.limits.graphs.colimits.diagram.
@UniMath.CategoryTheory.limits.graphs.colimits.diagram.
Definition 17: Cocone 
Definition cocone : ∏ {C : precategory} {g : graph}, diagram g C → C → UU :=
@UniMath.CategoryTheory.limits.graphs.colimits.cocone.
@UniMath.CategoryTheory.limits.graphs.colimits.cocone.
Definition 18: Colimiting cocone 
Definition isColimCocone : ∏ {C : precategory} {g : graph} (d : diagram g C)
(c0 : C), cocone d c0 → UU :=
@UniMath.CategoryTheory.limits.graphs.colimits.isColimCocone.
(c0 : C), cocone d c0 → UU :=
@UniMath.CategoryTheory.limits.graphs.colimits.isColimCocone.
Colimits of a specific shape 
Definition Colims_of_shape : graph → precategory → UU :=
@UniMath.CategoryTheory.limits.graphs.colimits.Colims_of_shape.
@UniMath.CategoryTheory.limits.graphs.colimits.Colims_of_shape.
Colimits of any shape 
Definition Colims : precategory → UU :=
@UniMath.CategoryTheory.limits.graphs.colimits.Colims.
@UniMath.CategoryTheory.limits.graphs.colimits.Colims.
Remark 19: Uniqueness of colimits 
Lemma isaprop_Colims : ∏ C : univalent_category, isaprop (Colims C).
Show proof.
Show proof.
exact @UniMath.CategoryTheory.limits.graphs.colimits.isaprop_Colims.
Definition 20: Preservation of colimits 
Definition preserves_colimit : ∏ {C D : precategory}, functor C D
→ ∏ {g : graph} (d : diagram g C) (L : C), cocone d L → UU :=
@UniMath.CategoryTheory.limits.graphs.colimits.preserves_colimit.
Definition is_cocont : ∏ {C D : precategory}, functor C D → UU :=
@UniMath.CategoryTheory.Chains.Chains.is_cocont.
Definition is_omega_cocont : ∏ {C D : precategory}, functor C D → UU :=
@UniMath.CategoryTheory.Chains.Chains.is_omega_cocont.
→ ∏ {g : graph} (d : diagram g C) (L : C), cocone d L → UU :=
@UniMath.CategoryTheory.limits.graphs.colimits.preserves_colimit.
Definition is_cocont : ∏ {C D : precategory}, functor C D → UU :=
@UniMath.CategoryTheory.Chains.Chains.is_cocont.
Definition is_omega_cocont : ∏ {C D : precategory}, functor C D → UU :=
@UniMath.CategoryTheory.Chains.Chains.is_omega_cocont.
Lemma 21: Invariance of cocontinuity under isomorphism 
Lemma preserves_colimit_iso :
∏ (C D : precategory) (hsD : has_homsets D)
(F G : functor C D) (α : @iso [C,D,hsD] F G)
(g : graph) (d : diagram g C) (L : C) (cc : cocone d L),
preserves_colimit F d L cc → preserves_colimit G d L cc.
Show proof.
∏ (C D : precategory) (hsD : has_homsets D)
(F G : functor C D) (α : @iso [C,D,hsD] F G)
(g : graph) (d : diagram g C) (L : C) (cc : cocone d L),
preserves_colimit F d L cc → preserves_colimit G d L cc.
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.preserves_colimit_iso.
Problem 22: Colimits in functor categories 
Definition ColimsFunctorCategory_of_shape :
∏ (g : graph) (A C : precategory) (hsC : has_homsets C),
Colims_of_shape g C → Colims_of_shape g [A,C,hsC] :=
@UniMath.CategoryTheory.limits.graphs.colimits.ColimsFunctorCategory_of_shape.
∏ (g : graph) (A C : precategory) (hsC : has_homsets C),
Colims_of_shape g C → Colims_of_shape g [A,C,hsC] :=
@UniMath.CategoryTheory.limits.graphs.colimits.ColimsFunctorCategory_of_shape.
Problem 24: Initial algebras of ω-cocontinuous functors 
Definition colimAlgInitial :
∏ (C : precategory) (hsC : has_homsets C) (InitC : Initial C)
(F : functor C C), is_omega_cocont F → ColimCocone (initChain InitC F) →
Initial (FunctorAlg F hsC) :=
@UniMath.CategoryTheory.Chains.Adamek.colimAlgInitial.
∏ (C : precategory) (hsC : has_homsets C) (InitC : Initial C)
(F : functor C C), is_omega_cocont F → ColimCocone (initChain InitC F) →
Initial (FunctorAlg F hsC) :=
@UniMath.CategoryTheory.Chains.Adamek.colimAlgInitial.
Lemma 25: Lambek's lemma 
Lemma initialAlg_is_iso :
∏ (C : precategory) (hsC : has_homsets C) (F : functor C C)
(Aa : algebra_ob F), isInitial (FunctorAlg F hsC) Aa → is_iso (alg_map F Aa).
Show proof.
∏ (C : precategory) (hsC : has_homsets C) (F : functor C C)
(Aa : algebra_ob F), isInitial (FunctorAlg F hsC) Aa → is_iso (alg_map F Aa).
Show proof.
exact @UniMath.CategoryTheory.FunctorAlgebras.initialAlg_is_iso.
Problem 27: Colimits in Set 
Lemma ColimsHSET_of_shape : ∏ (g : graph), Colims_of_shape g HSET.
Show proof.
Show proof.
exact @UniMath.CategoryTheory.categories.HSET.Colimits.ColimsHSET_of_shape.
Lemma 31: Left adjoints preserve colimits 
Lemma left_adjoint_cocont :
∏ (C D : precategory) (F : functor C D), is_left_adjoint F
→ has_homsets C → has_homsets D → is_cocont F.
Show proof.
∏ (C D : precategory) (F : functor C D), is_left_adjoint F
→ has_homsets C → has_homsets D → is_cocont F.
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.left_adjoint_cocont.
Lemma 32: Examples of preservation of colimits  (i): Identity functor 
Lemma preserves_colimit_identity :
∏ C : precategory, has_homsets C
→ ∏ (g : colimits.graph) (d : colimits.diagram g C)
(L : C) (cc : colimits.cocone d L),
preserves_colimit (functor_identity C) d L cc.
Show proof.
∏ C : precategory, has_homsets C
→ ∏ (g : colimits.graph) (d : colimits.diagram g C)
(L : C) (cc : colimits.cocone d L),
preserves_colimit (functor_identity C) d L cc.
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.preserves_colimit_identity.
(ii): Constant functor 
Lemma is_omega_cocont_constant_functor : ∏ C D : precategory, has_homsets D
→ ∏ x : D, Chains.Chains.is_omega_cocont (constant_functor C D x).
Show proof.
→ ∏ x : D, Chains.Chains.is_omega_cocont (constant_functor C D x).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_omega_cocont_constant_functor.
(iii): Diagonal functor 
Lemma is_cocont_delta_functor : ∏ (I : UU) (C : precategory),
Products I C → has_homsets C → is_cocont (delta_functor I C).
Show proof.
Lemma is_omega_cocont_delta_functor : ∏ (I : UU) (C : precategory),
Products I C → has_homsets C → is_omega_cocont (delta_functor I C).
Show proof.
Products I C → has_homsets C → is_cocont (delta_functor I C).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_cocont_delta_functor.
Lemma is_omega_cocont_delta_functor : ∏ (I : UU) (C : precategory),
Products I C → has_homsets C → is_omega_cocont (delta_functor I C).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_omega_cocont_delta_functor.
(iv): Coproduct functor 
Lemma is_cocont_coproduct_functor :
∏ (I : UU) (C : precategory) (PC : Coproducts I C),
has_homsets C → is_cocont (coproduct_functor I PC).
Show proof.
Lemma is_omega_cocont_coproduct_functor :
∏ (I : UU) (C : precategory) (PC : Coproducts I C),
has_homsets C → is_omega_cocont (coproduct_functor I PC).
Show proof.
∏ (I : UU) (C : precategory) (PC : Coproducts I C),
has_homsets C → is_cocont (coproduct_functor I PC).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_cocont_coproduct_functor.
Lemma is_omega_cocont_coproduct_functor :
∏ (I : UU) (C : precategory) (PC : Coproducts I C),
has_homsets C → is_omega_cocont (coproduct_functor I PC).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_omega_cocont_coproduct_functor.
Lemma 33: Examples of preservation of cocontinuity  (i): Composition of functors 
Lemma preserves_colimit_functor_composite :
∏ C D E : precategory, has_homsets E
→ ∏ (F : functor C D) (G : functor D E) (g : graph)
(d : diagram g C) (L : C) (cc : cocone d L),
preserves_colimit F d L cc
→ preserves_colimit G (mapdiagram F d) (F L) (mapcocone F d cc)
→ preserves_colimit (functor_composite F G) d L cc.
Show proof.
Lemma is_cocont_functor_composite :
∏ C D E : precategory, has_homsets E
→ ∏ (F : functor C D) (G : functor D E), is_cocont F → is_cocont G
→ is_cocont (functor_composite F G).
Show proof.
Lemma is_omega_cocont_functor_composite :
∏ C D E : precategory, has_homsets E
→ ∏ (F : functor C D) (G : functor D E), is_omega_cocont F → is_omega_cocont G
→ is_omega_cocont (functor_composite F G).
Show proof.
∏ C D E : precategory, has_homsets E
→ ∏ (F : functor C D) (G : functor D E) (g : graph)
(d : diagram g C) (L : C) (cc : cocone d L),
preserves_colimit F d L cc
→ preserves_colimit G (mapdiagram F d) (F L) (mapcocone F d cc)
→ preserves_colimit (functor_composite F G) d L cc.
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.preserves_colimit_functor_composite.
Lemma is_cocont_functor_composite :
∏ C D E : precategory, has_homsets E
→ ∏ (F : functor C D) (G : functor D E), is_cocont F → is_cocont G
→ is_cocont (functor_composite F G).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_cocont_functor_composite.
Lemma is_omega_cocont_functor_composite :
∏ C D E : precategory, has_homsets E
→ ∏ (F : functor C D) (G : functor D E), is_omega_cocont F → is_omega_cocont G
→ is_omega_cocont (functor_composite F G).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_omega_cocont_functor_composite.
(ii) Tuple functor 
Lemma is_cocont_tuple_functor :
∏ (I : UU) (A : precategory) (B: I -> precategory), (∏ i, has_homsets (B i))
-> ∏ (F : ∏ i, functor A (B i)), (∏ i, is_cocont (F i))
-> is_cocont (tuple_functor F).
Show proof.
Lemma is_omega_cocont_tuple_functor :
∏ (I : UU) (A : precategory) (B: I -> precategory), (∏ i, has_homsets (B i))
-> ∏ (F : ∏ i, functor A (B i)), (∏ i, is_omega_cocont (F i))
-> is_omega_cocont (tuple_functor F).
Show proof.
∏ (I : UU) (A : precategory) (B: I -> precategory), (∏ i, has_homsets (B i))
-> ∏ (F : ∏ i, functor A (B i)), (∏ i, is_cocont (F i))
-> is_cocont (tuple_functor F).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_cocont_tuple_functor.
Lemma is_omega_cocont_tuple_functor :
∏ (I : UU) (A : precategory) (B: I -> precategory), (∏ i, has_homsets (B i))
-> ∏ (F : ∏ i, functor A (B i)), (∏ i, is_omega_cocont (F i))
-> is_omega_cocont (tuple_functor F).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_omega_cocont_tuple_functor.
(iii): Families of functors 
Lemma is_cocont_family_functor :
∏ (I : UU) (A B : precategory), has_homsets A → has_homsets B → isdeceq I
→ ∏ F : I → functor A B, (∏ i : I, is_cocont (F i))
→ is_cocont (family_functor I F).
Show proof.
Lemma is_omega_cocont_family_functor :
∏ (I : UU) (A B : precategory), has_homsets A → has_homsets B → isdeceq I
→ ∏ F : I → functor A B, (∏ i : I, is_omega_cocont (F i))
→ is_omega_cocont (family_functor I F).
Show proof.
∏ (I : UU) (A B : precategory), has_homsets A → has_homsets B → isdeceq I
→ ∏ F : I → functor A B, (∏ i : I, is_cocont (F i))
→ is_cocont (family_functor I F).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_cocont_family_functor.
Lemma is_omega_cocont_family_functor :
∏ (I : UU) (A B : precategory), has_homsets A → has_homsets B → isdeceq I
→ ∏ F : I → functor A B, (∏ i : I, is_omega_cocont (F i))
→ is_omega_cocont (family_functor I F).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_omega_cocont_family_functor.
Example 35: Exponentials in Set 
Definition Exponentials_HSET : Exponentials BinProductsHSET :=
@UniMath.CategoryTheory.categories.HSET.Structures.Exponentials_HSET.
@UniMath.CategoryTheory.categories.HSET.Structures.Exponentials_HSET.
Lemma 36: Left and right product functors preserves colimits 
Lemma is_cocont_constprod_functor1 :
∏ (C : precategory) (PC : BinProducts C), has_homsets C → Exponentials PC
→ ∏ x : C, is_cocont (constprod_functor1 PC x).
Show proof.
Lemma is_omega_cocont_constprod_functor1 :
∏ (C : precategory) (PC : BinProducts C), has_homsets C → Exponentials PC
→ ∏ x : C, is_omega_cocont (constprod_functor1 PC x).
Show proof.
Lemma is_cocont_constprod_functor2 :
∏ (C : precategory) (PC : BinProducts C), has_homsets C → Exponentials PC
→ ∏ x : C, is_cocont (constprod_functor2 PC x).
Show proof.
Lemma is_omega_cocont_constprod_functor2 :
∏ (C : precategory) (PC : BinProducts C), has_homsets C → Exponentials PC
→ ∏ x : C, is_omega_cocont (constprod_functor2 PC x).
Show proof.
∏ (C : precategory) (PC : BinProducts C), has_homsets C → Exponentials PC
→ ∏ x : C, is_cocont (constprod_functor1 PC x).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_cocont_constprod_functor1.
Lemma is_omega_cocont_constprod_functor1 :
∏ (C : precategory) (PC : BinProducts C), has_homsets C → Exponentials PC
→ ∏ x : C, is_omega_cocont (constprod_functor1 PC x).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_omega_cocont_constprod_functor1.
Lemma is_cocont_constprod_functor2 :
∏ (C : precategory) (PC : BinProducts C), has_homsets C → Exponentials PC
→ ∏ x : C, is_cocont (constprod_functor2 PC x).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_cocont_constprod_functor2.
Lemma is_omega_cocont_constprod_functor2 :
∏ (C : precategory) (PC : BinProducts C), has_homsets C → Exponentials PC
→ ∏ x : C, is_omega_cocont (constprod_functor2 PC x).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_omega_cocont_constprod_functor2.
Theorem 37: Binary product functor is ω-cocontinuous 
Lemma is_omega_cocont_binproduct_functor :
∏ (C : precategory) (PC : BinProducts C), has_homsets C
→ (∏ x : C, is_omega_cocont (constprod_functor1 PC x))
→ is_omega_cocont (binproduct_functor PC).
Show proof.
∏ (C : precategory) (PC : BinProducts C), has_homsets C
→ (∏ x : C, is_omega_cocont (constprod_functor1 PC x))
→ is_omega_cocont (binproduct_functor PC).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_omega_cocont_binproduct_functor.
Example 38: Lists of sets 
Theorem 41: Precomposition functor preserves colimits 
Lemma preserves_colimit_pre_composition_functor :
∏ (A B C : precategory) (F : functor A B) (hsB : has_homsets B) (hsC : has_homsets C)
(g : graph) (d : diagram g [B, C, hsC]) (G : [B, C, hsC]) (ccG : cocone d G),
(∏ b : B, ColimCocone (diagram_pointwise hsC d b))
→ preserves_colimit (pre_composition_functor A B C hsB hsC F) d G ccG.
Show proof.
Lemma is_omega_cocont_pre_composition_functor :
∏ (A B C : precategory) (F : functor A B) (hsB : has_homsets B) (hsC : has_homsets C),
Colims_of_shape nat_graph C → is_omega_cocont (pre_composition_functor A B C hsB hsC F).
Show proof.
∏ (A B C : precategory) (F : functor A B) (hsB : has_homsets B) (hsC : has_homsets C)
(g : graph) (d : diagram g [B, C, hsC]) (G : [B, C, hsC]) (ccG : cocone d G),
(∏ b : B, ColimCocone (diagram_pointwise hsC d b))
→ preserves_colimit (pre_composition_functor A B C hsB hsC F) d G ccG.
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.preserves_colimit_pre_composition_functor.
Lemma is_omega_cocont_pre_composition_functor :
∏ (A B C : precategory) (F : functor A B) (hsB : has_homsets B) (hsC : has_homsets C),
Colims_of_shape nat_graph C → is_omega_cocont (pre_composition_functor A B C hsB hsC F).
Show proof.
exact @UniMath.CategoryTheory.Chains.OmegaCocontFunctors.is_omega_cocont_pre_composition_functor.
Theorem 43: Signature functor associated to a binding signature is ω-cocontinuous 
Lemma is_omega_cocont_BindingSigToSignature :
∏ (C : precategory) (hsC : has_homsets C)
(BPC : BinProducts C) (BCC : BinCoproducts C) (TC : Terminal C),
Colims_of_shape nat_graph C →
(∏ F : functor_precategory C C hsC, is_omega_cocont
(constprod_functor1 (BinProducts_functor_precat C C BPC hsC) F))
→ ∏ (sig : BindingSig) (CC : Coproducts (BindingSigIndex sig) C),
is_omega_cocont (pr1 (BindingSigToSignature hsC BPC BCC TC sig CC)).
Show proof.
∏ (C : precategory) (hsC : has_homsets C)
(BPC : BinProducts C) (BCC : BinCoproducts C) (TC : Terminal C),
Colims_of_shape nat_graph C →
(∏ F : functor_precategory C C hsC, is_omega_cocont
(constprod_functor1 (BinProducts_functor_precat C C BPC hsC) F))
→ ∏ (sig : BindingSig) (CC : Coproducts (BindingSigIndex sig) C),
is_omega_cocont (pr1 (BindingSigToSignature hsC BPC BCC TC sig CC)).
Show proof.
exact @UniMath.SubstitutionSystems.BindingSigToMonad.is_omega_cocont_BindingSigToSignature.
Problem 45: Datatypes specified by binding signatures 
Definition DatatypeOfBindingSig :
∏ (C : precategory) (hsC : has_homsets C)
(BPC : BinProducts C) (BCC : BinCoproducts C)
(_ : Initial C) (TC : Terminal C)
(_ : Colims_of_shape nat_graph C)
(_ : ∏ (F : functor_precategory C C hsC),
is_omega_cocont (constprod_functor1 (BinProducts_functor_precat C C BPC hsC) F))
(sig : BindingSig) (CC : Coproducts (BindingSigIndex sig) C),
Initial (FunctorAlg (Id_H C hsC BCC (BindingSigToSignature hsC BPC BCC TC sig CC))
(BindingSigToMonad.has_homsets_C2 hsC)).
Show proof.
∏ (C : precategory) (hsC : has_homsets C)
(BPC : BinProducts C) (BCC : BinCoproducts C)
(_ : Initial C) (TC : Terminal C)
(_ : Colims_of_shape nat_graph C)
(_ : ∏ (F : functor_precategory C C hsC),
is_omega_cocont (constprod_functor1 (BinProducts_functor_precat C C BPC hsC) F))
(sig : BindingSig) (CC : Coproducts (BindingSigIndex sig) C),
Initial (FunctorAlg (Id_H C hsC BCC (BindingSigToSignature hsC BPC BCC TC sig CC))
(BindingSigToMonad.has_homsets_C2 hsC)).
Show proof.
exact @UniMath.SubstitutionSystems.BindingSigToMonad.DatatypeOfBindingSig.
Theorem 48: Construction of a substitution operation on an initial algebra 
Definition InitHSS :
∏ (C : precategory) (hsC : has_homsets C) (CP : BinCoproducts C),
Initial C → Colims_of_shape nat_graph C →
∏ H : Signature C hsC C hsC, is_omega_cocont (pr1 H) → hss_precategory CP H.
Show proof.
Lemma isInitial_InitHSS :
∏ (C : precategory) (hsC : has_homsets C) (CP : BinCoproducts C)
(IC : Initial C) (CC : Colims_of_shape nat_graph C) (H : Signature C hsC C hsC)
(HH : is_omega_cocont (pr1 H)),
isInitial (hss_precategory CP H) (InitHSS C hsC CP IC CC H HH).
Show proof.
∏ (C : precategory) (hsC : has_homsets C) (CP : BinCoproducts C),
Initial C → Colims_of_shape nat_graph C →
∏ H : Signature C hsC C hsC, is_omega_cocont (pr1 H) → hss_precategory CP H.
Show proof.
exact @UniMath.SubstitutionSystems.LiftingInitial_alt.InitHSS.
Lemma isInitial_InitHSS :
∏ (C : precategory) (hsC : has_homsets C) (CP : BinCoproducts C)
(IC : Initial C) (CC : Colims_of_shape nat_graph C) (H : Signature C hsC C hsC)
(HH : is_omega_cocont (pr1 H)),
isInitial (hss_precategory CP H) (InitHSS C hsC CP IC CC H HH).
Show proof.
exact @UniMath.SubstitutionSystems.LiftingInitial_alt.isInitial_InitHSS.
Section 4.2: Binding signatures to monads 
Definition BindingSigToMonad :
∏ (C : precategory) (hsC : has_homsets C) (BPC : BinProducts C),
BinCoproducts C → Terminal C → Initial C → Colims_of_shape nat_graph C
→ (∏ F, is_omega_cocont (constprod_functor1 (BinProducts_functor_precat C C BPC hsC) F))
→ ∏ sig : BindingSig, Coproducts (BindingSigIndex sig) C
→ Monad C.
Show proof.
∏ (C : precategory) (hsC : has_homsets C) (BPC : BinProducts C),
BinCoproducts C → Terminal C → Initial C → Colims_of_shape nat_graph C
→ (∏ F, is_omega_cocont (constprod_functor1 (BinProducts_functor_precat C C BPC hsC) F))
→ ∏ sig : BindingSig, Coproducts (BindingSigIndex sig) C
→ Monad C.
Show proof.
  exact @UniMath.SubstitutionSystems.BindingSigToMonad.BindingSigToMonad.
Example 50: Untyped lambda calculus 
Example 51: Raw syntax of Martin-Löf type theory