ich eine TLA + spec der Türme von Hanoi Problem geschrieben haben:Wie Formel in TLA + Code übersetzen
TEX
ASCII
------------------------------- MODULE Hanoi -------------------------------
EXTENDS Sequences, Integers
VARIABLE A, B, C
CanMove(x,y) == /\ Len(x) > 0
/\ IF Len(y) > 0 THEN Head(y) > Head(x) ELSE TRUE
Move(x,y,z) == /\ CanMove(x,y)
/\ x' = Tail(x)
/\ y' = <<Head(x)>> \o y
/\ z' = z
Invariant == C /= <<1,2,3>> \* When we win!
Init == /\ A = <<1,2,3>>
/\ B = <<>>
/\ C = <<>>
Next == \/ Move(A,B,C) \* Move A to B
\/ Move(A,C,B) \* Move A to C
\/ Move(B,A,C) \* Move B to A
\/ Move(B,C,A) \* Move B to C
\/ Move(C,A,B) \* Move C to A
\/ Move(C,B,A) \* Move C to B
=============================================================================
Der TLA Model Checker wird das Rätsel für mich lösen, wenn ich denspezifiziereFormel als Invariante.
Ich möchte es aber ein bisschen weniger ausführlich machen, idealerweise möchte ich nicht die unveränderte Variable an Move()
übergeben, aber ich kann nicht herausfinden, wie. Was ich tun möchte, ist zu schreiben
Move(x,y) == /\ CanMove(x,y)
/\ x' = Tail(x)
/\ y' = <<Head(x)>> \o y
/\ UNCHANGED (Difference of and {A,B,C} and {y,x})
Wie kann ich das in der Sprache TLA ausdrücken?