thus
f :=<0,...,0> a is parahalting
f :=<0,...,0> a is keeping_0 proof
set Ma =
Macro (f :=<0,...,0> a);
let s be
0 -started State of
SCM+FSA;
AMISTD_1:def 11,
SCMFSA6C:def 1 for b1 being set holds
( not Macro (f :=<0,...,0> a) c= b1 or b1 halts_on s )
A12:
Start-At (
0,
SCM+FSA)
c= s
by MEMSTR_0:29;
let P be
Instruction-Sequence of
SCM+FSA;
( not Macro (f :=<0,...,0> a) c= P or P halts_on s )
assume A13:
Macro (f :=<0,...,0> a) c= P
;
P halts_on s
take
1
;
EXTPRO_1:def 8 ( IC (Comput (P,s,1)) in proj1 P & CurInstr (P,(Comput (P,s,1))) = halt SCM+FSA )
A15:
dom P = NAT
by PARTFUN1:def 2;
thus
IC (Comput (P,s,1)) in dom P
by A15;
CurInstr (P,(Comput (P,s,1))) = halt SCM+FSA
dom (Start-At (0,SCM+FSA)) = {(IC )}
by FUNCOP_1:13;
then A16:
IC in dom (Start-At (0,SCM+FSA))
by TARSKI:def 1;
A17:
IC s =
(Start-At (0,SCM+FSA)) . (IC )
by A16, A12, GRFUNC_1:2
.=
0
by FUNCOP_1:72
;
then A18:
IC (Exec ((f :=<0,...,0> a),s)) =
succ 0
by SCMFSA_2:75
.=
0 + 1
;
A19:
1
in dom (Macro (f :=<0,...,0> a))
by COMPOS_1:60;
A20:
0 in dom (Macro (f :=<0,...,0> a))
by COMPOS_1:60;
A21:
P . 0 =
(Macro (f :=<0,...,0> a)) . 0
by A13, A20, GRFUNC_1:2
.=
f :=<0,...,0> a
by COMPOS_1:58
;
A22:
P . 1 =
(Macro (f :=<0,...,0> a)) . 1
by A13, A19, GRFUNC_1:2
.=
halt SCM+FSA
by COMPOS_1:59
;
Comput (
P,
s,
(0 + 1)) =
Following (
P,
(Comput (P,s,0)))
by EXTPRO_1:3
.=
Following (
P,
s)
by EXTPRO_1:2
.=
Exec (
(f :=<0,...,0> a),
s)
by A17, A15, A21, PARTFUN1:def 6
;
hence
CurInstr (
P,
(Comput (P,s,1)))
= halt SCM+FSA
by A18, A15, A22, PARTFUN1:def 6;
verum
end;
thus
f :=<0,...,0> a is keeping_0
verumproof
set Ma =
Macro (f :=<0,...,0> a);
let s be
0 -started State of
SCM+FSA;
SCMFSA6B:def 4,
SCMFSA6C:def 2 for b1 being set holds
( not Macro (f :=<0,...,0> a) c= b1 or for b2 being Element of NAT holds (Comput (b1,s,b2)) . (intloc 0) = s . (intloc 0) )
A23:
Start-At (
0,
SCM+FSA)
c= s
by MEMSTR_0:29;
let P be
Instruction-Sequence of
SCM+FSA;
( not Macro (f :=<0,...,0> a) c= P or for b1 being Element of NAT holds (Comput (P,s,b1)) . (intloc 0) = s . (intloc 0) )
assume A24:
Macro (f :=<0,...,0> a) c= P
;
for b1 being Element of NAT holds (Comput (P,s,b1)) . (intloc 0) = s . (intloc 0)
let k be
Element of
NAT ;
(Comput (P,s,k)) . (intloc 0) = s . (intloc 0)
dom (Start-At (0,SCM+FSA)) = {(IC )}
by FUNCOP_1:13;
then A25:
IC in dom (Start-At (0,SCM+FSA))
by TARSKI:def 1;
A26:
IC s =
(Start-At (0,SCM+FSA)) . (IC )
by A25, A23, GRFUNC_1:2
.=
0
by FUNCOP_1:72
;
0 in dom (Macro (f :=<0,...,0> a))
by COMPOS_1:60;
then A27:
(Macro (f :=<0,...,0> a)) . 0 = P . 0
by A24, GRFUNC_1:2;
A28:
P /. (IC s) = P . (IC s)
by PBOOLE:143;
A29:
Comput (
P,
s,
(0 + 1)) =
Following (
P,
(Comput (P,s,0)))
by EXTPRO_1:3
.=
Following (
P,
s)
by EXTPRO_1:2
.=
Exec (
(f :=<0,...,0> a),
s)
by A26, A27, A28, COMPOS_1:58
;
1
in dom (Macro (f :=<0,...,0> a))
by COMPOS_1:60;
then
(Macro (f :=<0,...,0> a)) . 1
= P . 1
by A24, GRFUNC_1:2;
then A30:
P . 1
= halt SCM+FSA
by COMPOS_1:59;
IC (Exec ((f :=<0,...,0> a),s)) =
succ 0
by A26, SCMFSA_2:75
.=
0 + 1
;
then A31:
CurInstr (
P,
(Comput (P,s,1)))
= halt SCM+FSA
by A30, A29, PBOOLE:143;
end;