{-# OPTIONS --cubical --safe #-}
module Cubical.Relation.Nullary where
open import Cubical.Core.Everything
open import Cubical.Foundations.Prelude
open import Cubical.Data.Empty
private
variable
ℓ : Level
A : Set ℓ
infix 3 ¬_
¬_ : Set ℓ → Set ℓ
¬ A = A → ⊥
isProp¬ : (A : Set ℓ) → isProp (¬ A)
isProp¬ A p q i x = isProp⊥ (p x) (q x) i
data Dec (P : Set ℓ) : Set ℓ where
yes : ( p : P) → Dec P
no : (¬p : ¬ P) → Dec P
Stable : Set ℓ → Set ℓ
Stable A = ¬ ¬ A → A
Discrete : Set ℓ → Set ℓ
Discrete A = (x y : A) → Dec (x ≡ y)
Stable¬ : Stable (¬ A)
Stable¬ ¬¬¬a a = ¬¬¬a ¬¬a
where
¬¬a = λ ¬a → ¬a a
fromYes : A → Dec A → A
fromYes _ (yes a) = a
fromYes a (no _) = a
discreteDec : (Adis : Discrete A) → Discrete (Dec A)
discreteDec Adis (yes p) (yes p') = lift (Adis p p')
where
lift : Dec (p ≡ p') → Dec (yes p ≡ yes p')
lift (yes eq) = yes (cong yes eq)
lift (no ¬eq) = no λ eq → ¬eq (cong (fromYes p) eq)
discreteDec Adis (yes p) (no ¬p) = ⊥-elim (¬p p)
discreteDec Adis (no ¬p) (yes p) = ⊥-elim (¬p p)
discreteDec {A = A} Adis (no ¬p) (no ¬p') = yes (cong no (isProp¬ A ¬p ¬p'))
isPropDec : (Aprop : isProp A) → isProp (Dec A)
isPropDec Aprop (yes a) (yes a') = cong yes (Aprop a a')
isPropDec Aprop (yes a) (no ¬a) = ⊥-elim (¬a a)
isPropDec Aprop (no ¬a) (yes a) = ⊥-elim (¬a a)
isPropDec {A = A} Aprop (no ¬a) (no ¬a') = cong no (isProp¬ A ¬a ¬a')