Mercurial > hg > Members > atton > agda-proofs
view cbc/product.agda @ 73:a5cac9483f91
Cleanup sample
author | atton <atton@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Wed, 01 Feb 2017 05:27:05 +0000 |
parents | dc6a09d4f900 |
children |
line wrap: on
line source
module product where open import Data.String open import Data.Product open import Data.Nat open import Data.Unit open import Function using (_∘_ ; id) open import Relation.Binary.PropositionalEquality data CodeSegment (I O : Set) : Set where cs : (I -> O) -> CodeSegment I O twiceWithName : (String × ℕ ) -> (String × ℕ ) twiceWithName (s , n) = s , twice n where twice : ℕ -> ℕ twice zero = zero twice (ℕ.suc n₁) = (ℕ.suc (ℕ.suc (twice n₁))) csDouble : CodeSegment (String × ℕ) (String × ℕ) csDouble = cs twiceWithName ods : {I O : Set} -> CodeSegment I O -> Set ods {i} {o} c = o ods-double : ods csDouble ods-double = "hoge" , zero ids : {I O : Set} -> CodeSegment I O -> Set ids {i} {o} c = i ids-double : ids csDouble ids-double = "fuga" , 3 --ids-double : {A : Set} {a : A} -> ids csDouble --ids-double {_} {a} = \(s : String) -> \(n : ℕ) -> a executeCS : {A B : Set} -> CodeSegment A B -> (A -> B) executeCS (cs b) = b infixr 30 _◎_ _◎_ : {A B C : Set} -> CodeSegment A B -> CodeSegment B C -> CodeSegment A C (cs b1) ◎ (cs b2) = cs (b2 ∘ b1) ◎-double : CodeSegment (String × ℕ) (String × ℕ ) --◎-double = csDouble ◎ csDouble ◎ csDouble -- ok ◎-double = csDouble ◎ (cs (\s -> tt)) ◎ (cs (\t -> ("yo" , 100))) -- ok --◎-double = csDouble ◎ (cs (\s -> tt)) ◎ csDouble -- ng (valid type check) open ≡-Reasoning ◎-associative : {A B C D : Set} -> (a : CodeSegment A B) (b : CodeSegment B C) (c : CodeSegment C D) -> (a ◎ b) ◎ c ≡ a ◎ (b ◎ c) ◎-associative (cs _) (cs _) (cs _) = refl