mirror of
https://github.com/luau-lang/luau.git
synced 2025-04-04 02:40:53 +01:00
Add Properties.Equality to prototyping (#376)
This commit is contained in:
parent
7f867ac166
commit
0b783d8932
3 changed files with 34 additions and 0 deletions
|
@ -1,5 +1,7 @@
|
|||
module Properties where
|
||||
|
||||
import Properties.Contradiction
|
||||
import Properties.Dec
|
||||
import Properties.Equality
|
||||
import Properties.Step
|
||||
import Properties.Remember
|
||||
|
|
9
prototyping/Properties/Contradiction.agda
Normal file
9
prototyping/Properties/Contradiction.agda
Normal file
|
@ -0,0 +1,9 @@
|
|||
module Properties.Contradiction where
|
||||
|
||||
data ⊥ : Set where
|
||||
|
||||
¬ : Set → Set
|
||||
¬ A = A → ⊥
|
||||
|
||||
CONTRADICTION : ∀ {A : Set} → ⊥ → A
|
||||
CONTRADICTION ()
|
23
prototyping/Properties/Equality.agda
Normal file
23
prototyping/Properties/Equality.agda
Normal file
|
@ -0,0 +1,23 @@
|
|||
module Properties.Equality where
|
||||
|
||||
open import Agda.Builtin.Equality using (_≡_; refl)
|
||||
open import Properties.Contradiction using (¬)
|
||||
|
||||
sym : ∀ {A : Set} {a b : A} → (a ≡ b) → (b ≡ a)
|
||||
sym refl = refl
|
||||
|
||||
trans : ∀ {A : Set} {a b c : A} → (a ≡ b) → (b ≡ c) → (a ≡ c)
|
||||
trans refl refl = refl
|
||||
|
||||
cong : ∀ {A B : Set} {a b : A} (f : A → B) → (a ≡ b) → (f a ≡ f b)
|
||||
cong f refl = refl
|
||||
|
||||
subst₁ : ∀ {A : Set} {a b : A} (F : A → Set) → (a ≡ b) → (F a) → (F b)
|
||||
subst₁ F refl x = x
|
||||
|
||||
subst₂ : ∀ {A B : Set} {a b : A} {c d : B} (F : A → B → Set) → (a ≡ b) → (c ≡ d) → (F a c) → (F b d)
|
||||
subst₂ F refl refl x = x
|
||||
|
||||
_≢_ : ∀ {A : Set} → A → A → Set
|
||||
(a ≢ b) = ¬(a ≡ b)
|
||||
|
Loading…
Add table
Reference in a new issue