-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathSBTM.v
73 lines (59 loc) · 1.99 KB
/
SBTM.v
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
(*
Problem(s):
Binary Single-tape Turing Machine Halting (SBTM_HALT)
*)
Require Coq.Vectors.Fin Coq.Vectors.Vector.
#[local] Open Scope list_scope.
#[local] Open Scope type_scope.
Inductive direction : Type := go_left | go_right.
(* the tape implicitly contains blanks ("false") to the left and right *)
Definition mv (d: direction) (t: (list bool * bool * list bool)) :=
match d with
| go_left =>
match t with
| (l :: ls, a, rs) => (ls, l, a :: rs)
| (nil, a, rs) => (nil, false, a :: rs)
end
| go_right =>
match t with
| (ls, a, r :: rs) => (a :: ls, r, rs)
| (ls, a, nil) => (a :: ls, false, nil)
end
end.
Record SBTM := Build_SBTM {
num_states : nat;
(* transition table *)
trans : Vector.t (
(option ((Fin.t num_states) * bool * direction)) *
(option ((Fin.t num_states) * bool * direction)))
num_states }.
Module SBTMNotations.
Notation tape := (list bool * bool * list bool).
Notation state M := (Fin.t (num_states M)).
Notation config M := ((state M) * tape).
End SBTMNotations.
Import SBTMNotations.
(* transition table presented as a finite function *)
Definition trans' M : (state M) * bool -> option ((state M) * bool * direction) :=
fun '(q, a) =>
match a with
| true => fst
| false => snd
end (Vector.nth (trans M) q).
Arguments trans' : simpl never.
(* step function *)
Definition step (M: SBTM) : config M -> option (config M) :=
fun '(q, (ls, a, rs)) =>
match trans' M (q, a) with
| None => None
| Some (q', a', d) => Some (q', mv d (ls, a', rs))
end.
Arguments step : simpl never.
#[local] Definition obind {X Y} (f : X -> option Y) (o : option X) :=
match o with None => None | Some x => f x end.
(* iterated step function *)
Definition steps (M: SBTM) (k: nat) (x: config M) : option (config M) :=
Nat.iter k (obind (step M)) (Some x).
(* SBTM halting problem *)
Definition SBTM_HALT : { M : SBTM & config M } -> Prop :=
fun '(existT _ M x) => exists k, steps M k x = None.