Skip to content

UF.DependentEquality

Martin Escardo, 31st October 2025.


{-# OPTIONS --safe --without-K #-}

module UF.DependentEquality where

open import UF.Base
open import MLTT.Spartan

dependent-Id : {X : 𝓤 ̇ }
               (Y : X  𝓥 ̇ )
               {x₀ x₁ : X}
              x₀  x₁
              Y x₀
              Y x₁
              𝓥 ̇
dependent-Id Y refl y₀ y₁ = (y₀  y₁)

infix -1 dependent-Id

syntax dependent-Id Y e y₀ y₁ = y₀ =⟦ Y , e  y₁

dependent-Id-via-transport : {X : 𝓤 ̇ }
                             (Y : X  𝓥 ̇ )
                             {x₀ x₁ : X}
                             (e : x₀  x₁)
                             {y₀ : Y x₀}
                             {y₁ : Y x₁}
                            (y₀ =⟦ Y , e  y₁)  (transport Y e y₀  y₁)
dependent-Id-via-transport Y refl = refl


Added by Anna Williams, 17th March 2026.

Chaining of equalities.


_⟦∙⟧_ : {X : 𝓤 ̇ }
        {Y : X  𝓥 ̇ }
        {x₀ x₁ x₂ : X}
        {e : x₀  x₁}
        {e' : x₁  x₂}
        {a : Y x₀}
        {b : Y x₁}
        {c : Y x₂}
       a =⟦ Y , e  b
       b =⟦ Y , e'  c
       a =⟦ Y , e  e'  c
_⟦∙⟧_ {_} {_} {_} {_} {_} {_} {_} {refl} {refl} {_} E E' = E  E'


_=⟦⟨_⟩⟧_ : {X : 𝓤 ̇ }
            {Y : X  𝓥 ̇ }
            {x₀ x₁ x₂ : X}
            {e : x₀  x₁}
            {e' : x₁  x₂}
            (a : Y x₀)
            {b : Y x₁}
            {c : Y x₂}
           a =⟦ Y , e  b
           b =⟦ Y , e'  c
           a =⟦ Y , e  e'  c
a =⟦⟨ p ⟩⟧ q = p ⟦∙⟧ q


Symmetry of dependent equality.


dep-sym : {X : 𝓤 ̇ }
          {Y : X  𝓥 ̇ }
          {x₀ x₁ : X}
          {e : x₀  x₁}
          {a : Y x₀}
          {b : Y x₁}
         a =⟦ Y , e  b
         b =⟦ Y , e ⁻¹  a
dep-sym {_} {_} {_} {_} {_} {_} {refl} refl = refl


ap defined for dependent equality.


dep-ap : {X : 𝓤 ̇ }
         {Y : X  𝓥 ̇ }
         {Z : 𝓦 ̇ }
         {A : Z  𝓣 ̇ }
         {x₀ x₁ : X}
         {e : x₀  x₁}
         {E : X  Z}
         {a : Y x₀}
         {b : Y x₁}
         (f : {x : X}  Y x  A (E x))
        a =⟦ Y , e  b
        f a =⟦ A , ap E e  f b
dep-ap {_} {_} {_} {_} {_} {_} {_} {_} {_} {_} {refl} f eq = ap f eq


Equality of dependent equalities.


to-dep-= : {X : 𝓤 ̇ } {Y : X  𝓥 ̇ }
            {x₀ x₁ : X}
            {e : x₀  x₁} {a : Y x₀}
            {b : Y x₁}
           ((i j : transport Y e a  b)  i  j)
           (p q : a =⟦ Y , e  b)
           p  q
to-dep-= {_} {_} {_} {_} {_} {_} {refl} l = l


To show a dependent equality holds, it is sufficient to show that the
transport version holds. Likewise, we can show transport from dependent
equality.


dependent-Id-from-transport : {X : 𝓤 ̇ }
                              {Y : X  𝓥 ̇ }
                              {x₀ x₁ : X}
                              {e : x₀  x₁}
                              {a : Y x₀}
                              {b : Y x₁}
                             transport Y e a  b
                             a =⟦ Y , e  b
dependent-Id-from-transport = Idtofun ((dependent-Id-via-transport _ _)⁻¹)

transport-from-dependent-Id : {X : 𝓤 ̇ }
                              {Y : X  𝓥 ̇ }
                              {x₀ x₁ : X}
                              {e : x₀  x₁}
                              {a : Y x₀}
                              {b : Y x₁}
                             a =⟦ Y , e  b
                             transport Y e a  b
transport-from-dependent-Id = Idtofun (dependent-Id-via-transport _ _)


Define fixites.


infix  3 dep-sym
infixr 0 _=⟦⟨_⟩⟧_