Documentation

Mathlib.CategoryTheory.Dialectica.Basic

Dialectica category #

We define the category Dial of the Dialectica interpretation, after [DP89].

Background #

Dialectica categories are important models of linear type theory. They satisfy most of the distinctions that linear logic was meant to introduce and many models do not satisfy, like the independence of constants. Many linear type theories are being used at the moment--nLab describes some of them: for quantum systems, for effects in programming, for linear dependent types. In particular, dialectica categories are connected to polynomial functors, being a slightly more sophisticated version of polynomial types, as discussed, for instance, in Moss and von Glehn's Dialectica models of type theory. As such they are related to the polynomial constructions being developed by Awodey, Riehl, and Hazratpour. For the non-dependent version developed here several applications are known to Petri Nets, small cardinals in Set Theory, state in imperative programming, and others, see Dialectica Categories.

References #

The Dialectica category. An object of the category is a triple ⟨U, X, α ⊆ U × X⟩, and a morphism from ⟨U, X, α⟩ to ⟨V, Y, β⟩ is a pair (f : U ⟶ V, F : U ⨯ Y ⟶ X) such that {(u,y) | α(u, F(u, y))} ⊆ {(u,y) | β(f(u), y)}. The subset α is actually encoded as an element of Subobject (U × X), and the above inequality is expressed using pullbacks.

  • src : C

    The source object

  • tgt : C

    The target object

  • rel : Subobject (self.src self.tgt)

    A subobject of srctgt, interpreted as a relation

Instances For

    A morphism in the Dial C category from ⟨U, X, α⟩ to ⟨V, Y, β⟩ is a pair (f : U ⟶ V, F : U ⨯ Y ⟶ X) such that {(u,y) | α(u, F(u, y))} ≤ {(u,y) | β(f(u), y)}.

    Instances For
      theorem CategoryTheory.Dial.Hom.ext {C : Type u} {inst✝ : Category.{v, u} C} {inst✝¹ : Limits.HasFiniteProducts C} {inst✝² : Limits.HasPullbacks C} {X Y : Dial C} {x y : X.Hom Y} (f : x.f = y.f) (F : x.F = y.F) :
      x = y
      @[simp]
      theorem CategoryTheory.Dial.instCategory_comp_f {C : Type u} [Category.{v, u} C] [Limits.HasFiniteProducts C] [Limits.HasPullbacks C] {x✝ x✝¹ x✝² : Dial C} (F : x✝.Hom x✝¹) (G : x✝¹.Hom x✝²) :
      @[simp]
      theorem CategoryTheory.Dial.instCategory_comp_F {C : Type u} [Category.{v, u} C] [Limits.HasFiniteProducts C] [Limits.HasPullbacks C] {x✝ x✝¹ x✝² : Dial C} (F : x✝.Hom x✝¹) (G : x✝¹.Hom x✝²) :
      theorem CategoryTheory.Dial.hom_ext {C : Type u} [Category.{v, u} C] [Limits.HasFiniteProducts C] [Limits.HasPullbacks C] {X Y : Dial C} {x y : X Y} (hf : x.f = y.f) (hF : x.F = y.F) :
      x = y
      def CategoryTheory.Dial.isoMk {C : Type u} [Category.{v, u} C] [Limits.HasFiniteProducts C] [Limits.HasPullbacks C] {X Y : Dial C} (e₁ : X.src Y.src) (e₂ : X.tgt Y.tgt) (eq : X.rel = (Subobject.pullback (Limits.prod.map e₁.hom e₂.hom)).obj Y.rel) :
      X Y

      An isomorphism in Dial C can be induced by isomorphisms on the source and target, which respect the respective relations on X and Y.

      Equations
      • One or more equations did not get rendered due to their size.
      Instances For
        @[simp]
        theorem CategoryTheory.Dial.isoMk_inv_F {C : Type u} [Category.{v, u} C] [Limits.HasFiniteProducts C] [Limits.HasPullbacks C] {X Y : Dial C} (e₁ : X.src Y.src) (e₂ : X.tgt Y.tgt) (eq : X.rel = (Subobject.pullback (Limits.prod.map e₁.hom e₂.hom)).obj Y.rel) :
        (isoMk e₁ e₂ eq).inv.F = CategoryStruct.comp Limits.prod.snd e₂.hom
        @[simp]
        theorem CategoryTheory.Dial.isoMk_inv_f {C : Type u} [Category.{v, u} C] [Limits.HasFiniteProducts C] [Limits.HasPullbacks C] {X Y : Dial C} (e₁ : X.src Y.src) (e₂ : X.tgt Y.tgt) (eq : X.rel = (Subobject.pullback (Limits.prod.map e₁.hom e₂.hom)).obj Y.rel) :
        (isoMk e₁ e₂ eq).inv.f = e₁.inv
        @[simp]
        theorem CategoryTheory.Dial.isoMk_hom_F {C : Type u} [Category.{v, u} C] [Limits.HasFiniteProducts C] [Limits.HasPullbacks C] {X Y : Dial C} (e₁ : X.src Y.src) (e₂ : X.tgt Y.tgt) (eq : X.rel = (Subobject.pullback (Limits.prod.map e₁.hom e₂.hom)).obj Y.rel) :
        (isoMk e₁ e₂ eq).hom.F = CategoryStruct.comp Limits.prod.snd e₂.inv
        @[simp]
        theorem CategoryTheory.Dial.isoMk_hom_f {C : Type u} [Category.{v, u} C] [Limits.HasFiniteProducts C] [Limits.HasPullbacks C] {X Y : Dial C} (e₁ : X.src Y.src) (e₂ : X.tgt Y.tgt) (eq : X.rel = (Subobject.pullback (Limits.prod.map e₁.hom e₂.hom)).obj Y.rel) :
        (isoMk e₁ e₂ eq).hom.f = e₁.hom