TPTP Problem File: SWV474+1.p
View Solutions
- Solve Problem
%------------------------------------------------------------------------------
% File : SWV474+1 : TPTP v9.0.0. Released v4.0.0.
% Domain : Software Verification
% Problem : Establishing that there cannot be two leaders, part i55_p675
% Version : [Sve07] axioms : Especial.
% English :
% Refs : [Sto97] Stoller (1997), Leader Election in Distributed Systems
% : [Sve07] Svensson (2007), Email to Koen Claessen
% : [Sve08] Svensson (2008), A Semi-Automatic Correctness Proof Pr
% Source : [Sve07]
% Names : stoller_i55_p675 [Sve07]
% Status : Theorem
% Rating : 0.61 v8.2.0, 0.67 v8.1.0, 0.58 v7.5.0, 0.66 v7.4.0, 0.53 v7.3.0, 0.59 v7.1.0, 0.57 v7.0.0, 0.67 v6.4.0, 0.69 v6.3.0, 0.67 v6.2.0, 0.72 v6.1.0, 0.83 v6.0.0, 0.78 v5.5.0, 0.85 v5.4.0, 0.89 v5.3.0, 0.93 v5.2.0, 0.85 v5.1.0, 0.86 v5.0.0, 0.92 v4.1.0, 0.96 v4.0.1, 1.00 v4.0.0
% Syntax : Number of formulae : 67 ( 40 unt; 0 def)
% Number of atoms : 186 ( 101 equ)
% Maximal formula atoms : 75 ( 2 avg)
% Number of connectives : 186 ( 67 ~; 14 |; 60 &)
% ( 13 <=>; 32 =>; 0 <=; 0 <~>)
% Maximal formula depth : 26 ( 4 avg)
% Maximal term depth : 4 ( 1 avg)
% Number of predicates : 6 ( 5 usr; 0 prp; 1-2 aty)
% Number of functors : 32 ( 32 usr; 15 con; 0-2 aty)
% Number of variables : 157 ( 156 !; 1 ?)
% SPC : FOF_THM_RFO_SEQ
% Comments :
%------------------------------------------------------------------------------
%----Include axioms for verification of Stoller's leader election algorithm
include('Axioms/SWV011+0.ax').
%------------------------------------------------------------------------------
fof(conj,conjecture,
! [V,W,X,Y] :
( ( ! [Z,Pid0] :
( elem(m_Ldr(Pid0),queue(host(Z)))
=> ~ leq(host(Z),host(Pid0)) )
& ! [Z,Pid0] :
( elem(m_Down(Pid0),queue(host(Z)))
=> host(Pid0) != host(Z) )
& ! [Z,Pid0] :
( host(Pid0) = nbr_proc
=> ~ elem(m_NotNorm(Z),queue(host(Pid0))) )
& ! [Z,Pid0] :
( ( Pid0 != Z
& host(Pid0) = host(Z) )
=> ( ~ setIn(Z,alive)
| ~ setIn(Pid0,alive) ) )
& ! [Z] :
( ( ( index(status,host(Z)) = elec_1
| index(status,host(Z)) = elec_2 )
& setIn(Z,alive) )
=> index(elid,host(Z)) = Z )
& ! [Z,Pid20,Pid0] :
( ( host(Pid0) != host(Pid20)
& setIn(Pid0,alive)
& host(Pid0) = host(Z)
& index(status,host(Pid0)) = norm
& index(ldr,host(Pid0)) = host(Pid20) )
=> ~ elem(m_Down(Z),queue(host(Pid20))) )
& ! [Z,Pid20,Pid0] :
( ( host(Pid0) != host(Pid20)
& setIn(Pid0,alive)
& host(Pid0) = host(Z)
& index(status,host(Pid0)) = wait
& host(index(elid,host(Pid0))) = host(Pid20) )
=> ~ elem(m_Down(Z),queue(host(Pid20))) )
& ! [Z,Pid30,Pid20,Pid0] :
( ( host(Pid20) != host(Z)
& setIn(Z,alive)
& setIn(Pid20,alive)
& host(Pid30) = host(Z)
& host(Pid0) = host(Pid20) )
=> ~ ( elem(m_Down(Pid0),queue(host(Z)))
& elem(m_Down(Pid30),queue(host(Pid20))) ) )
& ! [Z,Pid30,Pid20,Pid0] :
( ( host(Pid20) != host(Z)
& setIn(Z,alive)
& setIn(Pid20,alive)
& host(Pid30) = host(Z)
& host(Pid0) = host(Pid20) )
=> ~ ( elem(m_Down(Pid0),queue(host(Z)))
& setIn(host(Pid30),index(down,host(Pid20))) ) )
& ! [Z,Pid30,Pid20,Pid0] :
( ( ! [V0] :
( ( ~ leq(host(Pid0),V0)
& leq(s(zero),V0) )
=> ( setIn(V0,index(down,host(Pid0)))
| V0 = host(Pid20) ) )
& elem(m_Down(Pid20),queue(host(Pid0)))
& host(Pid0) = nbr_proc
& host(Pid0) = host(Pid30)
& index(status,host(Pid0)) = elec_1 )
=> ~ ( setIn(Z,alive)
& elem(m_Down(Pid30),queue(host(Z))) ) )
& queue(host(X)) = cons(m_Down(Y),V) )
=> ( setIn(X,alive)
=> ( ~ leq(host(X),host(Y))
=> ( ~ ( ( index(ldr,host(X)) = host(Y)
& index(status,host(X)) = norm )
| ( index(status,host(X)) = wait
& host(Y) = host(index(elid,host(X))) ) )
=> ( ~ ( ! [Z] :
( ( ~ leq(host(X),Z)
& leq(s(zero),Z) )
=> ( setIn(Z,index(down,host(X)))
| Z = host(Y) ) )
& index(status,host(X)) = elec_1 )
=> ! [Z] :
( host(X) != host(Z)
=> ! [W0,X0,Y0] :
( host(X) = host(Y0)
=> ( ( ! [V0] :
( ( ~ leq(host(Y0),V0)
& leq(s(zero),V0) )
=> ( setIn(V0,index(down,host(X)))
| V0 = host(Y)
| V0 = host(X0) ) )
& elem(m_Down(X0),V)
& host(Y0) = host(W0)
& host(Y0) = nbr_proc
& index(status,host(Y0)) = elec_1 )
=> ~ ( setIn(Z,alive)
& elem(m_Down(W0),queue(host(Z))) ) ) ) ) ) ) ) ) ) ).
%------------------------------------------------------------------------------