changeset 51:16e27df74ec5

Split subtype definitions for reuse context
author atton <atton@cr.ie.u-ryukyu.ac.jp>
date Tue, 10 Jan 2017 02:04:55 +0000
parents ccb34e3f1514
children 4880184e4ab5
files cbc/subtype-sample.agda cbc/subtype.agda
diffstat 2 files changed, 101 insertions(+), 100 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/cbc/subtype-sample.agda	Tue Jan 10 02:04:55 2017 +0000
@@ -0,0 +1,89 @@
+module subtype-sample where
+
+open import Data.Nat
+open import Data.Nat.Show
+open import Data.String hiding (_++_ ; show ; toList ; fromList)
+open import Data.List
+open import Relation.Binary.PropositionalEquality
+
+
+
+record Context : Set where
+  field
+    cycle : ℕ
+    led   : String
+    signature : String
+    
+open import subtype Context
+record LoopCounter : Set where
+  field
+    count : ℕ
+    name  : String
+
+record SignatureWithNum : Set where
+  field
+    signature : String
+    num       : ℕ
+
+instance
+  contextHasLoopCounter : DataSegment LoopCounter
+  contextHasLoopCounter = record {get = (\c   -> record {count = Context.cycle c ;
+                                                         name  = Context.led   c });
+                                  set = (\c l -> record {cycle     = LoopCounter.count l;
+                                                         led       = LoopCounter.name  l;
+                                                         signature = Context.signature c})}
+  contextHasSignatureWithNum : DataSegment SignatureWithNum
+  contextHasSignatureWithNum = record {get = (\c -> record { signature = Context.signature c
+                                                           ; num       = Context.cycle     c})
+                                      ;set = (\c s -> record { cycle = SignatureWithNum.num s
+                                                             ; led    = Context.led c
+                                                             ; signature = SignatureWithNum.signature s})
+                                      }
+
+inc :  LoopCounter -> LoopCounter
+inc  l = record l {count = suc (LoopCounter.count l)}
+
+firstContext : Context
+firstContext = record { cycle = 3 ; led = "q" ; signature = "aaa" }
+
+
+incContextCycle : {{_ : DataSegment LoopCounter }} -> Context -> Context
+incContextCycle {{l}} c = DataSegment.set l c (inc (DataSegment.get l c))
+
+
+equiv : incContextCycle firstContext ≡ record { cycle = 4 ; led = "q" ; signature = "aaa" }
+equiv = refl
+
+
+csInc : CodeSegment LoopCounter LoopCounter
+csInc = cs inc
+
+
+
+equiv-exec : {l : List Set} -> incContextCycle firstContext ≡ exec csInc firstContext
+equiv-exec = refl
+
+comp-sample : {c : Context} -> CodeSegment LoopCounter LoopCounter
+comp-sample {c}  = (csComp {c} csInc csInc)
+
+
+apply-sample : Context
+apply-sample = exec (comp-sample {firstContext}) firstContext
+
+
+
+updateSignature : SignatureWithNum -> SignatureWithNum
+updateSignature record { signature = signature ; num = num } = record { signature = (Data.String._++_) signature (show num ) ; num = num}
+
+
+csUpdateSignature : CodeSegment SignatureWithNum SignatureWithNum
+csUpdateSignature = cs updateSignature
+
+
+
+comp-sample-2 : {c : Context} -> CodeSegment LoopCounter SignatureWithNum
+comp-sample-2 {c}  = csComp {c}  csUpdateSignature  csInc
+
+apply-sample-2 : Context
+apply-sample-2 = exec (comp-sample-2 {firstContext}) firstContext
+
--- a/cbc/subtype.agda	Tue Jan 10 01:40:55 2017 +0000
+++ b/cbc/subtype.agda	Tue Jan 10 02:04:55 2017 +0000
@@ -1,125 +1,37 @@
-module subtype where
+module subtype (Context : Set) where
 
-open import Data.Bool
-open import Data.Nat
-open import Data.Nat.Show
-open import Data.String hiding (_++_ ; show ; toList ; fromList)
-open import Data.List
-open import Data.AVL.Sets
 open import Relation.Binary.PropositionalEquality
 
 
-record Context : Set where
+record DataSegment (A : Set) : Set where
   field
-    cycle : ℕ
-    led   : String
-    signature : String
-
-record Datum (A : Set) : Set where
-  field 
     get : Context -> A
     set : Context -> A -> Context
-open Datum
-
-record LoopCounter : Set where
-  field
-    count : ℕ
-    name  : String
-
-record SignatureWithNum : Set where
-  field
-    signature : String
-    num       : ℕ
+open DataSegment
 
-instance
-  contextHasLoopCounter : Datum LoopCounter
-  contextHasLoopCounter = record {get = (\c   -> record {count = Context.cycle c ;
-                                                         name  = Context.led   c });
-                                  set = (\c l -> record {cycle     = LoopCounter.count l;
-                                                         led       = LoopCounter.name  l;
-                                                         signature = Context.signature c})}
-  contextHasSignatureWithNum : Datum SignatureWithNum
-  contextHasSignatureWithNum = record {get = (\c -> record { signature = Context.signature c
-                                                           ; num       = Context.cycle     c})
-                                      ;set = (\c s -> record { cycle = SignatureWithNum.num s
-                                                             ; led    = Context.led c
-                                                             ; signature = SignatureWithNum.signature s})
-                                      }
+data CodeSegment (A B : Set) : Set where
+  cs : {{_ : DataSegment A}} {{_ : DataSegment B}} -> (A -> B) -> CodeSegment A B
 
 
-inc :  LoopCounter -> LoopCounter
-inc  l = record l {count = suc (LoopCounter.count l)}
-
-firstContext : Context
-firstContext = record { cycle = 3 ; led = "q" ; signature = "aaa" }
-
-
-incContextCycle : {{_ : Datum LoopCounter }} -> Context -> Context
-incContextCycle {{l}} c = Datum.set l c (inc (Datum.get l c))
-
-
-equiv : incContextCycle firstContext ≡ record { cycle = 4 ; led = "q" ; signature = "aaa" }
-equiv = refl
+exec : {I O : Set} {{_ : DataSegment I}} {{_ : DataSegment O}} -> CodeSegment I O -> Context -> Context
+exec {l} {{i}} {{o}}  (cs b) c = DataSegment.set o c (b (get i c))
 
 
-data CodeSegment (A B : Set) : Set where
-  cs : {{_ : Datum A}} {{_ : Datum B}} -> (A -> B) -> CodeSegment A B
-
-BasicCS :  Set -> Set -> Set
-BasicCS A B = CodeSegment  A B
-  
-
-exec : {I O : Set} {{_ : Datum I}} {{_ : Datum O}} -> CodeSegment I O -> Context -> Context
-exec {l} {{i}} {{o}}  (cs b) c = Datum.set o c (b (get i c))
-
-
-comp : {con : Context} -> {A B C D : Set} {{_ : Datum A}} {{_ : Datum B}} {{_ : Datum C}} {{_ : Datum D}}
+comp : {con : Context} -> {A B C D : Set} {{_ : DataSegment A}} {{_ : DataSegment B}} {{_ : DataSegment C}} {{_ : DataSegment D}}
        -> (C -> D) -> (A -> B) -> A -> D
 comp {con} {{i}} {{io}} {{oi}} {{o}} g f x = g (get oi (set io con (f x)))
-                                         
-                                           
-csInc : BasicCS LoopCounter LoopCounter
-csInc = cs inc
-                                       
 
-
-equiv-exec : {l : List Set} -> incContextCycle firstContext ≡ exec csInc firstContext
-equiv-exec = refl
-
-
-csComp : {con : Context} {A B C D : Set} {{_ : Datum A}} {{_ : Datum B}} {{_ : Datum C}} {{_ : Datum D}}
+csComp : {con : Context} {A B C D : Set}
+         {{_ : DataSegment A}} {{_ : DataSegment B}} {{_ : DataSegment C}} {{_ : DataSegment D}}
        -> CodeSegment C D -> CodeSegment A B -> CodeSegment A D
 csComp {con} {A} {B} {C} {D} {{da}} {{db}} {{dc}} {{dd}} (cs g) (cs f)
       = cs {{da}} {{dd}} (comp {con} {{da}} {{db}} {{dc}} {{dd}} g f)
 
-comp-sample : {c : Context} -> CodeSegment LoopCounter LoopCounter
-comp-sample {c}  = (csComp {c} csInc csInc)
-
-
-apply-sample : Context
-apply-sample = exec (comp-sample {firstContext}) firstContext
-
-
-
-updateSignature : SignatureWithNum -> SignatureWithNum
-updateSignature record { signature = signature ; num = num } = record { signature = (Data.String._++_) signature (show num ) ; num = num}
-
-
-csUpdateSignature : BasicCS SignatureWithNum SignatureWithNum
-csUpdateSignature = cs updateSignature
-
-
-
-comp-sample-2 : {c : Context} -> CodeSegment LoopCounter SignatureWithNum
-comp-sample-2 {c}  = csComp {c}  csUpdateSignature  csInc
-
-apply-sample-2 : Context
-apply-sample-2 = exec (comp-sample-2 {firstContext}) firstContext
-
 
 
 comp-associative : {A B C D E F : Set} {con : Context}
-                   {{da : Datum A}} {{db : Datum B}} {{dc : Datum C}} {{dd : Datum D}} {{de : Datum E}} {{df : Datum F}}
+                   {{da : DataSegment A}} {{db : DataSegment B}} {{dc : DataSegment C}}
+                   {{dd : DataSegment D}} {{de : DataSegment E}} {{df : DataSegment F}}
                    -> (a : CodeSegment A B) (b : CodeSegment C D) (c : CodeSegment E F)
                    -> csComp {con} c (csComp {con} b a)  ≡ csComp {con} (csComp {con} c b) a
 comp-associative (cs _) (cs _) (cs _) = refl