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
%------------------------------------------------------------------------------