TSTP Solution File: LCL818-1 by Z3---4.8.9.0

View Problem - Process Solution

%------------------------------------------------------------------------------
% File     : Z3---4.8.9.0
% Problem  : LCL818-1 : TPTP v8.1.0. Released v4.1.0.
% Transfm  : none
% Format   : tptp
% Command  : z3_tptp -proof -model -t:%d -file:%s

% Computer : n002.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 04:58:31 EDT 2022

% Result   : Unsatisfiable 0.19s 0.50s
% Output   : Proof 0.19s
% Verified : 
% SZS Type : Refutation
%            Derivation depth      :    6
%            Number of leaves      :   29
% Syntax   : Number of formulae    :   43 (  10 unt;  15 typ;   0 def)
%            Number of atoms       :  136 (   0 equ)
%            Maximal formula atoms :   12 (   4 avg)
%            Number of connectives :  188 (  88   ~;  84   |;   0   &)
%                                         (  16 <=>;   0  =>;   0  <=;   0 <~>)
%            Maximal formula depth :   12 (   6 avg)
%            Maximal term depth    :    3 (   1 avg)
%            Number of FOOLs       :    8 (   8 fml;   0 var)
%            Number of types       :    2 (   0 usr)
%            Number of type conns  :   13 (   4   >;   9   *;   0   +;   0  <<)
%            Number of predicates  :    6 (   5 usr;   1 prp; 0-3 aty)
%            Number of functors    :   14 (  14 usr;  11 con; 0-5 aty)
%            Number of variables   :  105 (  95   !;   0   ?; 105   :)

% Comments : 
%------------------------------------------------------------------------------
tff(c_Type_Otyping_type,type,
    c_Type_Otyping: ( $i * $i * $i ) > $o ).

tff(c_List_Ofoldr_type,type,
    c_List_Ofoldr: ( $i * $i * $i * $i * $i ) > $i ).

tff(tc_Type_Otype_type,type,
    tc_Type_Otype: $i ).

tff(v_T_H_____type,type,
    v_T_H____: $i ).

tff(v_Ts_____type,type,
    v_Ts____: $i ).

tff(c_Type_Otype_OFun_type,type,
    c_Type_Otype_OFun: $i ).

tff(hAPP_type,type,
    hAPP: ( $i * $i ) > $i ).

tff(c_Lambda_Osubst_type,type,
    c_Lambda_Osubst: ( $i * $i * $i ) > $i ).

tff(v_i_____type,type,
    v_i____: $i ).

tff(v_u_____type,type,
    v_u____: $i ).

tff(v_a_____type,type,
    v_a____: $i ).

tff(c_Lambda_OdB_OApp_type,type,
    c_Lambda_OdB_OApp: $i ).

tff(v_e_____type,type,
    v_e____: $i ).

tff(v_T_H_H_____type,type,
    v_T_H_H____: $i ).

tff(v_T_____type,type,
    v_T____: $i ).

tff(1,plain,
    ( ~ c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype))
  <=> ~ c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)) ),
    inference(rewrite,[status(thm)],]) ).

tff(2,axiom,
    ~ c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)),
    file('/export/starexec/sandbox2/benchmark/theBenchmark.p',cls_conjecture_0) ).

tff(3,plain,
    ~ c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)),
    inference(modus_ponens,[status(thm)],[2,1]) ).

tff(4,plain,
    ( c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____)
  <=> c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____) ),
    inference(rewrite,[status(thm)],]) ).

tff(5,axiom,
    c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____),
    file('/export/starexec/sandbox2/benchmark/theBenchmark.p',cls_CHAINED_0) ).

tff(6,plain,
    c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____),
    inference(modus_ponens,[status(thm)],[5,4]) ).

tff(7,plain,
    ^ [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
      refl(
        ( ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
          | ~ c_Type_Otyping(V_env,V_t,V_T)
          | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) )
      <=> ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
          | ~ c_Type_Otyping(V_env,V_t,V_T)
          | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) ) )),
    inference(bind,[status(th)],]) ).

tff(8,plain,
    ( ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
        ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
        | ~ c_Type_Otyping(V_env,V_t,V_T)
        | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) )
  <=> ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
        ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
        | ~ c_Type_Otyping(V_env,V_t,V_T)
        | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) ) ),
    inference(quant_intro,[status(thm)],[7]) ).

tff(9,plain,
    ( ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
        ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
        | ~ c_Type_Otyping(V_env,V_t,V_T)
        | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) )
  <=> ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
        ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
        | ~ c_Type_Otyping(V_env,V_t,V_T)
        | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) ) ),
    inference(rewrite,[status(thm)],]) ).

tff(10,plain,
    ^ [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
      trans(
        monotonicity(
          rewrite(
            ( ( c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U)
              | ~ c_Type_Otyping(V_env,V_t,V_T) )
          <=> ( ~ c_Type_Otyping(V_env,V_t,V_T)
              | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) ) )),
          ( ( c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U)
            | ~ c_Type_Otyping(V_env,V_t,V_T)
            | ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U)) )
        <=> ( ~ c_Type_Otyping(V_env,V_t,V_T)
            | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U)
            | ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U)) ) )),
        rewrite(
          ( ( ~ c_Type_Otyping(V_env,V_t,V_T)
            | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U)
            | ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U)) )
        <=> ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
            | ~ c_Type_Otyping(V_env,V_t,V_T)
            | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) ) )),
        ( ( c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U)
          | ~ c_Type_Otyping(V_env,V_t,V_T)
          | ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U)) )
      <=> ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
          | ~ c_Type_Otyping(V_env,V_t,V_T)
          | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) ) )),
    inference(bind,[status(th)],]) ).

tff(11,plain,
    ( ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
        ( c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U)
        | ~ c_Type_Otyping(V_env,V_t,V_T)
        | ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U)) )
  <=> ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
        ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
        | ~ c_Type_Otyping(V_env,V_t,V_T)
        | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) ) ),
    inference(quant_intro,[status(thm)],[10]) ).

tff(12,axiom,
    ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
      ( c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U)
      | ~ c_Type_Otyping(V_env,V_t,V_T)
      | ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U)) ),
    file('/export/starexec/sandbox2/benchmark/theBenchmark.p',cls_App_0) ).

tff(13,plain,
    ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
      ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
      | ~ c_Type_Otyping(V_env,V_t,V_T)
      | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) ),
    inference(modus_ponens,[status(thm)],[12,11]) ).

tff(14,plain,
    ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
      ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
      | ~ c_Type_Otyping(V_env,V_t,V_T)
      | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) ),
    inference(modus_ponens,[status(thm)],[13,9]) ).

tff(15,plain,
    ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
      ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
      | ~ c_Type_Otyping(V_env,V_t,V_T)
      | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) ),
    inference(skolemize,[status(sab)],[14]) ).

tff(16,plain,
    ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
      ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
      | ~ c_Type_Otyping(V_env,V_t,V_T)
      | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) ),
    inference(modus_ponens,[status(thm)],[15,8]) ).

tff(17,plain,
    ( c_Type_Otyping(v_e____,v_u____,v_T____)
  <=> c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype))) ),
    inference(rewrite,[status(thm)],]) ).

tff(18,plain,
    ( c_Type_Otyping(v_e____,v_u____,v_T____)
  <=> c_Type_Otyping(v_e____,v_u____,v_T____) ),
    inference(rewrite,[status(thm)],]) ).

tff(19,axiom,
    c_Type_Otyping(v_e____,v_u____,v_T____),
    file('/export/starexec/sandbox2/benchmark/theBenchmark.p',cls_uT_0) ).

tff(20,plain,
    c_Type_Otyping(v_e____,v_u____,v_T____),
    inference(modus_ponens,[status(thm)],[19,18]) ).

tff(21,plain,
    c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype))),
    inference(modus_ponens,[status(thm)],[20,17]) ).

tff(22,plain,
    ( ( ~ ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
            ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
            | ~ c_Type_Otyping(V_env,V_t,V_T)
            | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) )
      | c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype))
      | ~ c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)))
      | ~ c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____) )
  <=> ( ~ ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
            ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
            | ~ c_Type_Otyping(V_env,V_t,V_T)
            | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) )
      | c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype))
      | ~ c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)))
      | ~ c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____) ) ),
    inference(rewrite,[status(thm)],]) ).

tff(23,plain,
    ( ( ~ c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)))
      | ~ c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____)
      | c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)) )
  <=> ( c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype))
      | ~ c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)))
      | ~ c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____) ) ),
    inference(rewrite,[status(thm)],]) ).

tff(24,plain,
    ( ( ~ ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
            ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
            | ~ c_Type_Otyping(V_env,V_t,V_T)
            | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) )
      | ~ c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)))
      | ~ c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____)
      | c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)) )
  <=> ( ~ ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
            ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
            | ~ c_Type_Otyping(V_env,V_t,V_T)
            | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) )
      | c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype))
      | ~ c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)))
      | ~ c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____) ) ),
    inference(monotonicity,[status(thm)],[23]) ).

tff(25,plain,
    ( ( ~ ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
            ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
            | ~ c_Type_Otyping(V_env,V_t,V_T)
            | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) )
      | ~ c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)))
      | ~ c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____)
      | c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)) )
  <=> ( ~ ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
            ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
            | ~ c_Type_Otyping(V_env,V_t,V_T)
            | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) )
      | c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype))
      | ~ c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)))
      | ~ c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____) ) ),
    inference(transitivity,[status(thm)],[24,22]) ).

tff(26,plain,
    ( ~ ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
          ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
          | ~ c_Type_Otyping(V_env,V_t,V_T)
          | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) )
    | ~ c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)))
    | ~ c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____)
    | c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)) ),
    inference(quant_inst,[status(thm)],]) ).

tff(27,plain,
    ( ~ ! [V_U: $i,V_T: $i,V_t: $i,V_env: $i,V_s: $i] :
          ( ~ c_Type_Otyping(V_env,V_s,hAPP(hAPP(c_Type_Otype_OFun,V_T),V_U))
          | ~ c_Type_Otyping(V_env,V_t,V_T)
          | c_Type_Otyping(V_env,hAPP(hAPP(c_Lambda_OdB_OApp,V_s),V_t),V_U) )
    | c_Type_Otyping(v_e____,hAPP(hAPP(c_Lambda_OdB_OApp,v_u____),c_Lambda_Osubst(v_a____,v_u____,v_i____)),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype))
    | ~ c_Type_Otyping(v_e____,v_u____,hAPP(hAPP(c_Type_Otype_OFun,v_T_H_H____),c_List_Ofoldr(c_Type_Otype_OFun,v_Ts____,v_T_H____,tc_Type_Otype,tc_Type_Otype)))
    | ~ c_Type_Otyping(v_e____,c_Lambda_Osubst(v_a____,v_u____,v_i____),v_T_H_H____) ),
    inference(modus_ponens,[status(thm)],[26,25]) ).

tff(28,plain,
    $false,
    inference(unit_resolution,[status(thm)],[27,21,16,6,3]) ).

%------------------------------------------------------------------------------
%----ORIGINAL SYSTEM OUTPUT
% 0.10/0.11  % Problem  : LCL818-1 : TPTP v8.1.0. Released v4.1.0.
% 0.10/0.12  % Command  : z3_tptp -proof -model -t:%d -file:%s
% 0.12/0.33  % Computer : n002.cluster.edu
% 0.12/0.33  % Model    : x86_64 x86_64
% 0.12/0.33  % CPU      : Intel(R) Xeon(R) CPU E5-2620 v4 @ 2.10GHz
% 0.12/0.33  % Memory   : 8042.1875MB
% 0.12/0.33  % OS       : Linux 3.10.0-693.el7.x86_64
% 0.12/0.33  % CPULimit : 300
% 0.12/0.33  % WCLimit  : 300
% 0.12/0.33  % DateTime : Fri Sep  2 01:23:16 EDT 2022
% 0.12/0.33  % CPUTime  : 
% 0.12/0.33  Z3tptp [4.8.9.0] (c) 2006-20**. Microsoft Corp.
% 0.12/0.33  Usage: tptp [options] [-file:]file
% 0.12/0.33    -h, -?       prints this message.
% 0.12/0.33    -smt2        print SMT-LIB2 benchmark.
% 0.12/0.33    -m, -model   generate model.
% 0.12/0.33    -p, -proof   generate proof.
% 0.12/0.33    -c, -core    generate unsat core of named formulas.
% 0.12/0.33    -st, -statistics display statistics.
% 0.12/0.33    -t:timeout   set timeout (in second).
% 0.12/0.33    -smt2status  display status in smt2 format instead of SZS.
% 0.12/0.33    -check_status check the status produced by Z3 against annotation in benchmark.
% 0.12/0.33    -<param>:<value> configuration parameter and value.
% 0.12/0.33    -o:<output-file> file to place output in.
% 0.19/0.50  % SZS status Unsatisfiable
% 0.19/0.50  % SZS output start Proof
% See solution above
%------------------------------------------------------------------------------