TSTP Solution File: PUZ035-5 by Z3---4.8.9.0
View Problem
- Process Solution
%------------------------------------------------------------------------------
% File : Z3---4.8.9.0
% Problem : PUZ035-5 : TPTP v8.1.0. Released v2.0.0.
% Transfm : none
% Format : tptp
% Command : z3_tptp -proof -model -t:%d -file:%s
% Computer : n028.cluster.edu
% Model : x86_64 x86_64
% CPU : Intel(R) Xeon(R) CPU E5-2620 v4 2.10GHz
% Memory : 8042.1875MB
% OS : Linux 3.10.0-693.el7.x86_64
% CPULimit : 300s
% WCLimit : 300s
% DateTime : Sun Sep 18 14:11:01 EDT 2022
% Result : Unsatisfiable 0.14s 0.34s
% Output : Proof 0.14s
% Verified :
% SZS Type : -
% Comments :
%------------------------------------------------------------------------------
%----WARNING: Could not form TPTP format derivation
%------------------------------------------------------------------------------
%----ORIGINAL SYSTEM OUTPUT
% 0.05/0.09 % Problem : PUZ035-5 : TPTP v8.1.0. Released v2.0.0.
% 0.05/0.10 % Command : z3_tptp -proof -model -t:%d -file:%s
% 0.10/0.30 % Computer : n028.cluster.edu
% 0.10/0.30 % Model : x86_64 x86_64
% 0.10/0.30 % CPU : Intel(R) Xeon(R) CPU E5-2620 v4 @ 2.10GHz
% 0.10/0.30 % Memory : 8042.1875MB
% 0.10/0.30 % OS : Linux 3.10.0-693.el7.x86_64
% 0.10/0.30 % CPULimit : 300
% 0.10/0.30 % WCLimit : 300
% 0.10/0.30 % DateTime : Fri Sep 2 18:33:37 EDT 2022
% 0.10/0.30 % CPUTime :
% 0.10/0.30 Z3tptp [4.8.9.0] (c) 2006-20**. Microsoft Corp.
% 0.10/0.30 Usage: tptp [options] [-file:]file
% 0.10/0.30 -h, -? prints this message.
% 0.10/0.30 -smt2 print SMT-LIB2 benchmark.
% 0.10/0.30 -m, -model generate model.
% 0.10/0.30 -p, -proof generate proof.
% 0.10/0.30 -c, -core generate unsat core of named formulas.
% 0.10/0.30 -st, -statistics display statistics.
% 0.10/0.30 -t:timeout set timeout (in second).
% 0.10/0.30 -smt2status display status in smt2 format instead of SZS.
% 0.10/0.30 -check_status check the status produced by Z3 against annotation in benchmark.
% 0.10/0.30 -<param>:<value> configuration parameter and value.
% 0.10/0.30 -o:<output-file> file to place output in.
% 0.14/0.34 % SZS status Unsatisfiable
% 0.14/0.34 % SZS output start Proof
% 0.14/0.34 tff(truth_type, type, (
% 0.14/0.34 truth: $i > $o)).
% 0.14/0.34 tff(isa_type, type, (
% 0.14/0.34 isa: ( $i * $i ) > $i)).
% 0.14/0.34 tff(knave_type, type, (
% 0.14/0.34 knave: $i)).
% 0.14/0.34 tff(other_type, type, (
% 0.14/0.34 other: $i)).
% 0.14/0.34 tff(knight_type, type, (
% 0.14/0.34 knight: $i)).
% 0.14/0.34 tff(asked_type, type, (
% 0.14/0.34 asked: $i)).
% 0.14/0.34 tff(or_type, type, (
% 0.14/0.34 or: ( $i * $i ) > $i)).
% 0.14/0.34 tff(says_type, type, (
% 0.14/0.34 says: ( $i * $i ) > $o)).
% 0.14/0.34 tff(1,assumption,(~truth(isa(asked, knight))), introduced(assumption)).
% 0.14/0.34 tff(2,plain,
% 0.14/0.34 (says(asked, or(isa(asked, knight), isa(other, knight))) <=> says(asked, or(isa(asked, knight), isa(other, knight)))),
% 0.14/0.34 inference(rewrite,[status(thm)],[])).
% 0.14/0.34 tff(3,axiom,(says(asked, or(isa(asked, knight), isa(other, knight)))), file('/export/starexec/sandbox/benchmark/theBenchmark.p','says_yes')).
% 0.14/0.34 tff(4,plain,
% 0.14/0.34 (says(asked, or(isa(asked, knight), isa(other, knight)))),
% 0.14/0.34 inference(modus_ponens,[status(thm)],[3, 2])).
% 0.14/0.34 tff(5,plain,
% 0.14/0.34 (^[S: $i, P: $i] : refl((truth(isa(P, knight)) | (~says(P, S)) | (~truth(S))) <=> (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S))))),
% 0.14/0.34 inference(bind,[status(th)],[])).
% 0.14/0.34 tff(6,plain,
% 0.14/0.34 (![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S))) <=> ![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))),
% 0.14/0.34 inference(quant_intro,[status(thm)],[5])).
% 0.14/0.34 tff(7,plain,
% 0.14/0.34 (![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S))) <=> ![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))),
% 0.14/0.34 inference(rewrite,[status(thm)],[])).
% 0.14/0.34 tff(8,plain,
% 0.14/0.34 (^[S: $i, P: $i] : trans(monotonicity(rewrite((truth(isa(P, knight)) | (~truth(S))) <=> (truth(isa(P, knight)) | (~truth(S)))), (((truth(isa(P, knight)) | (~truth(S))) | (~says(P, S))) <=> ((truth(isa(P, knight)) | (~truth(S))) | (~says(P, S))))), rewrite(((truth(isa(P, knight)) | (~truth(S))) | (~says(P, S))) <=> (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))), (((truth(isa(P, knight)) | (~truth(S))) | (~says(P, S))) <=> (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))))),
% 0.14/0.34 inference(bind,[status(th)],[])).
% 0.14/0.34 tff(9,plain,
% 0.14/0.34 (![S: $i, P: $i] : ((truth(isa(P, knight)) | (~truth(S))) | (~says(P, S))) <=> ![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))),
% 0.14/0.34 inference(quant_intro,[status(thm)],[8])).
% 0.14/0.34 tff(10,axiom,(![S: $i, P: $i] : ((truth(isa(P, knight)) | (~truth(S))) | (~says(P, S)))), file('/export/starexec/sandbox/benchmark/theBenchmark.p','knights_make_true_statements2')).
% 0.14/0.34 tff(11,plain,
% 0.14/0.34 (![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))),
% 0.14/0.34 inference(modus_ponens,[status(thm)],[10, 9])).
% 0.14/0.34 tff(12,plain,
% 0.14/0.34 (![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))),
% 0.14/0.34 inference(modus_ponens,[status(thm)],[11, 7])).
% 0.14/0.34 tff(13,plain,(
% 0.14/0.34 ![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))),
% 0.14/0.34 inference(skolemize,[status(sab)],[12])).
% 0.14/0.34 tff(14,plain,
% 0.14/0.34 (![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))),
% 0.14/0.34 inference(modus_ponens,[status(thm)],[13, 6])).
% 0.14/0.34 tff(15,plain,
% 0.14/0.34 (((~![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))) | (truth(isa(asked, knight)) | (~says(asked, or(isa(asked, knight), isa(other, knight)))) | (~truth(or(isa(asked, knight), isa(other, knight)))))) <=> ((~![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))) | truth(isa(asked, knight)) | (~says(asked, or(isa(asked, knight), isa(other, knight)))) | (~truth(or(isa(asked, knight), isa(other, knight)))))),
% 0.14/0.34 inference(rewrite,[status(thm)],[])).
% 0.14/0.34 tff(16,plain,
% 0.14/0.34 ((~![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))) | (truth(isa(asked, knight)) | (~says(asked, or(isa(asked, knight), isa(other, knight)))) | (~truth(or(isa(asked, knight), isa(other, knight)))))),
% 0.14/0.34 inference(quant_inst,[status(thm)],[])).
% 0.14/0.34 tff(17,plain,
% 0.14/0.34 ((~![S: $i, P: $i] : (truth(isa(P, knight)) | (~says(P, S)) | (~truth(S)))) | truth(isa(asked, knight)) | (~says(asked, or(isa(asked, knight), isa(other, knight)))) | (~truth(or(isa(asked, knight), isa(other, knight))))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[16, 15])).
% 0.14/0.35 tff(18,plain,
% 0.14/0.35 (truth(isa(asked, knight)) | (~truth(or(isa(asked, knight), isa(other, knight))))),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[17, 14, 4])).
% 0.14/0.35 tff(19,plain,
% 0.14/0.35 (~truth(or(isa(asked, knight), isa(other, knight)))),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[18, 1])).
% 0.14/0.35 tff(20,plain,
% 0.14/0.35 (^[B: $i, A: $i] : refl(((~truth(B)) | truth(or(A, B))) <=> ((~truth(B)) | truth(or(A, B))))),
% 0.14/0.35 inference(bind,[status(th)],[])).
% 0.14/0.35 tff(21,plain,
% 0.14/0.35 (![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B))) <=> ![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B)))),
% 0.14/0.35 inference(quant_intro,[status(thm)],[20])).
% 0.14/0.35 tff(22,plain,
% 0.14/0.35 (![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B))) <=> ![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B)))),
% 0.14/0.35 inference(rewrite,[status(thm)],[])).
% 0.14/0.35 tff(23,plain,
% 0.14/0.35 (^[B: $i, A: $i] : rewrite((truth(or(A, B)) | (~truth(B))) <=> ((~truth(B)) | truth(or(A, B))))),
% 0.14/0.35 inference(bind,[status(th)],[])).
% 0.14/0.35 tff(24,plain,
% 0.14/0.35 (![B: $i, A: $i] : (truth(or(A, B)) | (~truth(B))) <=> ![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B)))),
% 0.14/0.35 inference(quant_intro,[status(thm)],[23])).
% 0.14/0.35 tff(25,axiom,(![B: $i, A: $i] : (truth(or(A, B)) | (~truth(B)))), file('/export/starexec/sandbox/benchmark/theBenchmark.p','or3')).
% 0.14/0.35 tff(26,plain,
% 0.14/0.35 (![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B)))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[25, 24])).
% 0.14/0.35 tff(27,plain,
% 0.14/0.35 (![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B)))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[26, 22])).
% 0.14/0.35 tff(28,plain,(
% 0.14/0.35 ![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B)))),
% 0.14/0.35 inference(skolemize,[status(sab)],[27])).
% 0.14/0.35 tff(29,plain,
% 0.14/0.35 (![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B)))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[28, 21])).
% 0.14/0.35 tff(30,plain,
% 0.14/0.35 (((~![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B)))) | ((~truth(isa(other, knight))) | truth(or(isa(asked, knight), isa(other, knight))))) <=> ((~![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B)))) | (~truth(isa(other, knight))) | truth(or(isa(asked, knight), isa(other, knight))))),
% 0.14/0.35 inference(rewrite,[status(thm)],[])).
% 0.14/0.35 tff(31,plain,
% 0.14/0.35 ((~![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B)))) | ((~truth(isa(other, knight))) | truth(or(isa(asked, knight), isa(other, knight))))),
% 0.14/0.35 inference(quant_inst,[status(thm)],[])).
% 0.14/0.35 tff(32,plain,
% 0.14/0.35 ((~![B: $i, A: $i] : ((~truth(B)) | truth(or(A, B)))) | (~truth(isa(other, knight))) | truth(or(isa(asked, knight), isa(other, knight)))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[31, 30])).
% 0.14/0.35 tff(33,plain,
% 0.14/0.35 ((~truth(isa(other, knight))) | truth(or(isa(asked, knight), isa(other, knight)))),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[32, 29])).
% 0.14/0.35 tff(34,plain,
% 0.14/0.35 (~truth(isa(other, knight))),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[33, 19])).
% 0.14/0.35 tff(35,plain,
% 0.14/0.35 (^[P: $i] : refl((truth(isa(P, knave)) | truth(isa(P, knight))) <=> (truth(isa(P, knave)) | truth(isa(P, knight))))),
% 0.14/0.35 inference(bind,[status(th)],[])).
% 0.14/0.35 tff(36,plain,
% 0.14/0.35 (![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight))) <=> ![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))),
% 0.14/0.35 inference(quant_intro,[status(thm)],[35])).
% 0.14/0.35 tff(37,plain,
% 0.14/0.35 (![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight))) <=> ![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))),
% 0.14/0.35 inference(rewrite,[status(thm)],[])).
% 0.14/0.35 tff(38,plain,
% 0.14/0.35 (^[P: $i] : rewrite((truth(isa(P, knight)) | truth(isa(P, knave))) <=> (truth(isa(P, knave)) | truth(isa(P, knight))))),
% 0.14/0.35 inference(bind,[status(th)],[])).
% 0.14/0.35 tff(39,plain,
% 0.14/0.35 (![P: $i] : (truth(isa(P, knight)) | truth(isa(P, knave))) <=> ![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))),
% 0.14/0.35 inference(quant_intro,[status(thm)],[38])).
% 0.14/0.35 tff(40,axiom,(![P: $i] : (truth(isa(P, knight)) | truth(isa(P, knave)))), file('/export/starexec/sandbox/benchmark/theBenchmark.p','everyone_a_knight_or_knave')).
% 0.14/0.35 tff(41,plain,
% 0.14/0.35 (![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[40, 39])).
% 0.14/0.35 tff(42,plain,
% 0.14/0.35 (![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[41, 37])).
% 0.14/0.35 tff(43,plain,(
% 0.14/0.35 ![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))),
% 0.14/0.35 inference(skolemize,[status(sab)],[42])).
% 0.14/0.35 tff(44,plain,
% 0.14/0.35 (![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[43, 36])).
% 0.14/0.35 tff(45,plain,
% 0.14/0.35 (((~![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))) | (truth(isa(other, knave)) | truth(isa(other, knight)))) <=> ((~![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))) | truth(isa(other, knave)) | truth(isa(other, knight)))),
% 0.14/0.35 inference(rewrite,[status(thm)],[])).
% 0.14/0.35 tff(46,plain,
% 0.14/0.35 ((~![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))) | (truth(isa(other, knave)) | truth(isa(other, knight)))),
% 0.14/0.35 inference(quant_inst,[status(thm)],[])).
% 0.14/0.35 tff(47,plain,
% 0.14/0.35 ((~![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))) | truth(isa(other, knave)) | truth(isa(other, knight))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[46, 45])).
% 0.14/0.35 tff(48,plain,
% 0.14/0.35 (truth(isa(other, knave)) | truth(isa(other, knight))),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[47, 44])).
% 0.14/0.35 tff(49,plain,
% 0.14/0.35 (truth(isa(other, knave))),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[48, 34])).
% 0.14/0.35 tff(50,plain,
% 0.14/0.35 (((~![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))) | (truth(isa(asked, knave)) | truth(isa(asked, knight)))) <=> ((~![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))) | truth(isa(asked, knave)) | truth(isa(asked, knight)))),
% 0.14/0.35 inference(rewrite,[status(thm)],[])).
% 0.14/0.35 tff(51,plain,
% 0.14/0.35 ((~![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))) | (truth(isa(asked, knave)) | truth(isa(asked, knight)))),
% 0.14/0.35 inference(quant_inst,[status(thm)],[])).
% 0.14/0.35 tff(52,plain,
% 0.14/0.35 ((~![P: $i] : (truth(isa(P, knave)) | truth(isa(P, knight)))) | truth(isa(asked, knave)) | truth(isa(asked, knight))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[51, 50])).
% 0.14/0.35 tff(53,plain,
% 0.14/0.35 (truth(isa(asked, knave)) | truth(isa(asked, knight))),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[52, 44])).
% 0.14/0.35 tff(54,plain,
% 0.14/0.35 (truth(isa(asked, knave))),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[53, 1])).
% 0.14/0.35 tff(55,plain,
% 0.14/0.35 (^[Y: $i, X: $i] : refl(((~truth(isa(asked, X))) | (~truth(isa(other, Y)))) <=> ((~truth(isa(asked, X))) | (~truth(isa(other, Y)))))),
% 0.14/0.35 inference(bind,[status(th)],[])).
% 0.14/0.35 tff(56,plain,
% 0.14/0.35 (![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y)))) <=> ![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))),
% 0.14/0.35 inference(quant_intro,[status(thm)],[55])).
% 0.14/0.35 tff(57,plain,
% 0.14/0.35 (![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y)))) <=> ![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))),
% 0.14/0.35 inference(rewrite,[status(thm)],[])).
% 0.14/0.35 tff(58,axiom,(![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))), file('/export/starexec/sandbox/benchmark/theBenchmark.p','query')).
% 0.14/0.35 tff(59,plain,
% 0.14/0.35 (![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[58, 57])).
% 0.14/0.35 tff(60,plain,(
% 0.14/0.35 ![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))),
% 0.14/0.35 inference(skolemize,[status(sab)],[59])).
% 0.14/0.35 tff(61,plain,
% 0.14/0.35 (![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[60, 56])).
% 0.14/0.35 tff(62,plain,
% 0.14/0.35 (((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | ((~truth(isa(asked, knave))) | (~truth(isa(other, knave))))) <=> ((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | (~truth(isa(asked, knave))) | (~truth(isa(other, knave))))),
% 0.14/0.35 inference(rewrite,[status(thm)],[])).
% 0.14/0.35 tff(63,plain,
% 0.14/0.35 ((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | ((~truth(isa(asked, knave))) | (~truth(isa(other, knave))))),
% 0.14/0.35 inference(quant_inst,[status(thm)],[])).
% 0.14/0.35 tff(64,plain,
% 0.14/0.35 ((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | (~truth(isa(asked, knave))) | (~truth(isa(other, knave)))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[63, 62])).
% 0.14/0.35 tff(65,plain,
% 0.14/0.35 ($false),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[64, 61, 54, 49])).
% 0.14/0.35 tff(66,plain,(truth(isa(asked, knight))), inference(lemma,lemma(discharge,[]))).
% 0.14/0.35 tff(67,plain,
% 0.14/0.35 (((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | ((~truth(isa(asked, knight))) | (~truth(isa(other, knight))))) <=> ((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | (~truth(isa(asked, knight))) | (~truth(isa(other, knight))))),
% 0.14/0.35 inference(rewrite,[status(thm)],[])).
% 0.14/0.35 tff(68,plain,
% 0.14/0.35 ((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | ((~truth(isa(asked, knight))) | (~truth(isa(other, knight))))),
% 0.14/0.35 inference(quant_inst,[status(thm)],[])).
% 0.14/0.35 tff(69,plain,
% 0.14/0.35 ((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | (~truth(isa(asked, knight))) | (~truth(isa(other, knight)))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[68, 67])).
% 0.14/0.35 tff(70,plain,
% 0.14/0.35 ((~truth(isa(asked, knight))) | (~truth(isa(other, knight)))),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[69, 61])).
% 0.14/0.35 tff(71,plain,
% 0.14/0.35 (~truth(isa(other, knight))),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[70, 66])).
% 0.14/0.35 tff(72,plain,
% 0.14/0.35 (truth(isa(other, knave))),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[48, 71])).
% 0.14/0.35 tff(73,plain,
% 0.14/0.35 (((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | ((~truth(isa(asked, knight))) | (~truth(isa(other, knave))))) <=> ((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | (~truth(isa(asked, knight))) | (~truth(isa(other, knave))))),
% 0.14/0.35 inference(rewrite,[status(thm)],[])).
% 0.14/0.35 tff(74,plain,
% 0.14/0.35 ((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | ((~truth(isa(asked, knight))) | (~truth(isa(other, knave))))),
% 0.14/0.35 inference(quant_inst,[status(thm)],[])).
% 0.14/0.35 tff(75,plain,
% 0.14/0.35 ((~![Y: $i, X: $i] : ((~truth(isa(asked, X))) | (~truth(isa(other, Y))))) | (~truth(isa(asked, knight))) | (~truth(isa(other, knave)))),
% 0.14/0.35 inference(modus_ponens,[status(thm)],[74, 73])).
% 0.14/0.35 tff(76,plain,
% 0.14/0.35 ($false),
% 0.14/0.35 inference(unit_resolution,[status(thm)],[75, 61, 66, 72])).
% 0.14/0.35 % SZS output end Proof
%------------------------------------------------------------------------------