let s1, s2 be State of SCM+FSA ; :: thesis: for I being parahalting Program of SCM+FSA st I +* (Start-At 0 ,SCM+FSA ) c= s1 & I +* (Start-At 0 ,SCM+FSA ) c= s2 & s1,s2 equal_outside NAT holds
( LifeSpan s1 = LifeSpan s2 & Result s1, Result s2 equal_outside NAT )

let I be parahalting Program of SCM+FSA ; :: thesis: ( I +* (Start-At 0 ,SCM+FSA ) c= s1 & I +* (Start-At 0 ,SCM+FSA ) c= s2 & s1,s2 equal_outside NAT implies ( LifeSpan s1 = LifeSpan s2 & Result s1, Result s2 equal_outside NAT ) )
assume that
A1: I +* (Start-At 0 ,SCM+FSA ) c= s1 and
A2: I +* (Start-At 0 ,SCM+FSA ) c= s2 and
A3: s1,s2 equal_outside NAT ; :: thesis: ( LifeSpan s1 = LifeSpan s2 & Result s1, Result s2 equal_outside NAT )
A4: ProgramPart s2 halts_on s2 by A2, Th18;
A5: ProgramPart s1 halts_on s1 by A1, Th18;
A6: now end;
CurInstr (ProgramPart (Comput (ProgramPart s2),s2,(LifeSpan s1))),(Comput (ProgramPart s2),s2,(LifeSpan s1)) = CurInstr (ProgramPart (Comput (ProgramPart s1),s1,(LifeSpan s1))),(Comput (ProgramPart s1),s1,(LifeSpan s1)) by A1, A2, A3, Th28
.= halt SCM+FSA by A5, AMI_1:def 46 ;
hence K: LifeSpan s1 = LifeSpan s2 by A6, A4, AMI_1:def 46; :: thesis: Result s1, Result s2 equal_outside NAT
ProgramPart s2 halts_on s2 by A2, Th18;
then A8: Result s2 = Comput (ProgramPart s2),s2,(LifeSpan s1) by K, AMI_1:122;
ProgramPart s1 halts_on s1 by A1, Th18;
then Result s1 = Comput (ProgramPart s1),s1,(LifeSpan s1) by AMI_1:122;
hence Result s1, Result s2 equal_outside NAT by A1, A2, A3, A8, Th28; :: thesis: verum