\begin{code}
{-# OPTIONS --without-K #-}
module UsingIrrelevantFunext.IrrelevantFunext where
open import Preliminaries.SetsAndFunctions
open import UsingIrrelevantFunext.Irrelevance
postulate
[funext] : [ Funext ]
open [_]
funext¹ : {X : Set}
{Y : X → Set}
{f g : (x : X) → Y x}
→ (∀ x → f x ≡ g x) → [ f ≡ g ]
funext¹ e = hide (reveal [funext] e)
funext² : {X : Set}
{Y : X → Set}
{Z : (x : X) → (y : Y x) → Set} →
{f g : (x : X) → (y : Y x) → Z x y}
→ (∀ x y → f x y ≡ g x y) → [ f ≡ g ]
funext² {X} {Y} {Z} {f} {g} exy = goal
where
F G : (w : Σ \(x : X) → Y x) → Z (pr₁ w) (pr₂ w)
F (x , y) = f x y
G (x , y) = g x y
Exy : (w : Σ \(x : X) → Y x) → F w ≡ G w
Exy (x , y) = exy x y
E : [ F ≡ G ]
E = funext¹ Exy
goal : [ f ≡ g ]
goal = functor (ap (λ φ x y → φ(x , y))) E
funext³ : {X : Set}
{Y : X → Set}
{Z : (x : X) → Y x → Set}
{W : (x : X) → (y : Y x) → Z x y → Set}
{f g : (x : X) → (y : Y x) → (z : Z x y) → W x y z}
→ (∀ x y z → f x y z ≡ g x y z) → [ f ≡ g ]
funext³ {X} {Y} {Z} {W} {f} {g} exyz = goal
where
F G : (w : Σ \(x : X) → Σ \(y : Y x) → Z x y) → W (pr₁ w) (pr₁(pr₂ w)) (pr₂(pr₂ w))
F (x , y , z) = f x y z
G (x , y , z) = g x y z
Exyz : (w : Σ \(x : X) → Σ \(y : Y x) → Z x y) → F w ≡ G w
Exyz (x , y , z) = exyz x y z
E : [ F ≡ G ]
E = funext¹ Exyz
goal : [ f ≡ g ]
goal = functor (ap (λ φ x y z → φ(x , y , z))) E
funext⁴ : {X : Set}
{Y : X → Set}
{Z : (x : X) → Y x → Set}
{W : (x : X) → (y : Y x) → Z x y → Set}
{U : (x : X) → (y : Y x) → (z : Z x y) → (w : W x y z) → Set}
{f g : (x : X) → (y : Y x) → (z : Z x y) → (w : W x y z) → U x y z w}
→ (∀ x y z w → f x y z w ≡ g x y z w) → [ f ≡ g ]
funext⁴ {X} {Y} {Z} {W} {U} {f} {g} ex = goal
where
Ω : Set
Ω = Σ \(x : X) → Σ \(y : Y x) → Σ \(z : Z x y) → W x y z
F G : (ω : Ω) → U (pr₁ ω) (pr₁(pr₂ ω)) (pr₁(pr₂(pr₂ ω))) (pr₂(pr₂(pr₂ ω)))
F (x , y , z , w) = f x y z w
G (x , y , z , w) = g x y z w
Ex : (ω : Ω) → F ω ≡ G ω
Ex (x , y , z , w) = ex x y z w
E : [ F ≡ G ]
E = funext¹ Ex
goal : [ f ≡ g ]
goal = functor (ap (λ φ x y z w → φ(x , y , z , w))) E
funext⁵ : {X : Set}
{Y : X → Set}
{Z : (x : X) → Y x → Set}
{W : (x : X) → (y : Y x) → Z x y → Set}
{U : (x : X) → (y : Y x) → (z : Z x y) → W x y z → Set}
{V : (x : X) → (y : Y x) → (z : Z x y) → (w : W x y z) → U x y z w → Set}
{f g : (x : X) → (y : Y x) → (z : Z x y) → (w : W x y z) → (u : U x y z w) → V x y z w u}
→ (∀ x y z w u → f x y z w u ≡ g x y z w u) → [ f ≡ g ]
funext⁵ {X} {Y} {Z} {W} {U} {V} {f} {g} ex = goal
where
Ω : Set
Ω = Σ \(x : X) → Σ \(y : Y x) → Σ \(z : Z x y) → Σ \(w : W x y z) → U x y z w
F G : (ω : Ω) → V (pr₁ ω) (pr₁(pr₂ ω)) (pr₁(pr₂(pr₂ ω))) (pr₁(pr₂(pr₂(pr₂ ω)))) (pr₂(pr₂(pr₂(pr₂ ω))))
F (x , y , z , w , u) = f x y z w u
G (x , y , z , w , u) = g x y z w u
Ex : (ω : Ω) → F ω ≡ G ω
Ex (x , y , z , w , u) = ex x y z w u
E : [ F ≡ G ]
E = funext¹ Ex
goal : [ f ≡ g ]
goal = functor (ap (λ φ x y z w u → φ(x , y , z , w , u))) E
\end{code}