annotate automaton-in-agda/src/cfg.agda @ 283:e5a0499e7b40

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 27 Dec 2021 19:48:00 +0900
parents 42563cc6afdf
children 91781b7c65a8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
36
9558d870e8ae add cfg and derive
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 module cfg where
9558d870e8ae add cfg and derive
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2
9558d870e8ae add cfg and derive
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 open import Level renaming ( suc to succ ; zero to Zero )
43
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
4 open import Data.Nat hiding ( _≟_ )
39
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 36
diff changeset
5 open import Data.Fin
36
9558d870e8ae add cfg and derive
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 open import Data.Product
39
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 36
diff changeset
7 open import Data.List
36
9558d870e8ae add cfg and derive
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 open import Data.Maybe
40
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
9 open import Data.Bool using ( Bool ; true ; false ; _∧_ ; _∨_ )
36
9558d870e8ae add cfg and derive
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 open import Relation.Binary.PropositionalEquality hiding ( [_] )
9558d870e8ae add cfg and derive
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 open import Relation.Nullary using (¬_; Dec; yes; no)
40
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
12 -- open import Data.String
36
9558d870e8ae add cfg and derive
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
14 data IsTerm (Token : Set) : Set where
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
15 isTerm : Token → IsTerm Token
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
16 noTerm : IsTerm Token
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
17
43
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
18 record CFGGrammer (Token Node : Set) : Set (succ Zero) where
39
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 36
diff changeset
19 field
42
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
20 cfg : Node → List ( List ( Node ) )
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
21 cfgtop : Node
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
22 term? : Node → IsTerm Token
43
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
23 tokensz : ℕ
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
24 tokenid : Token → Fin tokensz
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
25
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
26 open CFGGrammer
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
27
42
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
28 -----------------
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
29 --
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
30 -- CGF language
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
31 --
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
32 -----------------
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
33
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
34 split : {Σ : Set} → (List Σ → Bool)
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
35 → ( List Σ → Bool) → List Σ → Bool
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
36 split x y [] = x [] ∧ y []
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
37 split x y (h ∷ t) = (x [] ∧ y (h ∷ t)) ∨
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
38 split (λ t1 → x ( h ∷ t1 )) (λ t2 → y t2 ) t
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
39
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
40
43
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
41 cfg-language0 : {Node Token : Set} → CFGGrammer Token Node → List (List Node ) → List Token → Bool
40
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
42
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
43 {-# TERMINATING #-}
43
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
44 cfg-language2 : {Node Token : Set} → CFGGrammer Token Node → Node → List Token → Bool
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
45 cfg-language2 cg _ [] = false
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
46 cfg-language2 cg x (h1 ∷ [] ) with term? cg x
43
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
47 cfg-language2 cg x (h1 ∷ []) | isTerm t with tokenid cg h1 ≟ tokenid cg t
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
48 cfg-language2 cg x (h1 ∷ []) | isTerm t | yes p = true
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
49 cfg-language2 cg x (h1 ∷ []) | isTerm t | no ¬p = false
42
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
50 cfg-language2 cg x (h1 ∷ []) | noTerm = cfg-language0 cg (cfg cg x) ( h1 ∷ [] )
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
51 cfg-language2 cg x In with term? cg x
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
52 cfg-language2 cg x In | isTerm t = false
42
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
53 cfg-language2 cg x In | noTerm = cfg-language0 cg (cfg cg x ) In
40
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
54
43
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
55 cfg-language1 : {Node Token : Set} → CFGGrammer Token Node → List Node → List Token → Bool
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
56 cfg-language1 cg [] [] = true
40
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
57 cfg-language1 cg [] _ = false
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
58 cfg-language1 cg (node ∷ T) = split ( cfg-language2 cg node ) ( cfg-language1 cg T )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
59
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
60 cfg-language0 cg [] [] = true
40
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
61 cfg-language0 cg [] _ = false
42
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
62 cfg-language0 cg (node ∷ T) In = cfg-language1 cg node In ∨ cfg-language0 cg T In
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
63
43
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
64 cfg-language : {Node Token : Set} → CFGGrammer Token Node → List Token → Bool
42
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
65 cfg-language cg = cfg-language0 cg (cfg cg (cfgtop cg))
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
66
bbb39677d5ab list base CFG
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
67 -----------------
39
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 36
diff changeset
68
43
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
69 data IFToken : Set where
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
70 t:EA : IFToken
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
71 t:EB : IFToken
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
72 t:EC : IFToken
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
73 t:IF : IFToken
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
74 t:THEN : IFToken
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
75 t:ELSE : IFToken
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
76 t:SA : IFToken
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
77 t:SB : IFToken
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
78 t:SC : IFToken
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
79
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
80 IFtokenid : IFToken → Fin 9
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
81 IFtokenid t:EA = # 0
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
82 IFtokenid t:EB = # 1
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
83 IFtokenid t:EC = # 2
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
84 IFtokenid t:IF = # 3
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
85 IFtokenid t:THEN = # 4
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
86 IFtokenid t:ELSE = # 5
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
87 IFtokenid t:SA = # 6
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
88 IFtokenid t:SB = # 7
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
89 IFtokenid t:SC = # 8
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
90
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
91 data IFNode (T : Set) : Set where
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
92 Token : T → IFNode T
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
93 expr : IFNode T
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
94 statement : IFNode T
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
95
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
96 IFGrammer : CFGGrammer IFToken (IFNode IFToken)
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
97 IFGrammer = record {
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
98 cfg = cfg'
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
99 ; cfgtop = statement
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
100 ; term? = term?'
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
101 ; tokensz = 9
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
102 ; tokenid = IFtokenid
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
103 } where
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
104 term?' : IFNode IFToken → IsTerm IFToken
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
105 term?' (Token x) = isTerm x
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
106 term?' _ = noTerm
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
107 cfg' : IFNode IFToken → List ( List (IFNode IFToken) )
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
108 cfg' (Token t) = ( (Token t) ∷ [] ) ∷ []
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
109 cfg' expr = ( Token t:EA ∷ [] ) ∷
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
110 ( Token t:EB ∷ [] ) ∷
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
111 ( Token t:EC ∷ [] ) ∷ []
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
112 cfg' statement = ( Token t:SA ∷ [] ) ∷
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
113 ( Token t:SB ∷ [] ) ∷
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
114 ( Token t:SC ∷ [] ) ∷
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
115 ( Token t:IF ∷ expr ∷ statement ∷ [] ) ∷
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
116 ( Token t:IF ∷ expr ∷ statement ∷ Token t:ELSE ∷ statement ∷ [] ) ∷ []
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
117
31e4bd173951 using Fin id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 42
diff changeset
118
46
964e4bd0272a add coinduction
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
119 cfgtest1 = cfg-language IFGrammer ( t:SA ∷ [] )
39
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 36
diff changeset
120
46
964e4bd0272a add coinduction
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
121 cfgtest2 = cfg-language2 IFGrammer (Token t:SA) ( t:SA ∷ [] )
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
122
46
964e4bd0272a add coinduction
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
123 cfgtest3 = cfg-language1 IFGrammer (Token t:SA ∷ [] ) ( t:SA ∷ [] )
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
124
46
964e4bd0272a add coinduction
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
125 cfgtest4 = cfg-language IFGrammer (t:IF ∷ t:EA ∷ t:SA ∷ [] )
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
126
46
964e4bd0272a add coinduction
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
127 cfgtest5 = cfg-language1 IFGrammer (Token t:IF ∷ expr ∷ statement ∷ []) (t:IF ∷ t:EA ∷ t:EA ∷ [] )
964e4bd0272a add coinduction
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
128 cfgtest6 = cfg-language2 IFGrammer statement (t:IF ∷ t:EA ∷ t:SA ∷ [] )
964e4bd0272a add coinduction
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
129 cfgtest7 = cfg-language1 IFGrammer (Token t:IF ∷ expr ∷ statement ∷ Token t:ELSE ∷ statement ∷ []) (t:IF ∷ t:EA ∷ t:SA ∷ t:ELSE ∷ t:SB ∷ [] )
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
130
46
964e4bd0272a add coinduction
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 43
diff changeset
131 cfgtest8 = cfg-language IFGrammer (t:IF ∷ t:EA ∷ t:IF ∷ t:EB ∷ t:SA ∷ t:ELSE ∷ t:SB ∷ [] )
41
ae69102153a9 cfg done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 40
diff changeset
132