annotate paper/src/MetaMetaCodeSegment.agda.replaced @ 2:c7acb9211784

add code, figure. and paper fix content
author ryokka
date Mon, 27 Jan 2020 20:41:36 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
1 -- meta level
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
2 liftContext : {X Y : Set} {{_ : N.DataSegment X}} {{_ : N.DataSegment Y}} @$\rightarrow$@ N.CodeSegment X Y @$\rightarrow$@ N.CodeSegment Context Context
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
3 liftContext {{x}} {{y}} (N.cs f) = N.cs (\c @$\rightarrow$@ N.DataSegment.set y c (f (N.DataSegment.get x c)))
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
4
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
5 liftMeta : {X Y : Set} {{_ : M.DataSegment X}} {{_ : M.DataSegment Y}} @$\rightarrow$@ N.CodeSegment X Y @$\rightarrow$@ M.CodeSegment X Y
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
6 liftMeta (N.cs f) = M.cs f
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
7
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
8 gotoMeta : {I O : Set} {{_ : N.DataSegment I}} {{_ : N.DataSegment O}} @$\rightarrow$@ M.CodeSegment Meta Meta @$\rightarrow$@ N.CodeSegment I O @$\rightarrow$@ Meta @$\rightarrow$@ Meta
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
9 gotoMeta mCode code m = M.exec mCode (record m {next = (liftContext code)})
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
10
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
11 push : M.CodeSegment Meta Meta
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
12 push = M.cs (\m @$\rightarrow$@ M.exec (liftMeta (Meta.next m)) (record m {c' = Context.c (Meta.context m)}))
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
13
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
14 -- normal level
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
15
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
16 cs2 : N.CodeSegment ds1 ds1
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
17 cs2 = N.cs id
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
18
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
19 cs1 : N.CodeSegment ds1 ds1
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
20 cs1 = N.cs (\d @$\rightarrow$@ N.goto cs2 d)
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
21
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
22 cs0 : N.CodeSegment ds0 ds1
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
23 cs0 = N.cs (\d @$\rightarrow$@ N.goto cs1 (record {c = (ds0.a d) + (ds0.b d)}))
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
24
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
25 -- meta level (with extended normal)
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
26 main : Meta
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
27 main = gotoMeta push cs0 (record {context = (record {a = 100 ; b = 50 ; c = 70}) ; c' = 0 ; next = (N.cs id)})
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
28 -- record {context = record {a = 100 ; b = 50 ; c = 150} ; c' = 70 ; next = (N.cs id)}
c7acb9211784 add code, figure. and paper fix content
ryokka
parents:
diff changeset
29