Mercurial > hg > Papers > 2017 > atton-master
view paper/src/Reasoning.agda @ 144:060202b21724 default tip
Bookbinding
author | atton <atton@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Mon, 27 Feb 2017 20:29:43 +0900 |
parents | 70bea06ebdf3 |
children |
line wrap: on
line source
open import Relation.Binary.PropositionalEquality open import nat open import nat_add open ≡-Reasoning module nat_add_sym_reasoning where addToRight : (n m : Nat) -> S (n + m) ≡ n + (S m) addToRight O m = refl addToRight (S n) m = cong S (addToRight n m) addSym : (n m : Nat) -> n + m ≡ m + n addSym O O = refl addSym O (S m) = cong S (addSym O m) addSym (S n) O = cong S (addSym n O) addSym (S n) (S m) = begin (S n) + (S m) ≡⟨ refl ⟩ S (n + S m) ≡⟨ cong S (addSym n (S m)) ⟩ S ((S m) + n) ≡⟨ addToRight (S m) n ⟩ S (m + S n) ≡⟨ refl ⟩ (S m) + (S n) ∎