1
|
1 module agda-term where
|
|
2
|
|
3 open import Data.Nat.Base
|
|
4 open import Relation.Binary.PropositionalEquality
|
|
5
|
|
6 +zero : {y : ℕ} → y + zero ≡ y
|
|
7 +zero {zero} = refl
|
|
8 +zero {suc y} = cong (λ yy → suc yy) (+zero {y})
|
|
9
|
|
10 +-suc : {x y : ℕ} → x + suc y ≡ suc (x + y)
|
|
11 +-suc {zero} {y} = refl
|
|
12 +-suc {suc x} {y} = cong suc (+-suc {x} {y})
|
|
13
|
|
14 +-comm : (x y : ℕ) → x + y ≡ y + x
|
|
15 +-comm zero y rewrite (+zero {y}) = refl
|
|
16 +-comm (suc x) y = let open ≡-Reasoning in
|
|
17 begin
|
|
18 suc (x + y) ≡⟨⟩
|
|
19 suc (x + y) ≡⟨ cong suc (+-comm x y) ⟩
|
|
20 suc (y + x) ≡⟨ sym (+-suc {y} {x}) ⟩
|
|
21 y + suc x ∎
|
|
22
|
|
23 +-come : (x y : ℕ) → x + y ≡ y + x
|
|
24 +-come zero y rewrite (+zero {y}) = refl
|
|
25 +-come (suc x) y
|
|
26 rewrite (cong suc (+-come x y)) | sym (+-suc {y} {x}) = refl
|
|
27
|
|
28
|