[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [tlaplus] Obtaining Actual Proof Found when using TLAPS? Why is associativity not built-in?




Thanks again @Stephen for your comprehensive answer. This is much more detailed than I had expected. Thank you for your guidance regarding defining a closed (infinite) set of formulas, I will try it later.

I come from a (dynamically-typed) programming language implementation background and the closest analogy to what I am trying to do is a "meta-circular implementation" of propositional logic on top of TLA+. In other words, I am trying to make explicit some of the logic while avoid a complete reimplementation by reusing existing operators. This way I can force the provers to require explicit fact and definition declarations so that the required proofs of basic theorems of propositional logic closely follow what I wrote by hand. In particular, a proof step will fail if I make simple mistakes, such as using the wrong facts or failing to explicit the targets of substitution. But I would like to still obtain a mostly declarative format for the proof, as usual for TLAPS and the proof style advocated by Lamport, and not have to completely redefine and prove a propositional logic.

I think this is possible because the textbook I am using ("A logical approach to discrete mathematics" by Gries and Schneider (1993)), uses a syntactic approach to proving theorems based on sequences of equivalences and substitutions, until the formula is equivalent to one of the axioms. They do this so that you need very little conceptual background to start proving theorem and the proof steps mostly follow the intuition students already have from algebra. So I think I can get away with not having to define and prove a semantics (i.e. interpretation) for the formulas, at the cost of a little more work when defining the axioms and assumptions to supply how equivalence maps to them.

Concretely, here is the current version I have. I re-use:
1. the TLA+ '\equiv'
2. the TLA+ '=' to define variables that corresponds to sub-formulas
3. explicitly mention that substitution is possible between the left-hand side and right-hand side of '\equiv' by asserting that both sides are equal  when equivalent, otherwise the provers don't use the equivalence relationship for substitution.

  EquivImpliesEq == \A f1,f2 \in F : f1 \equiv f2 => f1 = f2

where F is the set of formulas.

Everything else is redefined with different syntactic operators and a representation based on sequences, so the provers cannot use their knowledge of propositional logic to implicitly perform the proof steps. Any feedback is welcome to help simplify things or maybe correct
some misunderstanding I may have!

------------------------ MODULE PropositionalLogic2 ------------------------
EXTENDS Sequences

(* Syntactic redefinition of basic operators of propositional       *)
(* logic to hide them from the provers. Proofs then require         *)
(* explicit facts, otherwise facts we supply that are inconsistent  *)
(* with the proof step do not matter since the provers already know *)
(* all of propositional logic.                                      *)
True   == <<"T">>
False  == <<"F">>
Neg(f) == <<"neg", f>>
Equiv(s) == <<"equiv">> \circ s
a \doteq b == Equiv(<<a,b>>)
a ## b  == Neg(a \doteq b)

(* We define the set of valid formulas by an unconstrained set       *)
(* on which we later assert some properties. This side-steps a few   *)
(* bugs we ran into while using recursive operators or functions.    *)
(* This set is however not closed so cannot be relied on to determine*)
(* when a syntactic formula is incorrect. I will try the approach    *)
(* suggested by Stephen next.                                        *)
CONSTANT F


Formula(f) ==
  \/ Len(f) = 1 /\ Head(f) = Head(True)
  \/ Len(f) = 1 /\ Head(f) = Head(False)
  \/ /\ Head(f) = "neg"
     /\ Len(f) = 2
     /\ \E f2 \in F :
       /\ f=Neg(f2)
  \/ /\ Head(f) = "equiv"
     /\ Len(f) = 3
     /\ \E f1,f2 \in F :
       /\ f=(f1 \doteq f2)

(* The FOK assumptions seemed useful in previous tests     *)
(* but are not necessary for the first two theorems below. *)
FOK ==
/\ \A f : Formula(f) \equiv f \in F
/\ { True, False } \subseteq F
/\ \A f \in F : Neg(f) \in F
/\ \A f1,f2 \in F : (f1 \doteq f2) \in F
/\ \A f1,f2 \in F : (f1 ## f2) \in F

(* Tells the prover to allow substitutions
   between f1 and f2 when they are asserted to be equivalent. *)
EquivImpliesEq == \A f1,f2 \in F : f1 \equiv f2 => f1 = f2


(* These global assumptions are only for the reader: *)
(* they are ignored by the proof manager so we need  *)
(* to repeat them for every theorem when necessary.  *)
ASSUME FOK
ASSUME EquivImpliesEq

(* Axioms are given, first with their strictly syntactic version,  *)
(* then with a subset of corresponding equivalences that we used   *)
(* in proofs.*)
AXIOM EqAssoc == \A p,q,r \in F :
  /\ ((p \doteq q) \doteq r) \doteq (p \doteq (q \doteq r))
  /\ ((p \doteq q) \doteq r) \equiv (p \doteq (q \doteq r))
AXIOM EqSym   == \A p,q   \in F :
  /\ (p \doteq q) \doteq (q \doteq p)
  /\ (p \doteq q) \equiv (q \doteq p)
AXIOM EqIden  == \A p     \in F :
  /\ True \doteq (p \doteq p)
  /\ True \equiv (p \doteq p)
  /\ (True \doteq p) \equiv p

(* Following Gries and Schneider (1993), proofs are   *)
(* written with sequences of equivalences until the   *)
(* theorem reduces to one of the (purely syntactic)   *)
(* axioms.                                            *)
(* Equalities mentioned in proof steps are redundant, *)
(* since they are already part of the assumptions,    *)
(* but they make the substitution explicit for the    *)
(* reader.                                            *)
THEOREM Thm3_4 ==
ASSUME EquivImpliesEq,
       NEW p \in F,
       NEW q \in F, q = True,
       NEW r \in F, r = (p \doteq p)

PROVE True
<1>1 True \equiv (q \doteq q)
  BY EqIden  
<1>2 (q \doteq q) \equiv (q \doteq r)
  BY EqIden, q = True, r = (p \doteq p)  
<1>3 (True \doteq (p \doteq p))
  BY EqIden (* Syntactic Axiom, done *)
<1>z QED
  BY <1>1,<1>2,<1>3
 

THEOREM EqRefl ==
ASSUME EquivImpliesEq,
       NEW p \in F,
       NEW r \in F, r = True,
       NEW s \in F, s = (p \doteq p),
       NEW t \in F, t = p,
       NEW u \in F, u = (p \doteq True),
       \A f1,f2 \in F : f1 \equiv f2 => f1 = f2
PROVE p \doteq p
<1>1 (p \doteq p) \equiv (p \doteq (p \doteq True))
  BY EqIden, t = p, u = (p \doteq True)
<1>2 (p \doteq (p \doteq True)) \equiv ((p \doteq p) \doteq True)
  BY EqAssoc, r = True
<1>3 (True \doteq (p \doteq p)) \equiv ((p \doteq p) \doteq True)
  BY EqSym, r = True, s = (p \doteq p)
<1>4 (True \doteq (p \doteq p))

  BY EqIden (* Syntactic Axiom, done *)
<1>5 QED
  BY <1>1, <1>2, <1>3, <1>4

 
=============================================================================















On Fri, Apr 4, 2025 at 1:52 PM Stephan Merz <stephan.merz@xxxxxxxxx> wrote:
Specifying Systems shows the definitions of the standard modules, including natural numbers. In particular, a set is chosen that satisfies the Peano axioms. Since the book adopts a semantic approach, it does not provide a logical justification for the existence of such a set – after all, we know that the standard set of natural numbers satisfies the Peano axioms.

A proof of existence, analogous to the one written in Isabelle, could very well be given in TLA+, but it requires some preliminary work, including the definition of fixed-point operators and corresponding lemmas in order to justify the underlying inductive definition. Additional TLA+ theorems about natural numbers are given in [1], and if you look at the proofs, you’ll see that the standard induction rule for Nat is justified using the corresponding rule proved in Isabelle.

Stephan

[1] https://github.com/tlaplus/tlapm/blob/main/library/NaturalsInduction.tla, with proofs appearing in https://github.com/tlaplus/tlapm/blob/main/library/NaturalsInduction_proofs.tla


On 3 Apr 2025, at 22:18, Erick Lavoie <erick.lavoie@xxxxxxxxx> wrote:

I have found the Peano natural numbers definition in the TLA+ examples. I also found the Isabelle equivalent, including the comment mentioning that: "the existence of such [a set of naturals] is assumed, but not proven in the [Specifying Systems] book". Are there fundamental limitations of TLA+ that prevent a proof of the existence of a Peano set to be written in TLA+?

Erick 

 

On Thu, Apr 3, 2025 at 5:38 PM Erick Lavoie <erick.lavoie@xxxxxxxxx> wrote:

Thanks both to @Calvin and @Stephen for your detailed answers. That was really useful.

I also stumbled upon "Encoding TLA+ into unsorted and many-sorted first-order logic" (https://doi.org/10.1016/j.scico.2017.09.004) from Stephen, with Section 3.1. on the liberal interpretation of Boolification of TLAPS that helped me understand why I could use propositional logic operators on variables whose possible values are elements of an unconstrained set.

My end goal is to use TLAPS for proving properties of distributed algorithms. I do understand that I should avoid using custom axioms when doing so, for it could unintentionally hide errors. However, my background knowledge on formal mathematics and logic is somewhat lacking, so I am ramping up with the same tools I intend to use later, to validate my reasoning, practice the proof format advocated by Lamport, and learn the limitations of the tools. 

I am impressed that all interesting theorems of propositional calculus from Gries and Schneider (1993) could be obviously proven with TLAPS, except for Leibniz substition (which I could not find how to express). That defeats my goal of verifying my hand proofs however because the Proof Manager succeeds at them regardless of which facts I am supplying to justify intermediate steps (so I cannot catch errors in mis-selecting relevant facts). I understand this is intentional: working engineers should not have to reprove basics of propositional calculus.

So in the last days, I have been experimenting with using the axioms given by Gries and Schneider (1993) with custom syntax / operators except for equivalence, in order to force the provers to work by re-writing. TLAPS successfully verifies the followings theorems from the book this way:

CONSTANT Form

True   == <<"T">>
False  == <<"F">>
Neg(f) == <<"neg", f>>
a ## b  == Neg(a \equiv b)

AXIOM EqAssoc == \A p,q,r \in Form : ((p \equiv q) \equiv r) \equiv (p \equiv (q \equiv r))
AXIOM EqSym   == \A p,q   \in Form : (p \equiv q) \equiv (q \equiv p)
AXIOM EqIden  == \A p     \in Form : (True \equiv (p \equiv p))

THEOREM Thm3_4 == 
ASSUME NEW p \in Form
PROVE True
<1>1 True \equiv (True \equiv True)
  BY EqIden  
<1>2 (True \equiv True) \equiv (True \equiv (p \equiv p))
  BY EqIden (* By replacing 2nd True with (p \equiv p) *)
<1>3 (True \equiv (p \equiv p))
  BY EqIden (* Axiom *)
<1>z QED
  BY <1>1,<1>2,<1>3

AXIOM NegDistrOverEq == \A p,q \in Form : Neg(p \equiv q) \equiv (Neg(p) \equiv q)

THEOREM Thm3_11 ==
ASSUME NEW p \in Form,
       NEW q \in Form
PROVE (Neg(p) \equiv q) \equiv (p \equiv Neg(q))
<1>1 (Neg(p) \equiv q) \equiv Neg(p \equiv q)
  BY NegDistrOverEq   
<1>2 (p \equiv Neg(q)) \equiv Neg(p \equiv q)
  <2>1 (p \equiv Neg(q)) \equiv (Neg(q) \equiv p)
    BY EqSym
  <2>2 (Neg(q) \equiv p) \equiv Neg(q \equiv p)
    BY NegDistrOverEq
  <2>3 Neg(q \equiv p) \equiv Neg(p \equiv q)
    BY EqSym
  <2>4 (Neg(p) \equiv q) \equiv Neg(p \equiv q)
    BY NegDistrOverEq
  <2>5 QED
    BY <2>1, <2>2, <2>3, <2>4
<1>z QED
  BY <1>1, <1>2, EqSym

However, I did not manage to restrict the "Form" set to only contain valid formulas (rather than being an unconstrained set). The various ways I have tried to define the infinite set of valid formulas seem to run into limitations of TLAPS. 

I understand this is possible since Integers and Sequences are infinite sets themselves, but as far as I can tell they are defined in Isabelle rather TLA+. So is what I am trying possible?

Thanks again for your previous help, that was really useful.

Best regards,

Erick

On Thu, Apr 3, 2025 at 3:34 PM Stephan Merz <stephan.merz@xxxxxxxxx> wrote:


LEMMA \A n \in Nat : (\E m \in Nat : n = m+m) => n \div 2 = 0

fails

Well, fortunately TLAPS fails to prove this ... I meant to write

LEMMA \A n \in Nat : (\E m \in Nat : n = m+m) => n % 2 = 0

which is indeed proved by OBVIOUS. Still, there are many intuitively obvious facts that TLAPS fails to prove: for example, it will not prove essentially any assertion involving the Cardinality operator.

Stephan

-- 
You received this message because you are subscribed to the Google Groups "tlaplus" group.
To unsubscribe from this group and stop receiving emails from it, send an email to tlaplus+unsubscribe@xxxxxxxxxxxxxxxx.
To view this discussion visit https://groups.google.com/d/msgid/tlaplus/e7535dbc-0eeb-49a4-ba50-aac7a35bc9dfn%40googlegroups.com.

-- 
You received this message because you are subscribed to the Google Groups "tlaplus" group.
To unsubscribe from this group and stop receiving emails from it, send an email to tlaplus+unsubscribe@xxxxxxxxxxxxxxxx.
To view this discussion visit https://groups.google.com/d/msgid/tlaplus/CAF6T5KrfvpboULwBuoZTEy6jNygV8GBiLXmOG40Ayywc68qgAw%40mail.gmail.com.

--
You received this message because you are subscribed to the Google Groups "tlaplus" group.
To unsubscribe from this group and stop receiving emails from it, send an email to tlaplus+unsubscribe@xxxxxxxxxxxxxxxx.
To view this discussion visit https://groups.google.com/d/msgid/tlaplus/0577B216-F066-4DEB-84B4-D2EDFC3AB903%40gmail.com.

--
You received this message because you are subscribed to the Google Groups "tlaplus" group.
To unsubscribe from this group and stop receiving emails from it, send an email to tlaplus+unsubscribe@xxxxxxxxxxxxxxxx.
To view this discussion visit https://groups.google.com/d/msgid/tlaplus/CAF6T5KoRjiY4gMoVZ%2BCSB3_0kiJXDVmwFeBb2L3Y7zr12dscMQ%40mail.gmail.com.