diff agda/utm.agda @ 140:4c3fbfde1bc2

utm tester
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 14 Mar 2020 19:42:27 +0900
parents 3be1afb87f82
children b3f05cd08d24
line wrap: on
line diff
--- a/agda/utm.agda	Sat Mar 14 17:34:54 2020 +0900
+++ b/agda/utm.agda	Sat Mar 14 19:42:27 2020 +0900
@@ -7,6 +7,7 @@
 open import Data.Nat
 
 data utmStates : Set where
+     reads : utmStates
      read0 : utmStates
      read1 : utmStates
      read2 : utmStates
@@ -67,6 +68,7 @@
     b : utmΣ
 
 utmδ :  utmStates →  utmΣ  → utmStates × (Write utmΣ) × Move
+utmδ reads  x = read0 , wnone , mnone
 utmδ read0  * = read1 , write * , left
 utmδ read0  x = read0 , write x , right
 utmδ read1  x = read2 , write @ , right
@@ -220,15 +222,28 @@
         ++   Copyδ-encode
         ++ ( $ ∷ ^ ∷ input-encode )
 
-utm-test1 : utmStates × ( List  utmΣ ) × ( List  utmΣ )
-utm-test1 = Turing.taccept U-TM  input+Copyδ
+short-input : List utmΣ
+short-input = $  ∷ 0  ∷ 0  ∷  0 ∷  * ∷
+    0  ∷ 0  ∷  0 ∷  1  ∷ 0  ∷ 1 ∷ 1  ∷  * ∷
+    0  ∷ 0  ∷  1 ∷  0  ∷ 1  ∷ 1 ∷ 1  ∷  * ∷
+    0  ∷ 1  ∷  B  ∷  1 ∷  0  ∷ 1 ∷ 0  ∷  * ∷
+    1  ∷ 0  ∷  0 ∷  0 ∷  1  ∷ 1 ∷ 1  ∷  $ ∷
+    ^   ∷ 0  ∷  0 ∷  1  ∷ 1 ∷ []  
 
-utm-test2 : ℕ  → utmStates × ( List  utmΣ ) × ( List  utmΣ )
-utm-test2 n  = loop n (Turing.tstart U-TM) input+Copyδ []
+utm-test1 : List  utmΣ → utmStates × ( List  utmΣ ) × ( List  utmΣ )
+utm-test1 inp = Turing.taccept U-TM  inp
+
+{-# TERMINATING #-}
+utm-test2 : ℕ  → List  utmΣ  → utmStates × ( List  utmΣ ) × ( List  utmΣ )
+utm-test2 n inp  = loop n (Turing.tstart U-TM) inp []
   where
         loop :  ℕ → utmStates → ( List  utmΣ ) → ( List  utmΣ ) → utmStates × ( List  utmΣ ) × ( List  utmΣ )
         loop zero q L R = ( q , L , R )
-        loop (suc n) q L R with  move {utmStates} {utmΣ} {0} {utmδ} q L R
-        ... | nq , nL , nR = loop n nq nL nR
+        loop (suc n) q L R with  move {utmStates} {utmΣ} {0} {utmδ} q L R | q
+        ... | nq , nL , nR | reads = loop n nq nL nR
+        ... | nq , nL , nR | _ = loop (suc n) nq nL nR
 
-t1 = utm-test2 10
+t1 = utm-test2 20 short-input 
+
+t : (n : ℕ)  → utmStates × ( List  utmΣ ) × ( List  utmΣ )
+t n = utm-test2 n short-input