annotate automaton-in-agda/src/extended-automaton.agda @ 392:23db567b4098

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Thu, 27 Jul 2023 09:03:13 +0900
parents 6f3636fbc481
children af8f630b7e60
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
139
3be1afb87f82 add utm
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 46
diff changeset
1 {-# OPTIONS --allow-unsolved-metas #-}
332
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
2 module extended-automaton where
17
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 open import Level renaming ( suc to succ ; zero to Zero )
139
3be1afb87f82 add utm
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 46
diff changeset
5 open import Data.Nat -- hiding ( erase )
17
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 open import Data.List
164
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 141
diff changeset
7 open import Data.Maybe hiding ( map )
318
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 183
diff changeset
8 -- open import Data.Bool using ( Bool ; true ; false ) renaming ( not to negate )
17
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 open import Relation.Binary.PropositionalEquality hiding ( [_] )
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 open import Relation.Nullary using (¬_; Dec; yes; no)
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 open import Level renaming ( suc to succ ; zero to Zero )
164
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 141
diff changeset
12 open import Data.Product hiding ( map )
318
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 183
diff changeset
13 open import logic
17
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14
332
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
15 record Automaton ( Q : Set ) ( Σ : Set ) : Set where
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
16 field
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
17 δ : Q → Σ → Q
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
18 aend : Q → Bool
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
19
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
20 open Automaton
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
21
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
22 accept : { Q : Set } { Σ : Set }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
23 → Automaton Q Σ
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
24 → Q
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
25 → List Σ → Bool
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
26 accept M q [] = aend M q
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
27 accept M q ( H ∷ T ) = accept M ( δ M q H ) T
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
28
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
29 NAutomaton : ( Q : Set ) ( Σ : Set ) → Set
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
30 NAutomaton Q Σ = Automaton ( Q → Bool ) Σ
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
31
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
32 Naccept : { Q : Set } { Σ : Set }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
33 → Automaton (Q → Bool) Σ
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
34 → (exists : ( Q → Bool ) → Bool)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
35 → (Nstart : Q → Bool) → List Σ → Bool
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
36 Naccept M exists sb [] = exists ( λ q → sb q /\ aend M sb )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
37 Naccept M exists sb (i ∷ t ) = Naccept M exists (λ q → exists ( λ qn → (sb qn /\ ( δ M sb i q ) ))) t
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
38
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
39 PDA : ( Q : Set ) ( Σ : Set ) → Set
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
40 PDA Q Σ = Automaton ( List Q ) Σ
17
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41
18
6ec8e933ab43 turing wrote but not yet worked
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
42 data Write ( Σ : Set ) : Set where
6ec8e933ab43 turing wrote but not yet worked
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
43 write : Σ → Write Σ
6ec8e933ab43 turing wrote but not yet worked
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
44 wnone : Write Σ
6ec8e933ab43 turing wrote but not yet worked
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
45 -- erase write tnone
6ec8e933ab43 turing wrote but not yet worked
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
46
20
6032a2317ffa add halt
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
47 data Move : Set where
6032a2317ffa add halt
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
48 left : Move
6032a2317ffa add halt
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
49 right : Move
6032a2317ffa add halt
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
50 mnone : Move
18
6ec8e933ab43 turing wrote but not yet worked
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
51
332
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
52 record OTuring ( Q : Set ) ( Σ : Set )
17
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 : Set where
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 field
20
6032a2317ffa add halt
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
55 tδ : Q → Σ → Q × ( Write Σ ) × Move
17
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 tstart : Q
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 tend : Q → Bool
18
6ec8e933ab43 turing wrote but not yet worked
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
58 tnone : Σ
6ec8e933ab43 turing wrote but not yet worked
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
59 taccept : List Σ → ( Q × List Σ × List Σ )
332
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
60 taccept L = ?
18
6ec8e933ab43 turing wrote but not yet worked
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
61
332
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
62 open import bijection
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
63
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
64 b0 : ( Q : Set ) ( Σ : Set ) → Bijection (List Q) (( Q × ( Write Σ ) × Move ) ∧ ( Q × List Σ × List Σ ))
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
65 b0 = ?
318
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 183
diff changeset
66
332
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
67 Turing : ( Q : Set ) ( Σ : Set ) → Set
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
68 Turing Q Σ = Automaton ( List Q ) Σ
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
69
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
70 NDTM : ( Q : Set ) ( Σ : Set ) → Set
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
71 NDTM Q Σ = Automaton ( List Q → Bool ) Σ
318
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 183
diff changeset
72
332
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
73 UTM : ( Q : Set ) ( Σ : Set ) → Set
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
74 UTM Q Σ = Automaton ( List Q ) Σ
318
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 183
diff changeset
75
332
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
76 SuperTM : ( Q : Set ) ( Σ : Set ) → Set
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 318
diff changeset
77 SuperTM Q Σ = Automaton ( List Q ) Σ
17
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79
08b589172493 add pushdown and turing
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
80