annotate src/agda-term.agda @ 1:73127e0ab57c

(none)
author soto@cr.ie.u-ryukyu.ac.jp
date Tue, 08 Sep 2020 18:38:08 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
1 module agda-term where
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
2
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
3 open import Data.Nat.Base
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
4 open import Relation.Binary.PropositionalEquality
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
5
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
6 +zero : {y : ℕ} → y + zero ≡ y
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
7 +zero {zero} = refl
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
8 +zero {suc y} = cong (λ yy → suc yy) (+zero {y})
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
9
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
10 +-suc : {x y : ℕ} → x + suc y ≡ suc (x + y)
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
11 +-suc {zero} {y} = refl
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
12 +-suc {suc x} {y} = cong suc (+-suc {x} {y})
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
13
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
14 +-comm : (x y : ℕ) → x + y ≡ y + x
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
15 +-comm zero y rewrite (+zero {y}) = refl
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
16 +-comm (suc x) y = let open ≡-Reasoning in
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
17 begin
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
18 suc (x + y) ≡⟨⟩
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
19 suc (x + y) ≡⟨ cong suc (+-comm x y) ⟩
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
20 suc (y + x) ≡⟨ sym (+-suc {y} {x}) ⟩
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
21 y + suc x ∎
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
22
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
23 +-come : (x y : ℕ) → x + y ≡ y + x
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
24 +-come zero y rewrite (+zero {y}) = refl
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
25 +-come (suc x) y
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
26 rewrite (cong suc (+-come x y)) | sym (+-suc {y} {x}) = refl
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
27
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
28