TPTP Problem File: DAT136^1.p
View Solutions
- Solve Problem
%------------------------------------------------------------------------------
% File : DAT136^1 : TPTP v9.2.1. Released v7.0.0.
% Domain : Data Structures
% Problem : Coinductive list 4627
% Version : [Bla16] axioms : Especial.
% English :
% Refs : [Loc10] Lochbihler (2010), Coinductive
% : [RB15] Reynolds & Blanchette (2015), A Decision Procedure for
% : [Bla16] Blanchette (2016), Email to Geoff Sutcliffe
% Source : [Bla16]
% Names : coinductive_list__4627.p [Bla16]
% Status : Theorem
% Rating : 0.33 v9.1.0, 0.00 v8.1.0, 0.25 v7.5.0, 0.00 v7.1.0
% Syntax : Number of formulae : 354 ( 148 unt; 62 typ; 0 def)
% Number of atoms : 662 ( 301 equ; 0 cnn)
% Maximal formula atoms : 12 ( 2 avg)
% Number of connectives : 2885 ( 84 ~; 10 |; 27 &;2512 @)
% ( 0 <=>; 252 =>; 0 <=; 0 <~>)
% Maximal formula depth : 21 ( 6 avg)
% Number of types : 4 ( 3 usr)
% Number of type conns : 107 ( 107 >; 0 *; 0 +; 0 <<)
% Number of symbols : 60 ( 59 usr; 10 con; 0-4 aty)
% Number of variables : 756 ( 26 ^; 657 !; 30 ?; 756 :)
% ( 43 !>; 0 ?*; 0 @-; 0 @+)
% SPC : TH1_THM_EQU_NAR
% Comments : This file was generated by Isabelle (most likely Sledgehammer)
% 2016-07-13 15:08:08.226
%------------------------------------------------------------------------------
%----Could-be-implicit typings (7)
thf(ty_t_Coinductive__List__Mirabelle__kmikjhschf_Ollist,type,
coindu1593790203_llist: $tType > $tType ).
thf(ty_t_Extended__Nat_Oenat,type,
extended_enat: $tType ).
thf(ty_t_List_Olist,type,
list: $tType > $tType ).
thf(ty_t_Set_Oset,type,
set: $tType > $tType ).
thf(ty_t_Nat_Onat,type,
nat: $tType ).
thf(ty_t_itself,type,
itself: $tType > $tType ).
thf(ty_tf_a,type,
a: $tType ).
%----Explicit typings (55)
thf(sy_cl_HOL_Otype,type,
type:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Ozero,type,
zero:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Orderings_Oord,type,
ord:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Orderings_Oorder,type,
order:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Ogroup__add,type,
group_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Omonoid__add,type,
monoid_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Orderings_Olinorder,type,
linorder:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Osemigroup__add,type,
semigroup_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Rings_Ocomm__semiring__1,type,
comm_semiring_1:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Ocomm__monoid__add,type,
comm_monoid_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Oab__semigroup__add,type,
ab_semigroup_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Ocancel__semigroup__add,type,
cancel_semigroup_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Ocancel__comm__monoid__add,type,
cancel1352612707id_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Olinordered__ab__group__add,type,
linord219039673up_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Oordered__comm__monoid__add,type,
ordere216010020id_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Oordered__ab__semigroup__add,type,
ordere779506340up_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Ocanonically__ordered__monoid__add,type,
canoni770627133id_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Ostrict__ordered__comm__monoid__add,type,
strict797366125id_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Oordered__ab__semigroup__add__imp__le,type,
ordere236663937imp_le:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Oordered__cancel__ab__semigroup__add,type,
ordere223160158up_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Ostrict__ordered__ab__semigroup__add,type,
strict2144017051up_add:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Groups_Oordered__ab__semigroup__monoid__add__imp__le,type,
ordere516151231imp_le:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_cl_Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct,type,
semiri456707255roduct:
!>[A: $tType] : ( ( itself @ A ) > $o ) ).
thf(sy_c_Coinductive__List__Mirabelle__kmikjhschf_Ogen__llength,type,
coindu493225792length:
!>[A: $tType] : ( nat > ( coindu1593790203_llist @ A ) > extended_enat ) ).
thf(sy_c_Coinductive__List__Mirabelle__kmikjhschf_Olconcat,type,
coindu441856546concat:
!>[A: $tType] : ( ( coindu1593790203_llist @ ( coindu1593790203_llist @ A ) ) > ( coindu1593790203_llist @ A ) ) ).
thf(sy_c_Coinductive__List__Mirabelle__kmikjhschf_Oldropn,type,
coindu531130065ldropn:
!>[A: $tType] : ( nat > ( coindu1593790203_llist @ A ) > ( coindu1593790203_llist @ A ) ) ).
thf(sy_c_Coinductive__List__Mirabelle__kmikjhschf_Olfinite,type,
coindu1213758845finite:
!>[A: $tType] : ( ( coindu1593790203_llist @ A ) > $o ) ).
thf(sy_c_Coinductive__List__Mirabelle__kmikjhschf_Ollength,type,
coindu1018505716length:
!>[A: $tType] : ( ( coindu1593790203_llist @ A ) > extended_enat ) ).
thf(sy_c_Coinductive__List__Mirabelle__kmikjhschf_Ollist_OLCons,type,
coindu1121789889_LCons:
!>[A: $tType] : ( A > ( coindu1593790203_llist @ A ) > ( coindu1593790203_llist @ A ) ) ).
thf(sy_c_Coinductive__List__Mirabelle__kmikjhschf_Ollist_OLNil,type,
coindu1598213697e_LNil:
!>[A: $tType] : ( coindu1593790203_llist @ A ) ).
thf(sy_c_Coinductive__List__Mirabelle__kmikjhschf_Ollist_Olnull,type,
coindu335574135_lnull:
!>[A: $tType] : ( ( coindu1593790203_llist @ A ) > $o ) ).
thf(sy_c_Coinductive__List__Mirabelle__kmikjhschf_Ollist__of,type,
coindu1079202755ist_of:
!>[A: $tType] : ( ( list @ A ) > ( coindu1593790203_llist @ A ) ) ).
thf(sy_c_Coinductive__List__Mirabelle__kmikjhschf_Olnth,type,
coindu749330388e_lnth:
!>[A: $tType] : ( ( coindu1593790203_llist @ A ) > nat > A ) ).
thf(sy_c_Extended__Nat_Oenat,type,
extended_enat2: nat > extended_enat ).
thf(sy_c_Extended__Nat_Oenat_Osize__enat,type,
extended_size_enat: extended_enat > nat ).
thf(sy_c_Groups_Oplus__class_Oplus,type,
plus_plus:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Groups_Ozero__class_Ozero,type,
zero_zero:
!>[A: $tType] : A ).
thf(sy_c_Groups__Big_Ocomm__monoid__add__class_Osetsum,type,
groups15040474setsum:
!>[B: $tType,A: $tType] : ( ( B > A ) > ( set @ B ) > A ) ).
thf(sy_c_Nat_OSuc,type,
suc: nat > nat ).
thf(sy_c_Nat_Osize__class_Osize,type,
size_size:
!>[A: $tType] : ( A > nat ) ).
thf(sy_c_Orderings_Oord__class_Oless,type,
ord_less:
!>[A: $tType] : ( A > A > $o ) ).
thf(sy_c_Pure_Otype,type,
type2:
!>[A: $tType] : ( itself @ A ) ).
thf(sy_c_Set_OCollect,type,
collect:
!>[A: $tType] : ( ( A > $o ) > ( set @ A ) ) ).
thf(sy_c_Set__Interval_Oord__class_OlessThan,type,
set_ord_lessThan:
!>[A: $tType] : ( A > ( set @ A ) ) ).
thf(sy_c_member,type,
member:
!>[A: $tType] : ( A > ( set @ A ) > $o ) ).
thf(sy_v_N____,type,
n: nat ).
thf(sy_v_m____,type,
m: nat ).
thf(sy_v_n,type,
n2: nat ).
thf(sy_v_n_H____,type,
n3: nat ).
thf(sy_v_na____,type,
na: nat ).
thf(sy_v_x____,type,
x: a ).
thf(sy_v_xs____,type,
xs: coindu1593790203_llist @ a ).
thf(sy_v_xss,type,
xss: coindu1593790203_llist @ ( coindu1593790203_llist @ a ) ).
thf(sy_v_xss_H____,type,
xss2: list @ ( coindu1593790203_llist @ a ) ).
thf(sy_v_xssa____,type,
xssa: coindu1593790203_llist @ ( coindu1593790203_llist @ a ) ).
%----Relevant facts (250)
thf(fact_0__092_060open_062enat_A_Ilength_Axss_H_J_A_060_Allength_Axss_092_060close_062,axiom,
ord_less @ extended_enat @ ( extended_enat2 @ ( size_size @ ( list @ ( coindu1593790203_llist @ a ) ) @ xss2 ) ) @ ( coindu1018505716length @ ( coindu1593790203_llist @ a ) @ xssa ) ).
% \<open>enat (length xss') < llength xss\<close>
thf(fact_1_assms,axiom,
ord_less @ extended_enat @ ( extended_enat2 @ n2 ) @ ( coindu1018505716length @ a @ ( coindu441856546concat @ a @ xss ) ) ).
% assms
thf(fact_2__092_060open_062enat_A_ISuc_An_H_J_A_060_Allength_A_Ilnth_Axss_A_Ilength_Axss_H_J_J_092_060close_062,axiom,
ord_less @ extended_enat @ ( extended_enat2 @ ( suc @ n3 ) ) @ ( coindu1018505716length @ a @ ( coindu749330388e_lnth @ ( coindu1593790203_llist @ a ) @ xssa @ ( size_size @ ( list @ ( coindu1593790203_llist @ a ) ) @ xss2 ) ) ) ).
% \<open>enat (Suc n') < llength (lnth xss (length xss'))\<close>
thf(fact_3_Suc_Oprems,axiom,
ord_less @ extended_enat @ ( extended_enat2 @ ( suc @ na ) ) @ ( coindu1018505716length @ a @ ( coindu441856546concat @ a @ xssa ) ) ).
% Suc.prems
thf(fact_4__092_060open_062lnth_A_Ilconcat_Axss_J_A_ISuc_An_J_A_061_Alnth_A_Ilnth_Axss_A_Ilength_Axss_H_J_J_A_ISuc_An_H_J_092_060close_062,axiom,
( ( coindu749330388e_lnth @ a @ ( coindu441856546concat @ a @ xssa ) @ ( suc @ na ) )
= ( coindu749330388e_lnth @ a @ ( coindu749330388e_lnth @ ( coindu1593790203_llist @ a ) @ xssa @ ( size_size @ ( list @ ( coindu1593790203_llist @ a ) ) @ xss2 ) ) @ ( suc @ n3 ) ) ) ).
% \<open>lnth (lconcat xss) (Suc n) = lnth (lnth xss (length xss')) (Suc n')\<close>
thf(fact_5__092_060open_062enat_A_ISuc_An_J_A_061_A_I_092_060Sum_062i_060length_Axss_H_O_Allength_A_Ilnth_Axss_Ai_J_J_A_L_Aenat_A_ISuc_An_H_J_092_060close_062,axiom,
( ( extended_enat2 @ ( suc @ na ) )
= ( plus_plus @ extended_enat
@ ( groups15040474setsum @ nat @ extended_enat
@ ^ [I: nat] : ( coindu1018505716length @ a @ ( coindu749330388e_lnth @ ( coindu1593790203_llist @ a ) @ xssa @ I ) )
@ ( set_ord_lessThan @ nat @ ( size_size @ ( list @ ( coindu1593790203_llist @ a ) ) @ xss2 ) ) )
@ ( extended_enat2 @ ( suc @ n3 ) ) ) ) ).
% \<open>enat (Suc n) = (\<Sum>i<length xss'. llength (lnth xss i)) + enat (Suc n')\<close>
thf(fact_6_Suc_Ohyps,axiom,
! [Xss: coindu1593790203_llist @ ( coindu1593790203_llist @ a )] :
( ( ord_less @ extended_enat @ ( extended_enat2 @ na ) @ ( coindu1018505716length @ a @ ( coindu441856546concat @ a @ Xss ) ) )
=> ? [M: nat,N: nat] :
( ( ( coindu749330388e_lnth @ a @ ( coindu441856546concat @ a @ Xss ) @ na )
= ( coindu749330388e_lnth @ a @ ( coindu749330388e_lnth @ ( coindu1593790203_llist @ a ) @ Xss @ M ) @ N ) )
& ( ord_less @ extended_enat @ ( extended_enat2 @ N ) @ ( coindu1018505716length @ a @ ( coindu749330388e_lnth @ ( coindu1593790203_llist @ a ) @ Xss @ M ) ) )
& ( ord_less @ extended_enat @ ( extended_enat2 @ M ) @ ( coindu1018505716length @ ( coindu1593790203_llist @ a ) @ Xss ) )
& ( ( extended_enat2 @ na )
= ( plus_plus @ extended_enat
@ ( groups15040474setsum @ nat @ extended_enat
@ ^ [I: nat] : ( coindu1018505716length @ a @ ( coindu749330388e_lnth @ ( coindu1593790203_llist @ a ) @ Xss @ I ) )
@ ( set_ord_lessThan @ nat @ M ) )
@ ( extended_enat2 @ N ) ) ) ) ) ).
% Suc.hyps
thf(fact_7_setsum__lessThan__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [F: nat > A,N2: nat] :
( ( groups15040474setsum @ nat @ A @ F @ ( set_ord_lessThan @ nat @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( groups15040474setsum @ nat @ A @ F @ ( set_ord_lessThan @ nat @ N2 ) ) @ ( F @ N2 ) ) ) ) ).
% setsum_lessThan_Suc
thf(fact_8_enat__add__mono,axiom,
! [X: nat,Y: extended_enat,Z: extended_enat] :
( ( ord_less @ extended_enat @ ( plus_plus @ extended_enat @ ( extended_enat2 @ X ) @ Y ) @ ( plus_plus @ extended_enat @ ( extended_enat2 @ X ) @ Z ) )
= ( ord_less @ extended_enat @ Y @ Z ) ) ).
% enat_add_mono
thf(fact_9_enat__add1__eq,axiom,
! [X: nat,Y: extended_enat,Z: extended_enat] :
( ( ( plus_plus @ extended_enat @ ( extended_enat2 @ X ) @ Y )
= ( plus_plus @ extended_enat @ ( extended_enat2 @ X ) @ Z ) )
= ( Y = Z ) ) ).
% enat_add1_eq
thf(fact_10_enat__add2__eq,axiom,
! [Y: extended_enat,X: nat,Z: extended_enat] :
( ( ( plus_plus @ extended_enat @ Y @ ( extended_enat2 @ X ) )
= ( plus_plus @ extended_enat @ Z @ ( extended_enat2 @ X ) ) )
= ( Y = Z ) ) ).
% enat_add2_eq
thf(fact_11_lessThan__iff,axiom,
! [A: $tType] :
( ( ord @ A @ ( type2 @ A ) )
=> ! [I2: A,K: A] :
( ( member @ A @ I2 @ ( set_ord_lessThan @ A @ K ) )
= ( ord_less @ A @ I2 @ K ) ) ) ).
% lessThan_iff
thf(fact_12_add__less__cancel__left,axiom,
! [A: $tType] :
( ( ordere236663937imp_le @ A @ ( type2 @ A ) )
=> ! [C: A,A2: A,B2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ C @ A2 ) @ ( plus_plus @ A @ C @ B2 ) )
= ( ord_less @ A @ A2 @ B2 ) ) ) ).
% add_less_cancel_left
thf(fact_13_add__less__cancel__right,axiom,
! [A: $tType] :
( ( ordere236663937imp_le @ A @ ( type2 @ A ) )
=> ! [A2: A,C: A,B2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ A2 @ C ) @ ( plus_plus @ A @ B2 @ C ) )
= ( ord_less @ A @ A2 @ B2 ) ) ) ).
% add_less_cancel_right
thf(fact_14__092_060open_062_I_092_060Sum_062i_060length_Axss_H_O_Allength_A_Ilnth_Axss_Ai_J_J_A_061_A0_092_060close_062,axiom,
( ( groups15040474setsum @ nat @ extended_enat
@ ^ [I: nat] : ( coindu1018505716length @ a @ ( coindu749330388e_lnth @ ( coindu1593790203_llist @ a ) @ xssa @ I ) )
@ ( set_ord_lessThan @ nat @ ( size_size @ ( list @ ( coindu1593790203_llist @ a ) ) @ xss2 ) ) )
= ( zero_zero @ extended_enat ) ) ).
% \<open>(\<Sum>i<length xss'. llength (lnth xss i)) = 0\<close>
thf(fact_15_enat_Oinject,axiom,
! [Nat: nat,Nat2: nat] :
( ( ( extended_enat2 @ Nat )
= ( extended_enat2 @ Nat2 ) )
= ( Nat = Nat2 ) ) ).
% enat.inject
thf(fact_16_lessThan__eq__iff,axiom,
! [A: $tType] :
( ( linorder @ A @ ( type2 @ A ) )
=> ! [X: A,Y: A] :
( ( ( set_ord_lessThan @ A @ X )
= ( set_ord_lessThan @ A @ Y ) )
= ( X = Y ) ) ) ).
% lessThan_eq_iff
thf(fact_17_nat_Oinject,axiom,
! [X2: nat,Y2: nat] :
( ( ( suc @ X2 )
= ( suc @ Y2 ) )
= ( X2 = Y2 ) ) ).
% nat.inject
thf(fact_18_n,axiom,
( na
= ( plus_plus @ nat @ n @ n3 ) ) ).
% n
thf(fact_19_add__right__cancel,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A @ ( type2 @ A ) )
=> ! [B2: A,A2: A,C: A] :
( ( ( plus_plus @ A @ B2 @ A2 )
= ( plus_plus @ A @ C @ A2 ) )
= ( B2 = C ) ) ) ).
% add_right_cancel
thf(fact_20_add__left__cancel,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A] :
( ( ( plus_plus @ A @ A2 @ B2 )
= ( plus_plus @ A @ A2 @ C ) )
= ( B2 = C ) ) ) ).
% add_left_cancel
thf(fact_21_add__Suc__right,axiom,
! [M2: nat,N2: nat] :
( ( plus_plus @ nat @ M2 @ ( suc @ N2 ) )
= ( suc @ ( plus_plus @ nat @ M2 @ N2 ) ) ) ).
% add_Suc_right
thf(fact_22_Suc__less__eq,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ ( suc @ M2 ) @ ( suc @ N2 ) )
= ( ord_less @ nat @ M2 @ N2 ) ) ).
% Suc_less_eq
thf(fact_23_Suc__mono,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ M2 @ N2 )
=> ( ord_less @ nat @ ( suc @ M2 ) @ ( suc @ N2 ) ) ) ).
% Suc_mono
thf(fact_24_lessI,axiom,
! [N2: nat] : ( ord_less @ nat @ N2 @ ( suc @ N2 ) ) ).
% lessI
thf(fact_25_old_Onat_Oinject,axiom,
! [Nat: nat,Nat2: nat] :
( ( ( suc @ Nat )
= ( suc @ Nat2 ) )
= ( Nat = Nat2 ) ) ).
% old.nat.inject
thf(fact_26_not__gr__zero,axiom,
! [A: $tType] :
( ( canoni770627133id_add @ A @ ( type2 @ A ) )
=> ! [N2: A] :
( ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ N2 ) )
= ( N2
= ( zero_zero @ A ) ) ) ) ).
% not_gr_zero
thf(fact_27_add__cancel__right__right,axiom,
! [A: $tType] :
( ( cancel1352612707id_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A] :
( ( A2
= ( plus_plus @ A @ A2 @ B2 ) )
= ( B2
= ( zero_zero @ A ) ) ) ) ).
% add_cancel_right_right
thf(fact_28_add__cancel__right__left,axiom,
! [A: $tType] :
( ( cancel1352612707id_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A] :
( ( A2
= ( plus_plus @ A @ B2 @ A2 ) )
= ( B2
= ( zero_zero @ A ) ) ) ) ).
% add_cancel_right_left
thf(fact_29_add__cancel__left__right,axiom,
! [A: $tType] :
( ( cancel1352612707id_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A] :
( ( ( plus_plus @ A @ A2 @ B2 )
= A2 )
= ( B2
= ( zero_zero @ A ) ) ) ) ).
% add_cancel_left_right
thf(fact_30_add__cancel__left__left,axiom,
! [A: $tType] :
( ( cancel1352612707id_add @ A @ ( type2 @ A ) )
=> ! [B2: A,A2: A] :
( ( ( plus_plus @ A @ B2 @ A2 )
= A2 )
= ( B2
= ( zero_zero @ A ) ) ) ) ).
% add_cancel_left_left
thf(fact_31_double__zero__sym,axiom,
! [A: $tType] :
( ( linord219039673up_add @ A @ ( type2 @ A ) )
=> ! [A2: A] :
( ( ( zero_zero @ A )
= ( plus_plus @ A @ A2 @ A2 ) )
= ( A2
= ( zero_zero @ A ) ) ) ) ).
% double_zero_sym
thf(fact_32_double__zero,axiom,
! [A: $tType] :
( ( linord219039673up_add @ A @ ( type2 @ A ) )
=> ! [A2: A] :
( ( ( plus_plus @ A @ A2 @ A2 )
= ( zero_zero @ A ) )
= ( A2
= ( zero_zero @ A ) ) ) ) ).
% double_zero
thf(fact_33_add_Oright__neutral,axiom,
! [A: $tType] :
( ( monoid_add @ A @ ( type2 @ A ) )
=> ! [A2: A] :
( ( plus_plus @ A @ A2 @ ( zero_zero @ A ) )
= A2 ) ) ).
% add.right_neutral
thf(fact_34_add_Oleft__neutral,axiom,
! [A: $tType] :
( ( monoid_add @ A @ ( type2 @ A ) )
=> ! [A2: A] :
( ( plus_plus @ A @ ( zero_zero @ A ) @ A2 )
= A2 ) ) ).
% add.left_neutral
thf(fact_35_enat__ord__simps_I2_J,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ extended_enat @ ( extended_enat2 @ M2 ) @ ( extended_enat2 @ N2 ) )
= ( ord_less @ nat @ M2 @ N2 ) ) ).
% enat_ord_simps(2)
thf(fact_36_i0__less,axiom,
! [N2: extended_enat] :
( ( ord_less @ extended_enat @ ( zero_zero @ extended_enat ) @ N2 )
= ( N2
!= ( zero_zero @ extended_enat ) ) ) ).
% i0_less
thf(fact_37_plus__enat__simps_I1_J,axiom,
! [M2: nat,N2: nat] :
( ( plus_plus @ extended_enat @ ( extended_enat2 @ M2 ) @ ( extended_enat2 @ N2 ) )
= ( extended_enat2 @ ( plus_plus @ nat @ M2 @ N2 ) ) ) ).
% plus_enat_simps(1)
thf(fact_38_zero__less__double__add__iff__zero__less__single__add,axiom,
! [A: $tType] :
( ( linord219039673up_add @ A @ ( type2 @ A ) )
=> ! [A2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ A2 @ A2 ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ A2 ) ) ) ).
% zero_less_double_add_iff_zero_less_single_add
thf(fact_39_double__add__less__zero__iff__single__add__less__zero,axiom,
! [A: $tType] :
( ( linord219039673up_add @ A @ ( type2 @ A ) )
=> ! [A2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ A2 @ A2 ) @ ( zero_zero @ A ) )
= ( ord_less @ A @ A2 @ ( zero_zero @ A ) ) ) ) ).
% double_add_less_zero_iff_single_add_less_zero
thf(fact_40_less__add__same__cancel2,axiom,
! [A: $tType] :
( ( ordere516151231imp_le @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A] :
( ( ord_less @ A @ A2 @ ( plus_plus @ A @ B2 @ A2 ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ B2 ) ) ) ).
% less_add_same_cancel2
thf(fact_41_less__add__same__cancel1,axiom,
! [A: $tType] :
( ( ordere516151231imp_le @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A] :
( ( ord_less @ A @ A2 @ ( plus_plus @ A @ A2 @ B2 ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ B2 ) ) ) ).
% less_add_same_cancel1
thf(fact_42_add__less__same__cancel2,axiom,
! [A: $tType] :
( ( ordere516151231imp_le @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ A2 @ B2 ) @ B2 )
= ( ord_less @ A @ A2 @ ( zero_zero @ A ) ) ) ) ).
% add_less_same_cancel2
thf(fact_43_mem__Collect__eq,axiom,
! [A: $tType,A2: A,P: A > $o] :
( ( member @ A @ A2 @ ( collect @ A @ P ) )
= ( P @ A2 ) ) ).
% mem_Collect_eq
thf(fact_44_Collect__mem__eq,axiom,
! [A: $tType,A3: set @ A] :
( ( collect @ A
@ ^ [X3: A] : ( member @ A @ X3 @ A3 ) )
= A3 ) ).
% Collect_mem_eq
thf(fact_45_Collect__cong,axiom,
! [A: $tType,P: A > $o,Q: A > $o] :
( ! [X4: A] :
( ( P @ X4 )
= ( Q @ X4 ) )
=> ( ( collect @ A @ P )
= ( collect @ A @ Q ) ) ) ).
% Collect_cong
thf(fact_46_ext,axiom,
! [B: $tType,A: $tType,F: A > B,G: A > B] :
( ! [X4: A] :
( ( F @ X4 )
= ( G @ X4 ) )
=> ( F = G ) ) ).
% ext
thf(fact_47_add__less__same__cancel1,axiom,
! [A: $tType] :
( ( ordere516151231imp_le @ A @ ( type2 @ A ) )
=> ! [B2: A,A2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ B2 @ A2 ) @ B2 )
= ( ord_less @ A @ A2 @ ( zero_zero @ A ) ) ) ) ).
% add_less_same_cancel1
thf(fact_48_less__add__Suc1,axiom,
! [I2: nat,M2: nat] : ( ord_less @ nat @ I2 @ ( suc @ ( plus_plus @ nat @ I2 @ M2 ) ) ) ).
% less_add_Suc1
thf(fact_49_less__add__Suc2,axiom,
! [I2: nat,M2: nat] : ( ord_less @ nat @ I2 @ ( suc @ ( plus_plus @ nat @ M2 @ I2 ) ) ) ).
% less_add_Suc2
thf(fact_50_zero__reorient,axiom,
! [A: $tType] :
( ( zero @ A @ ( type2 @ A ) )
=> ! [X: A] :
( ( ( zero_zero @ A )
= X )
= ( X
= ( zero_zero @ A ) ) ) ) ).
% zero_reorient
thf(fact_51_less__iff__Suc__add,axiom,
( ( ord_less @ nat )
= ( ^ [M3: nat,N3: nat] :
? [K2: nat] :
( N3
= ( suc @ ( plus_plus @ nat @ M3 @ K2 ) ) ) ) ) ).
% less_iff_Suc_add
thf(fact_52_less__imp__Suc__add,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ M2 @ N2 )
=> ? [K3: nat] :
( N2
= ( suc @ ( plus_plus @ nat @ M2 @ K3 ) ) ) ) ).
% less_imp_Suc_add
thf(fact_53_add__Suc,axiom,
! [M2: nat,N2: nat] :
( ( plus_plus @ nat @ ( suc @ M2 ) @ N2 )
= ( suc @ ( plus_plus @ nat @ M2 @ N2 ) ) ) ).
% add_Suc
thf(fact_54_add__Suc__shift,axiom,
! [M2: nat,N2: nat] :
( ( plus_plus @ nat @ ( suc @ M2 ) @ N2 )
= ( plus_plus @ nat @ M2 @ ( suc @ N2 ) ) ) ).
% add_Suc_shift
thf(fact_55_zero__less__iff__neq__zero,axiom,
! [A: $tType] :
( ( canoni770627133id_add @ A @ ( type2 @ A ) )
=> ! [N2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ N2 )
= ( N2
!= ( zero_zero @ A ) ) ) ) ).
% zero_less_iff_neq_zero
thf(fact_56_gr__implies__not__zero,axiom,
! [A: $tType] :
( ( canoni770627133id_add @ A @ ( type2 @ A ) )
=> ! [M2: A,N2: A] :
( ( ord_less @ A @ M2 @ N2 )
=> ( N2
!= ( zero_zero @ A ) ) ) ) ).
% gr_implies_not_zero
thf(fact_57_not__less__zero,axiom,
! [A: $tType] :
( ( canoni770627133id_add @ A @ ( type2 @ A ) )
=> ! [N2: A] :
~ ( ord_less @ A @ N2 @ ( zero_zero @ A ) ) ) ).
% not_less_zero
thf(fact_58_gr__zeroI,axiom,
! [A: $tType] :
( ( canoni770627133id_add @ A @ ( type2 @ A ) )
=> ! [N2: A] :
( ( N2
!= ( zero_zero @ A ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ N2 ) ) ) ).
% gr_zeroI
thf(fact_59_not__less__less__Suc__eq,axiom,
! [N2: nat,M2: nat] :
( ~ ( ord_less @ nat @ N2 @ M2 )
=> ( ( ord_less @ nat @ N2 @ ( suc @ M2 ) )
= ( N2 = M2 ) ) ) ).
% not_less_less_Suc_eq
thf(fact_60_strict__inc__induct,axiom,
! [I2: nat,J: nat,P: nat > $o] :
( ( ord_less @ nat @ I2 @ J )
=> ( ! [I3: nat] :
( ( J
= ( suc @ I3 ) )
=> ( P @ I3 ) )
=> ( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ J )
=> ( ( P @ ( suc @ I3 ) )
=> ( P @ I3 ) ) )
=> ( P @ I2 ) ) ) ) ).
% strict_inc_induct
thf(fact_61_less__Suc__induct,axiom,
! [I2: nat,J: nat,P: nat > nat > $o] :
( ( ord_less @ nat @ I2 @ J )
=> ( ! [I3: nat] : ( P @ I3 @ ( suc @ I3 ) )
=> ( ! [I3: nat,J2: nat,K3: nat] :
( ( ord_less @ nat @ I3 @ J2 )
=> ( ( ord_less @ nat @ J2 @ K3 )
=> ( ( P @ I3 @ J2 )
=> ( ( P @ J2 @ K3 )
=> ( P @ I3 @ K3 ) ) ) ) )
=> ( P @ I2 @ J ) ) ) ) ).
% less_Suc_induct
thf(fact_62_less__trans__Suc,axiom,
! [I2: nat,J: nat,K: nat] :
( ( ord_less @ nat @ I2 @ J )
=> ( ( ord_less @ nat @ J @ K )
=> ( ord_less @ nat @ ( suc @ I2 ) @ K ) ) ) ).
% less_trans_Suc
thf(fact_63_Suc__less__SucD,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ ( suc @ M2 ) @ ( suc @ N2 ) )
=> ( ord_less @ nat @ M2 @ N2 ) ) ).
% Suc_less_SucD
thf(fact_64_less__antisym,axiom,
! [N2: nat,M2: nat] :
( ~ ( ord_less @ nat @ N2 @ M2 )
=> ( ( ord_less @ nat @ N2 @ ( suc @ M2 ) )
=> ( M2 = N2 ) ) ) ).
% less_antisym
thf(fact_65_Suc__less__eq2,axiom,
! [N2: nat,M2: nat] :
( ( ord_less @ nat @ ( suc @ N2 ) @ M2 )
= ( ? [M4: nat] :
( ( M2
= ( suc @ M4 ) )
& ( ord_less @ nat @ N2 @ M4 ) ) ) ) ).
% Suc_less_eq2
thf(fact_66_not__less__eq,axiom,
! [M2: nat,N2: nat] :
( ( ~ ( ord_less @ nat @ M2 @ N2 ) )
= ( ord_less @ nat @ N2 @ ( suc @ M2 ) ) ) ).
% not_less_eq
thf(fact_67_less__Suc__eq,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ M2 @ ( suc @ N2 ) )
= ( ( ord_less @ nat @ M2 @ N2 )
| ( M2 = N2 ) ) ) ).
% less_Suc_eq
thf(fact_68_less__SucI,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ M2 @ N2 )
=> ( ord_less @ nat @ M2 @ ( suc @ N2 ) ) ) ).
% less_SucI
thf(fact_69_less__SucE,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ M2 @ ( suc @ N2 ) )
=> ( ~ ( ord_less @ nat @ M2 @ N2 )
=> ( M2 = N2 ) ) ) ).
% less_SucE
thf(fact_70_Suc__lessI,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ M2 @ N2 )
=> ( ( ( suc @ M2 )
!= N2 )
=> ( ord_less @ nat @ ( suc @ M2 ) @ N2 ) ) ) ).
% Suc_lessI
thf(fact_71_Suc__lessE,axiom,
! [I2: nat,K: nat] :
( ( ord_less @ nat @ ( suc @ I2 ) @ K )
=> ~ ! [J2: nat] :
( ( ord_less @ nat @ I2 @ J2 )
=> ( K
!= ( suc @ J2 ) ) ) ) ).
% Suc_lessE
thf(fact_72_Suc__lessD,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ ( suc @ M2 ) @ N2 )
=> ( ord_less @ nat @ M2 @ N2 ) ) ).
% Suc_lessD
thf(fact_73_lessE,axiom,
! [I2: nat,K: nat] :
( ( ord_less @ nat @ I2 @ K )
=> ( ( K
!= ( suc @ I2 ) )
=> ~ ! [J2: nat] :
( ( ord_less @ nat @ I2 @ J2 )
=> ( K
!= ( suc @ J2 ) ) ) ) ) ).
% lessE
thf(fact_74_add__eq__0__iff__both__eq__0,axiom,
! [A: $tType] :
( ( canoni770627133id_add @ A @ ( type2 @ A ) )
=> ! [X: A,Y: A] :
( ( ( plus_plus @ A @ X @ Y )
= ( zero_zero @ A ) )
= ( ( X
= ( zero_zero @ A ) )
& ( Y
= ( zero_zero @ A ) ) ) ) ) ).
% add_eq_0_iff_both_eq_0
thf(fact_75_add_Ogroup__left__neutral,axiom,
! [A: $tType] :
( ( group_add @ A @ ( type2 @ A ) )
=> ! [A2: A] :
( ( plus_plus @ A @ ( zero_zero @ A ) @ A2 )
= A2 ) ) ).
% add.group_left_neutral
thf(fact_76_add_Ocomm__neutral,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [A2: A] :
( ( plus_plus @ A @ A2 @ ( zero_zero @ A ) )
= A2 ) ) ).
% add.comm_neutral
thf(fact_77_comm__monoid__add__class_Oadd__0,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [A2: A] :
( ( plus_plus @ A @ ( zero_zero @ A ) @ A2 )
= A2 ) ) ).
% comm_monoid_add_class.add_0
thf(fact_78_not__iless0,axiom,
! [N2: extended_enat] :
~ ( ord_less @ extended_enat @ N2 @ ( zero_zero @ extended_enat ) ) ).
% not_iless0
thf(fact_79_plus__enat__eq__0__conv,axiom,
! [M2: extended_enat,N2: extended_enat] :
( ( ( plus_plus @ extended_enat @ M2 @ N2 )
= ( zero_zero @ extended_enat ) )
= ( ( M2
= ( zero_zero @ extended_enat ) )
& ( N2
= ( zero_zero @ extended_enat ) ) ) ) ).
% plus_enat_eq_0_conv
thf(fact_80_pos__add__strict,axiom,
! [A: $tType] :
( ( strict797366125id_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A2 )
=> ( ( ord_less @ A @ B2 @ C )
=> ( ord_less @ A @ B2 @ ( plus_plus @ A @ A2 @ C ) ) ) ) ) ).
% pos_add_strict
thf(fact_81_add__pos__pos,axiom,
! [A: $tType] :
( ( ordere216010020id_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ A2 @ B2 ) ) ) ) ) ).
% add_pos_pos
thf(fact_82_add__neg__neg,axiom,
! [A: $tType] :
( ( ordere216010020id_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A] :
( ( ord_less @ A @ A2 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( plus_plus @ A @ A2 @ B2 ) @ ( zero_zero @ A ) ) ) ) ) ).
% add_neg_neg
thf(fact_83_less__enatE,axiom,
! [N2: extended_enat,M2: nat] :
( ( ord_less @ extended_enat @ N2 @ ( extended_enat2 @ M2 ) )
=> ~ ! [K3: nat] :
( ( N2
= ( extended_enat2 @ K3 ) )
=> ~ ( ord_less @ nat @ K3 @ M2 ) ) ) ).
% less_enatE
thf(fact_84_enat__less__enat__plusI2,axiom,
! [Y: nat,Z: extended_enat,X: nat] :
( ( ord_less @ extended_enat @ ( extended_enat2 @ Y ) @ Z )
=> ( ord_less @ extended_enat @ ( extended_enat2 @ ( plus_plus @ nat @ X @ Y ) ) @ ( plus_plus @ extended_enat @ ( extended_enat2 @ X ) @ Z ) ) ) ).
% enat_less_enat_plusI2
thf(fact_85_enat__less__enat__plusI,axiom,
! [X: nat,Y: nat,Z: extended_enat] :
( ( ord_less @ nat @ X @ Y )
=> ( ord_less @ extended_enat @ ( extended_enat2 @ X ) @ ( plus_plus @ extended_enat @ ( extended_enat2 @ Y ) @ Z ) ) ) ).
% enat_less_enat_plusI
thf(fact_86_add__right__imp__eq,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A @ ( type2 @ A ) )
=> ! [B2: A,A2: A,C: A] :
( ( ( plus_plus @ A @ B2 @ A2 )
= ( plus_plus @ A @ C @ A2 ) )
=> ( B2 = C ) ) ) ).
% add_right_imp_eq
thf(fact_87_add__left__imp__eq,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A] :
( ( ( plus_plus @ A @ A2 @ B2 )
= ( plus_plus @ A @ A2 @ C ) )
=> ( B2 = C ) ) ) ).
% add_left_imp_eq
thf(fact_88_add_Oleft__commute,axiom,
! [A: $tType] :
( ( ab_semigroup_add @ A @ ( type2 @ A ) )
=> ! [B2: A,A2: A,C: A] :
( ( plus_plus @ A @ B2 @ ( plus_plus @ A @ A2 @ C ) )
= ( plus_plus @ A @ A2 @ ( plus_plus @ A @ B2 @ C ) ) ) ) ).
% add.left_commute
thf(fact_89_add_Ocommute,axiom,
! [A: $tType] :
( ( ab_semigroup_add @ A @ ( type2 @ A ) )
=> ( ( plus_plus @ A )
= ( ^ [A4: A,B3: A] : ( plus_plus @ A @ B3 @ A4 ) ) ) ) ).
% add.commute
thf(fact_90_add_Oright__cancel,axiom,
! [A: $tType] :
( ( group_add @ A @ ( type2 @ A ) )
=> ! [B2: A,A2: A,C: A] :
( ( ( plus_plus @ A @ B2 @ A2 )
= ( plus_plus @ A @ C @ A2 ) )
= ( B2 = C ) ) ) ).
% add.right_cancel
thf(fact_91_add_Oleft__cancel,axiom,
! [A: $tType] :
( ( group_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A] :
( ( ( plus_plus @ A @ A2 @ B2 )
= ( plus_plus @ A @ A2 @ C ) )
= ( B2 = C ) ) ) ).
% add.left_cancel
thf(fact_92_add_Oassoc,axiom,
! [A: $tType] :
( ( semigroup_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A] :
( ( plus_plus @ A @ ( plus_plus @ A @ A2 @ B2 ) @ C )
= ( plus_plus @ A @ A2 @ ( plus_plus @ A @ B2 @ C ) ) ) ) ).
% add.assoc
thf(fact_93_add__mono__thms__linordered__semiring_I4_J,axiom,
! [A: $tType] :
( ( ordere779506340up_add @ A @ ( type2 @ A ) )
=> ! [I2: A,J: A,K: A,L: A] :
( ( ( I2 = J )
& ( K = L ) )
=> ( ( plus_plus @ A @ I2 @ K )
= ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_semiring(4)
thf(fact_94_ab__semigroup__add__class_Oadd__ac_I1_J,axiom,
! [A: $tType] :
( ( ab_semigroup_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A] :
( ( plus_plus @ A @ ( plus_plus @ A @ A2 @ B2 ) @ C )
= ( plus_plus @ A @ A2 @ ( plus_plus @ A @ B2 @ C ) ) ) ) ).
% ab_semigroup_add_class.add_ac(1)
thf(fact_95_n__not__Suc__n,axiom,
! [N2: nat] :
( N2
!= ( suc @ N2 ) ) ).
% n_not_Suc_n
thf(fact_96_Suc__inject,axiom,
! [X: nat,Y: nat] :
( ( ( suc @ X )
= ( suc @ Y ) )
=> ( X = Y ) ) ).
% Suc_inject
thf(fact_97_enat__less__induct,axiom,
! [P: extended_enat > $o,N2: extended_enat] :
( ! [N4: extended_enat] :
( ! [M5: extended_enat] :
( ( ord_less @ extended_enat @ M5 @ N4 )
=> ( P @ M5 ) )
=> ( P @ N4 ) )
=> ( P @ N2 ) ) ).
% enat_less_induct
thf(fact_98_add__less__imp__less__right,axiom,
! [A: $tType] :
( ( ordere236663937imp_le @ A @ ( type2 @ A ) )
=> ! [A2: A,C: A,B2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ A2 @ C ) @ ( plus_plus @ A @ B2 @ C ) )
=> ( ord_less @ A @ A2 @ B2 ) ) ) ).
% add_less_imp_less_right
thf(fact_99_add__less__imp__less__left,axiom,
! [A: $tType] :
( ( ordere236663937imp_le @ A @ ( type2 @ A ) )
=> ! [C: A,A2: A,B2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ C @ A2 ) @ ( plus_plus @ A @ C @ B2 ) )
=> ( ord_less @ A @ A2 @ B2 ) ) ) ).
% add_less_imp_less_left
thf(fact_100_add__strict__right__mono,axiom,
! [A: $tType] :
( ( ordere223160158up_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A] :
( ( ord_less @ A @ A2 @ B2 )
=> ( ord_less @ A @ ( plus_plus @ A @ A2 @ C ) @ ( plus_plus @ A @ B2 @ C ) ) ) ) ).
% add_strict_right_mono
thf(fact_101_add__strict__left__mono,axiom,
! [A: $tType] :
( ( ordere223160158up_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A] :
( ( ord_less @ A @ A2 @ B2 )
=> ( ord_less @ A @ ( plus_plus @ A @ C @ A2 ) @ ( plus_plus @ A @ C @ B2 ) ) ) ) ).
% add_strict_left_mono
thf(fact_102_add__strict__mono,axiom,
! [A: $tType] :
( ( strict2144017051up_add @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A,D: A] :
( ( ord_less @ A @ A2 @ B2 )
=> ( ( ord_less @ A @ C @ D )
=> ( ord_less @ A @ ( plus_plus @ A @ A2 @ C ) @ ( plus_plus @ A @ B2 @ D ) ) ) ) ) ).
% add_strict_mono
thf(fact_103_add__mono__thms__linordered__field_I1_J,axiom,
! [A: $tType] :
( ( ordere223160158up_add @ A @ ( type2 @ A ) )
=> ! [I2: A,J: A,K: A,L: A] :
( ( ( ord_less @ A @ I2 @ J )
& ( K = L ) )
=> ( ord_less @ A @ ( plus_plus @ A @ I2 @ K ) @ ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_field(1)
thf(fact_104_add__mono__thms__linordered__field_I2_J,axiom,
! [A: $tType] :
( ( ordere223160158up_add @ A @ ( type2 @ A ) )
=> ! [I2: A,J: A,K: A,L: A] :
( ( ( I2 = J )
& ( ord_less @ A @ K @ L ) )
=> ( ord_less @ A @ ( plus_plus @ A @ I2 @ K ) @ ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_field(2)
thf(fact_105_add__mono__thms__linordered__field_I5_J,axiom,
! [A: $tType] :
( ( ordere223160158up_add @ A @ ( type2 @ A ) )
=> ! [I2: A,J: A,K: A,L: A] :
( ( ( ord_less @ A @ I2 @ J )
& ( ord_less @ A @ K @ L ) )
=> ( ord_less @ A @ ( plus_plus @ A @ I2 @ K ) @ ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_field(5)
thf(fact_106_lift__Suc__mono__less__iff,axiom,
! [A: $tType] :
( ( order @ A @ ( type2 @ A ) )
=> ! [F: nat > A,N2: nat,M2: nat] :
( ! [N4: nat] : ( ord_less @ A @ ( F @ N4 ) @ ( F @ ( suc @ N4 ) ) )
=> ( ( ord_less @ A @ ( F @ N2 ) @ ( F @ M2 ) )
= ( ord_less @ nat @ N2 @ M2 ) ) ) ) ).
% lift_Suc_mono_less_iff
thf(fact_107_lift__Suc__mono__less,axiom,
! [A: $tType] :
( ( order @ A @ ( type2 @ A ) )
=> ! [F: nat > A,N2: nat,N5: nat] :
( ! [N4: nat] : ( ord_less @ A @ ( F @ N4 ) @ ( F @ ( suc @ N4 ) ) )
=> ( ( ord_less @ nat @ N2 @ N5 )
=> ( ord_less @ A @ ( F @ N2 ) @ ( F @ N5 ) ) ) ) ) ).
% lift_Suc_mono_less
thf(fact_108_lessThan__strict__subset__iff,axiom,
! [A: $tType] :
( ( linorder @ A @ ( type2 @ A ) )
=> ! [M2: A,N2: A] :
( ( ord_less @ ( set @ A ) @ ( set_ord_lessThan @ A @ M2 ) @ ( set_ord_lessThan @ A @ N2 ) )
= ( ord_less @ A @ M2 @ N2 ) ) ) ).
% lessThan_strict_subset_iff
thf(fact_109_enat__iless,axiom,
! [N2: extended_enat,M2: nat] :
( ( ord_less @ extended_enat @ N2 @ ( extended_enat2 @ M2 ) )
=> ? [K3: nat] :
( N2
= ( extended_enat2 @ K3 ) ) ) ).
% enat_iless
thf(fact_110_chain__incr,axiom,
! [A: $tType,Y3: A > extended_enat,K: nat] :
( ! [I3: A] :
? [J3: A] : ( ord_less @ extended_enat @ ( Y3 @ I3 ) @ ( Y3 @ J3 ) )
=> ? [J2: A] : ( ord_less @ extended_enat @ ( extended_enat2 @ K ) @ ( Y3 @ J2 ) ) ) ).
% chain_incr
thf(fact_111_lessThan__def,axiom,
! [A: $tType] :
( ( ord @ A @ ( type2 @ A ) )
=> ( ( set_ord_lessThan @ A )
= ( ^ [U: A] :
( collect @ A
@ ^ [X3: A] : ( ord_less @ A @ X3 @ U ) ) ) ) ) ).
% lessThan_def
thf(fact_112_setsum_Oneutral__const,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [A3: set @ B] :
( ( groups15040474setsum @ B @ A
@ ^ [Uu: B] : ( zero_zero @ A )
@ A3 )
= ( zero_zero @ A ) ) ) ).
% setsum.neutral_const
thf(fact_113_lnth__prefix,axiom,
! [I4: nat] :
( ( ord_less @ nat @ I4 @ ( size_size @ ( list @ ( coindu1593790203_llist @ a ) ) @ xss2 ) )
=> ( ( coindu749330388e_lnth @ ( coindu1593790203_llist @ a ) @ xssa @ I4 )
= ( coindu1598213697e_LNil @ a ) ) ) ).
% lnth_prefix
thf(fact_114_llength__lconcat__lfinite__conv__sum,axiom,
! [A: $tType,Xss: coindu1593790203_llist @ ( coindu1593790203_llist @ A )] :
( ( coindu1213758845finite @ ( coindu1593790203_llist @ A ) @ Xss )
=> ( ( coindu1018505716length @ A @ ( coindu441856546concat @ A @ Xss ) )
= ( groups15040474setsum @ nat @ extended_enat
@ ^ [I: nat] : ( coindu1018505716length @ A @ ( coindu749330388e_lnth @ ( coindu1593790203_llist @ A ) @ Xss @ I ) )
@ ( collect @ nat
@ ^ [I: nat] : ( ord_less @ extended_enat @ ( extended_enat2 @ I ) @ ( coindu1018505716length @ ( coindu1593790203_llist @ A ) @ Xss ) ) ) ) ) ) ).
% llength_lconcat_lfinite_conv_sum
thf(fact_115_setsum_Odistrib,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [G: B > A,H: B > A,A3: set @ B] :
( ( groups15040474setsum @ B @ A
@ ^ [X3: B] : ( plus_plus @ A @ ( G @ X3 ) @ ( H @ X3 ) )
@ A3 )
= ( plus_plus @ A @ ( groups15040474setsum @ B @ A @ G @ A3 ) @ ( groups15040474setsum @ B @ A @ H @ A3 ) ) ) ) ).
% setsum.distrib
thf(fact_116__092_060open_062_092_060And_062thesis_O_A_I_092_060And_062x_Axs_O_Alconcat_Axss_A_061_ALCons_Ax_Axs_A_092_060Longrightarrow_062_Athesis_J_A_092_060Longrightarrow_062_Athesis_092_060close_062,axiom,
~ ! [X4: a,Xs: coindu1593790203_llist @ a] :
( ( coindu441856546concat @ a @ xssa )
!= ( coindu1121789889_LCons @ a @ X4 @ Xs ) ) ).
% \<open>\<And>thesis. (\<And>x xs. lconcat xss = LCons x xs \<Longrightarrow> thesis) \<Longrightarrow> thesis\<close>
thf(fact_117__092_060open_062_092_060not_062_Alnull_A_Ilconcat_Axss_J_092_060close_062,axiom,
~ ( coindu335574135_lnull @ a @ ( coindu441856546concat @ a @ xssa ) ) ).
% \<open>\<not> lnull (lconcat xss)\<close>
thf(fact_118_gen__llength__def,axiom,
! [A: $tType] :
( ( coindu493225792length @ A )
= ( ^ [N3: nat,Xs2: coindu1593790203_llist @ A] : ( plus_plus @ extended_enat @ ( extended_enat2 @ N3 ) @ ( coindu1018505716length @ A @ Xs2 ) ) ) ) ).
% gen_llength_def
thf(fact_119_setsum_Onot__neutral__contains__not__neutral,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [G: B > A,A3: set @ B] :
( ( ( groups15040474setsum @ B @ A @ G @ A3 )
!= ( zero_zero @ A ) )
=> ~ ! [A5: B] :
( ( member @ B @ A5 @ A3 )
=> ( ( G @ A5 )
= ( zero_zero @ A ) ) ) ) ) ).
% setsum.not_neutral_contains_not_neutral
thf(fact_120_setsum_Oneutral,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [A3: set @ B,G: B > A] :
( ! [X4: B] :
( ( member @ B @ X4 @ A3 )
=> ( ( G @ X4 )
= ( zero_zero @ A ) ) )
=> ( ( groups15040474setsum @ B @ A @ G @ A3 )
= ( zero_zero @ A ) ) ) ) ).
% setsum.neutral
thf(fact_121_add__0__iff,axiom,
! [A: $tType] :
( ( semiri456707255roduct @ A @ ( type2 @ A ) )
=> ! [B2: A,A2: A] :
( ( B2
= ( plus_plus @ A @ B2 @ A2 ) )
= ( A2
= ( zero_zero @ A ) ) ) ) ).
% add_0_iff
thf(fact_122_False,axiom,
~ ( ord_less @ nat @ ( zero_zero @ nat ) @ m ) ).
% False
thf(fact_123_neq0__conv,axiom,
! [N2: nat] :
( ( N2
!= ( zero_zero @ nat ) )
= ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ).
% neq0_conv
thf(fact_124_add__is__0,axiom,
! [M2: nat,N2: nat] :
( ( ( plus_plus @ nat @ M2 @ N2 )
= ( zero_zero @ nat ) )
= ( ( M2
= ( zero_zero @ nat ) )
& ( N2
= ( zero_zero @ nat ) ) ) ) ).
% add_is_0
thf(fact_125_Nat_Oadd__0__right,axiom,
! [M2: nat] :
( ( plus_plus @ nat @ M2 @ ( zero_zero @ nat ) )
= M2 ) ).
% Nat.add_0_right
thf(fact_126_llist_Oinject,axiom,
! [A: $tType,X21: A,X22: coindu1593790203_llist @ A,Y21: A,Y22: coindu1593790203_llist @ A] :
( ( ( coindu1121789889_LCons @ A @ X21 @ X22 )
= ( coindu1121789889_LCons @ A @ Y21 @ Y22 ) )
= ( ( X21 = Y21 )
& ( X22 = Y22 ) ) ) ).
% llist.inject
thf(fact_127_zero__less__Suc,axiom,
! [N2: nat] : ( ord_less @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) ) ).
% zero_less_Suc
thf(fact_128_less__Suc0,axiom,
! [N2: nat] :
( ( ord_less @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) )
= ( N2
= ( zero_zero @ nat ) ) ) ).
% less_Suc0
thf(fact_129_add__gr__0,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( plus_plus @ nat @ M2 @ N2 ) )
= ( ( ord_less @ nat @ ( zero_zero @ nat ) @ M2 )
| ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ).
% add_gr_0
thf(fact_130_nat__add__left__cancel__less,axiom,
! [K: nat,M2: nat,N2: nat] :
( ( ord_less @ nat @ ( plus_plus @ nat @ K @ M2 ) @ ( plus_plus @ nat @ K @ N2 ) )
= ( ord_less @ nat @ M2 @ N2 ) ) ).
% nat_add_left_cancel_less
thf(fact_131_lfinite__LCons,axiom,
! [A: $tType,X: A,Xs3: coindu1593790203_llist @ A] :
( ( coindu1213758845finite @ A @ ( coindu1121789889_LCons @ A @ X @ Xs3 ) )
= ( coindu1213758845finite @ A @ Xs3 ) ) ).
% lfinite_LCons
thf(fact_132_lfinite__code_I2_J,axiom,
! [B: $tType,X: B,Xs3: coindu1593790203_llist @ B] :
( ( coindu1213758845finite @ B @ ( coindu1121789889_LCons @ B @ X @ Xs3 ) )
= ( coindu1213758845finite @ B @ Xs3 ) ) ).
% lfinite_code(2)
thf(fact_133_lfinite__code_I1_J,axiom,
! [A: $tType] : ( coindu1213758845finite @ A @ ( coindu1598213697e_LNil @ A ) ) ).
% lfinite_code(1)
thf(fact_134_lnth__0,axiom,
! [A: $tType,X: A,Xs3: coindu1593790203_llist @ A] :
( ( coindu749330388e_lnth @ A @ ( coindu1121789889_LCons @ A @ X @ Xs3 ) @ ( zero_zero @ nat ) )
= X ) ).
% lnth_0
thf(fact_135_lconcat__LNil,axiom,
! [A: $tType] :
( ( coindu441856546concat @ A @ ( coindu1598213697e_LNil @ ( coindu1593790203_llist @ A ) ) )
= ( coindu1598213697e_LNil @ A ) ) ).
% lconcat_LNil
thf(fact_136_lnth__Suc__LCons,axiom,
! [A: $tType,X: A,Xs3: coindu1593790203_llist @ A,N2: nat] :
( ( coindu749330388e_lnth @ A @ ( coindu1121789889_LCons @ A @ X @ Xs3 ) @ ( suc @ N2 ) )
= ( coindu749330388e_lnth @ A @ Xs3 @ N2 ) ) ).
% lnth_Suc_LCons
thf(fact_137_llength__eq__0,axiom,
! [A: $tType,Xs3: coindu1593790203_llist @ A] :
( ( ( coindu1018505716length @ A @ Xs3 )
= ( zero_zero @ extended_enat ) )
= ( coindu335574135_lnull @ A @ Xs3 ) ) ).
% llength_eq_0
thf(fact_138_llength__lnull,axiom,
! [A: $tType,Xs3: coindu1593790203_llist @ A] :
( ( coindu335574135_lnull @ A @ Xs3 )
=> ( ( coindu1018505716length @ A @ Xs3 )
= ( zero_zero @ extended_enat ) ) ) ).
% llength_lnull
thf(fact_139_llength__LNil,axiom,
! [A: $tType] :
( ( coindu1018505716length @ A @ ( coindu1598213697e_LNil @ A ) )
= ( zero_zero @ extended_enat ) ) ).
% llength_LNil
thf(fact_140_concat__xss,axiom,
( ( coindu441856546concat @ a @ xssa )
= ( coindu1121789889_LCons @ a @ x @ xs ) ) ).
% concat_xss
thf(fact_141_gr0I,axiom,
! [N2: nat] :
( ( N2
!= ( zero_zero @ nat ) )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ).
% gr0I
thf(fact_142_not__gr0,axiom,
! [N2: nat] :
( ( ~ ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) )
= ( N2
= ( zero_zero @ nat ) ) ) ).
% not_gr0
thf(fact_143_not__less0,axiom,
! [N2: nat] :
~ ( ord_less @ nat @ N2 @ ( zero_zero @ nat ) ) ).
% not_less0
thf(fact_144_add__lessD1,axiom,
! [I2: nat,J: nat,K: nat] :
( ( ord_less @ nat @ ( plus_plus @ nat @ I2 @ J ) @ K )
=> ( ord_less @ nat @ I2 @ K ) ) ).
% add_lessD1
thf(fact_145_less__zeroE,axiom,
! [N2: nat] :
~ ( ord_less @ nat @ N2 @ ( zero_zero @ nat ) ) ).
% less_zeroE
thf(fact_146_nat__neq__iff,axiom,
! [M2: nat,N2: nat] :
( ( M2 != N2 )
= ( ( ord_less @ nat @ M2 @ N2 )
| ( ord_less @ nat @ N2 @ M2 ) ) ) ).
% nat_neq_iff
thf(fact_147_add__less__mono,axiom,
! [I2: nat,J: nat,K: nat,L: nat] :
( ( ord_less @ nat @ I2 @ J )
=> ( ( ord_less @ nat @ K @ L )
=> ( ord_less @ nat @ ( plus_plus @ nat @ I2 @ K ) @ ( plus_plus @ nat @ J @ L ) ) ) ) ).
% add_less_mono
thf(fact_148_less__not__refl,axiom,
! [N2: nat] :
~ ( ord_less @ nat @ N2 @ N2 ) ).
% less_not_refl
thf(fact_149_not__add__less1,axiom,
! [I2: nat,J: nat] :
~ ( ord_less @ nat @ ( plus_plus @ nat @ I2 @ J ) @ I2 ) ).
% not_add_less1
thf(fact_150_not__add__less2,axiom,
! [J: nat,I2: nat] :
~ ( ord_less @ nat @ ( plus_plus @ nat @ J @ I2 ) @ I2 ) ).
% not_add_less2
thf(fact_151_add__less__mono1,axiom,
! [I2: nat,J: nat,K: nat] :
( ( ord_less @ nat @ I2 @ J )
=> ( ord_less @ nat @ ( plus_plus @ nat @ I2 @ K ) @ ( plus_plus @ nat @ J @ K ) ) ) ).
% add_less_mono1
thf(fact_152_less__not__refl2,axiom,
! [N2: nat,M2: nat] :
( ( ord_less @ nat @ N2 @ M2 )
=> ( M2 != N2 ) ) ).
% less_not_refl2
thf(fact_153_less__not__refl3,axiom,
! [S: nat,T: nat] :
( ( ord_less @ nat @ S @ T )
=> ( S != T ) ) ).
% less_not_refl3
thf(fact_154_measure__induct,axiom,
! [A: $tType,F: A > nat,P: A > $o,A2: A] :
( ! [X4: A] :
( ! [Y4: A] :
( ( ord_less @ nat @ ( F @ Y4 ) @ ( F @ X4 ) )
=> ( P @ Y4 ) )
=> ( P @ X4 ) )
=> ( P @ A2 ) ) ).
% measure_induct
thf(fact_155_plus__nat_Oadd__0,axiom,
! [N2: nat] :
( ( plus_plus @ nat @ ( zero_zero @ nat ) @ N2 )
= N2 ) ).
% plus_nat.add_0
thf(fact_156_gr__implies__not0,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ M2 @ N2 )
=> ( N2
!= ( zero_zero @ nat ) ) ) ).
% gr_implies_not0
thf(fact_157_less__irrefl__nat,axiom,
! [N2: nat] :
~ ( ord_less @ nat @ N2 @ N2 ) ).
% less_irrefl_nat
thf(fact_158_nat__less__induct,axiom,
! [P: nat > $o,N2: nat] :
( ! [N4: nat] :
( ! [M5: nat] :
( ( ord_less @ nat @ M5 @ N4 )
=> ( P @ M5 ) )
=> ( P @ N4 ) )
=> ( P @ N2 ) ) ).
% nat_less_induct
thf(fact_159_trans__less__add1,axiom,
! [I2: nat,J: nat,M2: nat] :
( ( ord_less @ nat @ I2 @ J )
=> ( ord_less @ nat @ I2 @ ( plus_plus @ nat @ J @ M2 ) ) ) ).
% trans_less_add1
thf(fact_160_trans__less__add2,axiom,
! [I2: nat,J: nat,M2: nat] :
( ( ord_less @ nat @ I2 @ J )
=> ( ord_less @ nat @ I2 @ ( plus_plus @ nat @ M2 @ J ) ) ) ).
% trans_less_add2
thf(fact_161_add__eq__self__zero,axiom,
! [M2: nat,N2: nat] :
( ( ( plus_plus @ nat @ M2 @ N2 )
= M2 )
=> ( N2
= ( zero_zero @ nat ) ) ) ).
% add_eq_self_zero
thf(fact_162_infinite__descent,axiom,
! [P: nat > $o,N2: nat] :
( ! [N4: nat] :
( ~ ( P @ N4 )
=> ? [M5: nat] :
( ( ord_less @ nat @ M5 @ N4 )
& ~ ( P @ M5 ) ) )
=> ( P @ N2 ) ) ).
% infinite_descent
thf(fact_163_less__add__eq__less,axiom,
! [K: nat,L: nat,M2: nat,N2: nat] :
( ( ord_less @ nat @ K @ L )
=> ( ( ( plus_plus @ nat @ M2 @ L )
= ( plus_plus @ nat @ K @ N2 ) )
=> ( ord_less @ nat @ M2 @ N2 ) ) ) ).
% less_add_eq_less
thf(fact_164_infinite__descent0,axiom,
! [P: nat > $o,N2: nat] :
( ( P @ ( zero_zero @ nat ) )
=> ( ! [N4: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N4 )
=> ( ~ ( P @ N4 )
=> ? [M5: nat] :
( ( ord_less @ nat @ M5 @ N4 )
& ~ ( P @ M5 ) ) ) )
=> ( P @ N2 ) ) ) ).
% infinite_descent0
thf(fact_165_linorder__neqE__nat,axiom,
! [X: nat,Y: nat] :
( ( X != Y )
=> ( ~ ( ord_less @ nat @ X @ Y )
=> ( ord_less @ nat @ Y @ X ) ) ) ).
% linorder_neqE_nat
thf(fact_166_setsum__SucD,axiom,
! [A: $tType,F: A > nat,A3: set @ A,N2: nat] :
( ( ( groups15040474setsum @ A @ nat @ F @ A3 )
= ( suc @ N2 ) )
=> ? [X4: A] :
( ( member @ A @ X4 @ A3 )
& ( ord_less @ nat @ ( zero_zero @ nat ) @ ( F @ X4 ) ) ) ) ).
% setsum_SucD
thf(fact_167_less__nat__zero__code,axiom,
! [N2: nat] :
~ ( ord_less @ nat @ N2 @ ( zero_zero @ nat ) ) ).
% less_nat_zero_code
thf(fact_168_measure__induct__rule,axiom,
! [A: $tType,F: A > nat,P: A > $o,A2: A] :
( ! [X4: A] :
( ! [Y4: A] :
( ( ord_less @ nat @ ( F @ Y4 ) @ ( F @ X4 ) )
=> ( P @ Y4 ) )
=> ( P @ X4 ) )
=> ( P @ A2 ) ) ).
% measure_induct_rule
thf(fact_169_nat__add__left__cancel,axiom,
! [K: nat,M2: nat,N2: nat] :
( ( ( plus_plus @ nat @ K @ M2 )
= ( plus_plus @ nat @ K @ N2 ) )
= ( M2 = N2 ) ) ).
% nat_add_left_cancel
thf(fact_170_nat__add__right__cancel,axiom,
! [M2: nat,K: nat,N2: nat] :
( ( ( plus_plus @ nat @ M2 @ K )
= ( plus_plus @ nat @ N2 @ K ) )
= ( M2 = N2 ) ) ).
% nat_add_right_cancel
thf(fact_171_less__imp__add__positive,axiom,
! [I2: nat,J: nat] :
( ( ord_less @ nat @ I2 @ J )
=> ? [K3: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ K3 )
& ( ( plus_plus @ nat @ I2 @ K3 )
= J ) ) ) ).
% less_imp_add_positive
thf(fact_172_infinite__descent__measure,axiom,
! [A: $tType,P: A > $o,V: A > nat,X: A] :
( ! [X4: A] :
( ~ ( P @ X4 )
=> ? [Y4: A] :
( ( ord_less @ nat @ ( V @ Y4 ) @ ( V @ X4 ) )
& ~ ( P @ Y4 ) ) )
=> ( P @ X ) ) ).
% infinite_descent_measure
thf(fact_173_infinite__descent0__measure,axiom,
! [A: $tType,V: A > nat,P: A > $o,X: A] :
( ! [X4: A] :
( ( ( V @ X4 )
= ( zero_zero @ nat ) )
=> ( P @ X4 ) )
=> ( ! [X4: A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( V @ X4 ) )
=> ( ~ ( P @ X4 )
=> ? [Y4: A] :
( ( ord_less @ nat @ ( V @ Y4 ) @ ( V @ X4 ) )
& ~ ( P @ Y4 ) ) ) )
=> ( P @ X ) ) ) ).
% infinite_descent0_measure
thf(fact_174_lfinite__LConsI,axiom,
! [A: $tType,Xs3: coindu1593790203_llist @ A,X: A] :
( ( coindu1213758845finite @ A @ Xs3 )
=> ( coindu1213758845finite @ A @ ( coindu1121789889_LCons @ A @ X @ Xs3 ) ) ) ).
% lfinite_LConsI
thf(fact_175_lfinite__LNil,axiom,
! [A: $tType] : ( coindu1213758845finite @ A @ ( coindu1598213697e_LNil @ A ) ) ).
% lfinite_LNil
thf(fact_176_lnull__imp__lfinite,axiom,
! [A: $tType,Xs3: coindu1593790203_llist @ A] :
( ( coindu335574135_lnull @ A @ Xs3 )
=> ( coindu1213758845finite @ A @ Xs3 ) ) ).
% lnull_imp_lfinite
thf(fact_177_lnull__def,axiom,
! [A: $tType] :
( ( coindu335574135_lnull @ A )
= ( ^ [Llist: coindu1593790203_llist @ A] :
( Llist
= ( coindu1598213697e_LNil @ A ) ) ) ) ).
% lnull_def
thf(fact_178_lfinite_Oinducts,axiom,
! [A: $tType,X: coindu1593790203_llist @ A,P: ( coindu1593790203_llist @ A ) > $o] :
( ( coindu1213758845finite @ A @ X )
=> ( ( P @ ( coindu1598213697e_LNil @ A ) )
=> ( ! [Xs: coindu1593790203_llist @ A,X4: A] :
( ( coindu1213758845finite @ A @ Xs )
=> ( ( P @ Xs )
=> ( P @ ( coindu1121789889_LCons @ A @ X4 @ Xs ) ) ) )
=> ( P @ X ) ) ) ) ).
% lfinite.inducts
thf(fact_179_lappend_Oexhaust,axiom,
! [A: $tType,Xs3: coindu1593790203_llist @ A,Ys: coindu1593790203_llist @ A] :
( ( ( coindu335574135_lnull @ A @ Xs3 )
=> ~ ( coindu335574135_lnull @ A @ Ys ) )
=> ( ~ ( coindu335574135_lnull @ A @ Xs3 )
| ~ ( coindu335574135_lnull @ A @ Ys ) ) ) ).
% lappend.exhaust
thf(fact_180_not__lnull__conv,axiom,
! [A: $tType,Xs3: coindu1593790203_llist @ A] :
( ( ~ ( coindu335574135_lnull @ A @ Xs3 ) )
= ( ? [X3: A,Xs4: coindu1593790203_llist @ A] :
( Xs3
= ( coindu1121789889_LCons @ A @ X3 @ Xs4 ) ) ) ) ).
% not_lnull_conv
thf(fact_181_neq__LNil__conv,axiom,
! [A: $tType,Xs3: coindu1593790203_llist @ A] :
( ( Xs3
!= ( coindu1598213697e_LNil @ A ) )
= ( ? [X3: A,Xs4: coindu1593790203_llist @ A] :
( Xs3
= ( coindu1121789889_LCons @ A @ X3 @ Xs4 ) ) ) ) ).
% neq_LNil_conv
thf(fact_182_llist_Oexhaust,axiom,
! [A: $tType,Y: coindu1593790203_llist @ A] :
( ( Y
!= ( coindu1598213697e_LNil @ A ) )
=> ~ ! [X212: A,X222: coindu1593790203_llist @ A] :
( Y
!= ( coindu1121789889_LCons @ A @ X212 @ X222 ) ) ) ).
% llist.exhaust
thf(fact_183_lfinite_Osimps,axiom,
! [A: $tType] :
( ( coindu1213758845finite @ A )
= ( ^ [A4: coindu1593790203_llist @ A] :
( ( A4
= ( coindu1598213697e_LNil @ A ) )
| ? [Xs2: coindu1593790203_llist @ A,X3: A] :
( ( A4
= ( coindu1121789889_LCons @ A @ X3 @ Xs2 ) )
& ( coindu1213758845finite @ A @ Xs2 ) ) ) ) ) ).
% lfinite.simps
thf(fact_184_lfinite_Ocases,axiom,
! [A: $tType,A2: coindu1593790203_llist @ A] :
( ( coindu1213758845finite @ A @ A2 )
=> ( ( A2
!= ( coindu1598213697e_LNil @ A ) )
=> ~ ! [Xs: coindu1593790203_llist @ A] :
( ? [X4: A] :
( A2
= ( coindu1121789889_LCons @ A @ X4 @ Xs ) )
=> ~ ( coindu1213758845finite @ A @ Xs ) ) ) ) ).
% lfinite.cases
thf(fact_185_lzip_Oexhaust,axiom,
! [A: $tType,B: $tType,Xs3: coindu1593790203_llist @ A,Ys: coindu1593790203_llist @ B] :
( ~ ( ( coindu335574135_lnull @ A @ Xs3 )
| ( coindu335574135_lnull @ B @ Ys ) )
=> ~ ( ~ ( coindu335574135_lnull @ A @ Xs3 )
=> ( coindu335574135_lnull @ B @ Ys ) ) ) ).
% lzip.exhaust
thf(fact_186_llist_Odistinct_I1_J,axiom,
! [A: $tType,X21: A,X22: coindu1593790203_llist @ A] :
( ( coindu1598213697e_LNil @ A )
!= ( coindu1121789889_LCons @ A @ X21 @ X22 ) ) ).
% llist.distinct(1)
thf(fact_187_llist_Ocollapse_I1_J,axiom,
! [A: $tType,Llist2: coindu1593790203_llist @ A] :
( ( coindu335574135_lnull @ A @ Llist2 )
=> ( Llist2
= ( coindu1598213697e_LNil @ A ) ) ) ).
% llist.collapse(1)
thf(fact_188_llist_OdiscI_I1_J,axiom,
! [A: $tType,Llist2: coindu1593790203_llist @ A] :
( ( Llist2
= ( coindu1598213697e_LNil @ A ) )
=> ( coindu335574135_lnull @ A @ Llist2 ) ) ).
% llist.discI(1)
thf(fact_189_llist_OdiscI_I2_J,axiom,
! [A: $tType,Llist2: coindu1593790203_llist @ A,X21: A,X22: coindu1593790203_llist @ A] :
( ( Llist2
= ( coindu1121789889_LCons @ A @ X21 @ X22 ) )
=> ~ ( coindu335574135_lnull @ A @ Llist2 ) ) ).
% llist.discI(2)
thf(fact_190_llist_Odisc_I1_J,axiom,
! [A: $tType] : ( coindu335574135_lnull @ A @ ( coindu1598213697e_LNil @ A ) ) ).
% llist.disc(1)
thf(fact_191_llist_Odisc_I2_J,axiom,
! [A: $tType,X21: A,X22: coindu1593790203_llist @ A] :
~ ( coindu335574135_lnull @ A @ ( coindu1121789889_LCons @ A @ X21 @ X22 ) ) ).
% llist.disc(2)
thf(fact_192_gen__llength__code_I1_J,axiom,
! [A: $tType,N2: nat] :
( ( coindu493225792length @ A @ N2 @ ( coindu1598213697e_LNil @ A ) )
= ( extended_enat2 @ N2 ) ) ).
% gen_llength_code(1)
thf(fact_193_llength__code,axiom,
! [A: $tType] :
( ( coindu1018505716length @ A )
= ( coindu493225792length @ A @ ( zero_zero @ nat ) ) ) ).
% llength_code
thf(fact_194_ltake_Oexhaust,axiom,
! [A: $tType,N2: extended_enat,Xs3: coindu1593790203_llist @ A] :
( ~ ( ( N2
= ( zero_zero @ extended_enat ) )
| ( coindu335574135_lnull @ A @ Xs3 ) )
=> ~ ( ( N2
!= ( zero_zero @ extended_enat ) )
=> ( coindu335574135_lnull @ A @ Xs3 ) ) ) ).
% ltake.exhaust
thf(fact_195_nat_Odistinct_I1_J,axiom,
! [X2: nat] :
( ( zero_zero @ nat )
!= ( suc @ X2 ) ) ).
% nat.distinct(1)
thf(fact_196_old_Onat_Odistinct_I2_J,axiom,
! [Nat3: nat] :
( ( suc @ Nat3 )
!= ( zero_zero @ nat ) ) ).
% old.nat.distinct(2)
thf(fact_197_old_Onat_Odistinct_I1_J,axiom,
! [Nat2: nat] :
( ( zero_zero @ nat )
!= ( suc @ Nat2 ) ) ).
% old.nat.distinct(1)
thf(fact_198_nat_OdiscI,axiom,
! [Nat: nat,X2: nat] :
( ( Nat
= ( suc @ X2 ) )
=> ( Nat
!= ( zero_zero @ nat ) ) ) ).
% nat.discI
thf(fact_199_nat__induct,axiom,
! [P: nat > $o,N2: nat] :
( ( P @ ( zero_zero @ nat ) )
=> ( ! [N4: nat] :
( ( P @ N4 )
=> ( P @ ( suc @ N4 ) ) )
=> ( P @ N2 ) ) ) ).
% nat_induct
thf(fact_200_diff__induct,axiom,
! [P: nat > nat > $o,M2: nat,N2: nat] :
( ! [X4: nat] : ( P @ X4 @ ( zero_zero @ nat ) )
=> ( ! [Y5: nat] : ( P @ ( zero_zero @ nat ) @ ( suc @ Y5 ) )
=> ( ! [X4: nat,Y5: nat] :
( ( P @ X4 @ Y5 )
=> ( P @ ( suc @ X4 ) @ ( suc @ Y5 ) ) )
=> ( P @ M2 @ N2 ) ) ) ) ).
% diff_induct
thf(fact_201_zero__induct,axiom,
! [P: nat > $o,K: nat] :
( ( P @ K )
=> ( ! [N4: nat] :
( ( P @ ( suc @ N4 ) )
=> ( P @ N4 ) )
=> ( P @ ( zero_zero @ nat ) ) ) ) ).
% zero_induct
thf(fact_202_Suc__neq__Zero,axiom,
! [M2: nat] :
( ( suc @ M2 )
!= ( zero_zero @ nat ) ) ).
% Suc_neq_Zero
thf(fact_203_Zero__neq__Suc,axiom,
! [M2: nat] :
( ( zero_zero @ nat )
!= ( suc @ M2 ) ) ).
% Zero_neq_Suc
thf(fact_204_Zero__not__Suc,axiom,
! [M2: nat] :
( ( zero_zero @ nat )
!= ( suc @ M2 ) ) ).
% Zero_not_Suc
thf(fact_205_old_Onat_Oexhaust,axiom,
! [Y: nat] :
( ( Y
!= ( zero_zero @ nat ) )
=> ~ ! [Nat4: nat] :
( Y
!= ( suc @ Nat4 ) ) ) ).
% old.nat.exhaust
thf(fact_206_old_Onat_Oinducts,axiom,
! [P: nat > $o,Nat: nat] :
( ( P @ ( zero_zero @ nat ) )
=> ( ! [Nat4: nat] :
( ( P @ Nat4 )
=> ( P @ ( suc @ Nat4 ) ) )
=> ( P @ Nat ) ) ) ).
% old.nat.inducts
thf(fact_207_not0__implies__Suc,axiom,
! [N2: nat] :
( ( N2
!= ( zero_zero @ nat ) )
=> ? [M: nat] :
( N2
= ( suc @ M ) ) ) ).
% not0_implies_Suc
thf(fact_208_less__Suc__eq__0__disj,axiom,
! [M2: nat,N2: nat] :
( ( ord_less @ nat @ M2 @ ( suc @ N2 ) )
= ( ( M2
= ( zero_zero @ nat ) )
| ? [J4: nat] :
( ( M2
= ( suc @ J4 ) )
& ( ord_less @ nat @ J4 @ N2 ) ) ) ) ).
% less_Suc_eq_0_disj
thf(fact_209_gr0__implies__Suc,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ? [M: nat] :
( N2
= ( suc @ M ) ) ) ).
% gr0_implies_Suc
thf(fact_210_gr0__conv__Suc,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
= ( ? [M3: nat] :
( N2
= ( suc @ M3 ) ) ) ) ).
% gr0_conv_Suc
thf(fact_211_one__is__add,axiom,
! [M2: nat,N2: nat] :
( ( ( suc @ ( zero_zero @ nat ) )
= ( plus_plus @ nat @ M2 @ N2 ) )
= ( ( ( M2
= ( suc @ ( zero_zero @ nat ) ) )
& ( N2
= ( zero_zero @ nat ) ) )
| ( ( M2
= ( zero_zero @ nat ) )
& ( N2
= ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ).
% one_is_add
thf(fact_212_add__is__1,axiom,
! [M2: nat,N2: nat] :
( ( ( plus_plus @ nat @ M2 @ N2 )
= ( suc @ ( zero_zero @ nat ) ) )
= ( ( ( M2
= ( suc @ ( zero_zero @ nat ) ) )
& ( N2
= ( zero_zero @ nat ) ) )
| ( ( M2
= ( zero_zero @ nat ) )
& ( N2
= ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ).
% add_is_1
thf(fact_213_setsum__cong__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [A3: set @ nat,F: nat > A,G: nat > A] :
( ~ ( member @ nat @ ( zero_zero @ nat ) @ A3 )
=> ( ! [X4: nat] :
( ( member @ nat @ ( suc @ X4 ) @ A3 )
=> ( ( F @ ( suc @ X4 ) )
= ( G @ ( suc @ X4 ) ) ) )
=> ( ( groups15040474setsum @ nat @ A @ F @ A3 )
= ( groups15040474setsum @ nat @ A @ G @ A3 ) ) ) ) ) ).
% setsum_cong_Suc
thf(fact_214_lfinite__llength__enat,axiom,
! [A: $tType,Xs3: coindu1593790203_llist @ A] :
( ( coindu1213758845finite @ A @ Xs3 )
=> ? [N4: nat] :
( ( coindu1018505716length @ A @ Xs3 )
= ( extended_enat2 @ N4 ) ) ) ).
% lfinite_llength_enat
thf(fact_215_llength__eq__enat__lfiniteD,axiom,
! [A: $tType,Xs3: coindu1593790203_llist @ A,N2: nat] :
( ( ( coindu1018505716length @ A @ Xs3 )
= ( extended_enat2 @ N2 ) )
=> ( coindu1213758845finite @ A @ Xs3 ) ) ).
% llength_eq_enat_lfiniteD
thf(fact_216_lfinite__conv__llength__enat,axiom,
! [A: $tType] :
( ( coindu1213758845finite @ A )
= ( ^ [Xs2: coindu1593790203_llist @ A] :
? [N3: nat] :
( ( coindu1018505716length @ A @ Xs2 )
= ( extended_enat2 @ N3 ) ) ) ) ).
% lfinite_conv_llength_enat
thf(fact_217_zero__enat__def,axiom,
( ( zero_zero @ extended_enat )
= ( extended_enat2 @ ( zero_zero @ nat ) ) ) ).
% zero_enat_def
thf(fact_218_enat__0__iff_I1_J,axiom,
! [X: nat] :
( ( ( extended_enat2 @ X )
= ( zero_zero @ extended_enat ) )
= ( X
= ( zero_zero @ nat ) ) ) ).
% enat_0_iff(1)
thf(fact_219_enat__0__iff_I2_J,axiom,
! [X: nat] :
( ( ( zero_zero @ extended_enat )
= ( extended_enat2 @ X ) )
= ( X
= ( zero_zero @ nat ) ) ) ).
% enat_0_iff(2)
thf(fact_220_semiring__normalization__rules_I25_J,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A @ ( type2 @ A ) )
=> ! [A2: A,C: A,D: A] :
( ( plus_plus @ A @ A2 @ ( plus_plus @ A @ C @ D ) )
= ( plus_plus @ A @ ( plus_plus @ A @ A2 @ C ) @ D ) ) ) ).
% semiring_normalization_rules(25)
thf(fact_221_semiring__normalization__rules_I24_J,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A @ ( type2 @ A ) )
=> ( ( plus_plus @ A )
= ( ^ [A4: A,C2: A] : ( plus_plus @ A @ C2 @ A4 ) ) ) ) ).
% semiring_normalization_rules(24)
thf(fact_222_semiring__normalization__rules_I23_J,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A] :
( ( plus_plus @ A @ ( plus_plus @ A @ A2 @ B2 ) @ C )
= ( plus_plus @ A @ ( plus_plus @ A @ A2 @ C ) @ B2 ) ) ) ).
% semiring_normalization_rules(23)
thf(fact_223_semiring__normalization__rules_I22_J,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A @ ( type2 @ A ) )
=> ! [A2: A,C: A,D: A] :
( ( plus_plus @ A @ A2 @ ( plus_plus @ A @ C @ D ) )
= ( plus_plus @ A @ C @ ( plus_plus @ A @ A2 @ D ) ) ) ) ).
% semiring_normalization_rules(22)
thf(fact_224_semiring__normalization__rules_I21_J,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A] :
( ( plus_plus @ A @ ( plus_plus @ A @ A2 @ B2 ) @ C )
= ( plus_plus @ A @ A2 @ ( plus_plus @ A @ B2 @ C ) ) ) ) ).
% semiring_normalization_rules(21)
thf(fact_225_semiring__normalization__rules_I20_J,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A @ ( type2 @ A ) )
=> ! [A2: A,B2: A,C: A,D: A] :
( ( plus_plus @ A @ ( plus_plus @ A @ A2 @ B2 ) @ ( plus_plus @ A @ C @ D ) )
= ( plus_plus @ A @ ( plus_plus @ A @ A2 @ C ) @ ( plus_plus @ A @ B2 @ D ) ) ) ) ).
% semiring_normalization_rules(20)
thf(fact_226_setsum_Ocong,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [A3: set @ B,B4: set @ B,G: B > A,H: B > A] :
( ( A3 = B4 )
=> ( ! [X4: B] :
( ( member @ B @ X4 @ B4 )
=> ( ( G @ X4 )
= ( H @ X4 ) ) )
=> ( ( groups15040474setsum @ B @ A @ G @ A3 )
= ( groups15040474setsum @ B @ A @ H @ B4 ) ) ) ) ) ).
% setsum.cong
thf(fact_227_setsum_Oreindex__bij__witness,axiom,
! [B: $tType,A: $tType,C3: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [S2: set @ B,I2: C3 > B,J: B > C3,T2: set @ C3,H: C3 > A,G: B > A] :
( ! [A5: B] :
( ( member @ B @ A5 @ S2 )
=> ( ( I2 @ ( J @ A5 ) )
= A5 ) )
=> ( ! [A5: B] :
( ( member @ B @ A5 @ S2 )
=> ( member @ C3 @ ( J @ A5 ) @ T2 ) )
=> ( ! [B5: C3] :
( ( member @ C3 @ B5 @ T2 )
=> ( ( J @ ( I2 @ B5 ) )
= B5 ) )
=> ( ! [B5: C3] :
( ( member @ C3 @ B5 @ T2 )
=> ( member @ B @ ( I2 @ B5 ) @ S2 ) )
=> ( ! [A5: B] :
( ( member @ B @ A5 @ S2 )
=> ( ( H @ ( J @ A5 ) )
= ( G @ A5 ) ) )
=> ( ( groups15040474setsum @ B @ A @ G @ S2 )
= ( groups15040474setsum @ C3 @ A @ H @ T2 ) ) ) ) ) ) ) ) ).
% setsum.reindex_bij_witness
thf(fact_228_setsum_Ocommute,axiom,
! [A: $tType,B: $tType,C3: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [G: B > C3 > A,B4: set @ C3,A3: set @ B] :
( ( groups15040474setsum @ B @ A
@ ^ [I: B] : ( groups15040474setsum @ C3 @ A @ ( G @ I ) @ B4 )
@ A3 )
= ( groups15040474setsum @ C3 @ A
@ ^ [J4: C3] :
( groups15040474setsum @ B @ A
@ ^ [I: B] : ( G @ I @ J4 )
@ A3 )
@ B4 ) ) ) ).
% setsum.commute
thf(fact_229_setsum__lessThan__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A @ ( type2 @ A ) )
=> ! [F: nat > A,N2: nat] :
( ( groups15040474setsum @ nat @ A @ F @ ( set_ord_lessThan @ nat @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( F @ ( zero_zero @ nat ) )
@ ( groups15040474setsum @ nat @ A
@ ^ [I: nat] : ( F @ ( suc @ I ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ).
% setsum_lessThan_Suc_shift
thf(fact_230_semiring__normalization__rules_I6_J,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A @ ( type2 @ A ) )
=> ! [A2: A] :
( ( plus_plus @ A @ A2 @ ( zero_zero @ A ) )
= A2 ) ) ).
% semiring_normalization_rules(6)
thf(fact_231_semiring__normalization__rules_I5_J,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A @ ( type2 @ A ) )
=> ! [A2: A] :
( ( plus_plus @ A @ ( zero_zero @ A ) @ A2 )
= A2 ) ) ).
% semiring_normalization_rules(5)
thf(fact_232_concat__xss_H,axiom,
coindu335574135_lnull @ a @ ( coindu441856546concat @ a @ ( coindu1079202755ist_of @ ( coindu1593790203_llist @ a ) @ xss2 ) ) ).
% concat_xss'
thf(fact_233_enat_Osize_I1_J,axiom,
! [Nat: nat] :
( ( extended_size_enat @ ( extended_enat2 @ Nat ) )
= ( zero_zero @ nat ) ) ).
% enat.size(1)
thf(fact_234_length__induct,axiom,
! [A: $tType,P: ( list @ A ) > $o,Xs3: list @ A] :
( ! [Xs: list @ A] :
( ! [Ys2: list @ A] :
( ( ord_less @ nat @ ( size_size @ ( list @ A ) @ Ys2 ) @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( P @ Ys2 ) )
=> ( P @ Xs ) )
=> ( P @ Xs3 ) ) ).
% length_induct
thf(fact_235_lnth__ldropn,axiom,
! [A: $tType,N2: nat,M2: nat,Xs3: coindu1593790203_llist @ A] :
( ( ord_less @ extended_enat @ ( extended_enat2 @ ( plus_plus @ nat @ N2 @ M2 ) ) @ ( coindu1018505716length @ A @ Xs3 ) )
=> ( ( coindu749330388e_lnth @ A @ ( coindu531130065ldropn @ A @ N2 @ Xs3 ) @ M2 )
= ( coindu749330388e_lnth @ A @ Xs3 @ ( plus_plus @ nat @ M2 @ N2 ) ) ) ) ).
% lnth_ldropn
thf(fact_236_llist__of__inject,axiom,
! [A: $tType,Xs3: list @ A,Ys: list @ A] :
( ( ( coindu1079202755ist_of @ A @ Xs3 )
= ( coindu1079202755ist_of @ A @ Ys ) )
= ( Xs3 = Ys ) ) ).
% llist_of_inject
thf(fact_237_ldropn__0,axiom,
! [A: $tType,Xs3: coindu1593790203_llist @ A] :
( ( coindu531130065ldropn @ A @ ( zero_zero @ nat ) @ Xs3 )
= Xs3 ) ).
% ldropn_0
thf(fact_238_ldropn__ldropn,axiom,
! [A: $tType,N2: nat,M2: nat,Xs3: coindu1593790203_llist @ A] :
( ( coindu531130065ldropn @ A @ N2 @ ( coindu531130065ldropn @ A @ M2 @ Xs3 ) )
= ( coindu531130065ldropn @ A @ ( plus_plus @ nat @ N2 @ M2 ) @ Xs3 ) ) ).
% ldropn_ldropn
thf(fact_239_ldropn__LNil,axiom,
! [A: $tType,N2: nat] :
( ( coindu531130065ldropn @ A @ N2 @ ( coindu1598213697e_LNil @ A ) )
= ( coindu1598213697e_LNil @ A ) ) ).
% ldropn_LNil
thf(fact_240_lfinite__ldropn,axiom,
! [A: $tType,N2: nat,Xs3: coindu1593790203_llist @ A] :
( ( coindu1213758845finite @ A @ ( coindu531130065ldropn @ A @ N2 @ Xs3 ) )
= ( coindu1213758845finite @ A @ Xs3 ) ) ).
% lfinite_ldropn
thf(fact_241_ldropn__Suc__LCons,axiom,
! [A: $tType,N2: nat,X: A,Xs3: coindu1593790203_llist @ A] :
( ( coindu531130065ldropn @ A @ ( suc @ N2 ) @ ( coindu1121789889_LCons @ A @ X @ Xs3 ) )
= ( coindu531130065ldropn @ A @ N2 @ Xs3 ) ) ).
% ldropn_Suc_LCons
thf(fact_242__092_060open_062m_A_061_A0_092_060close_062,axiom,
( m
= ( zero_zero @ nat ) ) ).
% \<open>m = 0\<close>
thf(fact_243_llength__llist__of,axiom,
! [A: $tType,Xs3: list @ A] :
( ( coindu1018505716length @ A @ ( coindu1079202755ist_of @ A @ Xs3 ) )
= ( extended_enat2 @ ( size_size @ ( list @ A ) @ Xs3 ) ) ) ).
% llength_llist_of
thf(fact_244_lfinite__llist__of,axiom,
! [A: $tType,Xs3: list @ A] : ( coindu1213758845finite @ A @ ( coindu1079202755ist_of @ A @ Xs3 ) ) ).
% lfinite_llist_of
thf(fact_245_ldropn__lnull,axiom,
! [A: $tType,Xs3: coindu1593790203_llist @ A,N2: nat] :
( ( coindu335574135_lnull @ A @ Xs3 )
=> ( ( coindu531130065ldropn @ A @ N2 @ Xs3 )
= ( coindu1598213697e_LNil @ A ) ) ) ).
% ldropn_lnull
thf(fact_246_Ex__list__of__length,axiom,
! [A: $tType,N2: nat] :
? [Xs: list @ A] :
( ( size_size @ ( list @ A ) @ Xs )
= N2 ) ).
% Ex_list_of_length
thf(fact_247_neq__if__length__neq,axiom,
! [A: $tType,Xs3: list @ A,Ys: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs3 )
!= ( size_size @ ( list @ A ) @ Ys ) )
=> ( Xs3 != Ys ) ) ).
% neq_if_length_neq
thf(fact_248_ldropn__eq__LConsD,axiom,
! [A: $tType,N2: nat,Xs3: coindu1593790203_llist @ A,Y: A,Ys: coindu1593790203_llist @ A] :
( ( ( coindu531130065ldropn @ A @ N2 @ Xs3 )
= ( coindu1121789889_LCons @ A @ Y @ Ys ) )
=> ( ord_less @ extended_enat @ ( extended_enat2 @ N2 ) @ ( coindu1018505716length @ A @ Xs3 ) ) ) ).
% ldropn_eq_LConsD
thf(fact_249_ldropn__Suc__conv__ldropn,axiom,
! [A: $tType,N2: nat,Xs3: coindu1593790203_llist @ A] :
( ( ord_less @ extended_enat @ ( extended_enat2 @ N2 ) @ ( coindu1018505716length @ A @ Xs3 ) )
=> ( ( coindu1121789889_LCons @ A @ ( coindu749330388e_lnth @ A @ Xs3 @ N2 ) @ ( coindu531130065ldropn @ A @ ( suc @ N2 ) @ Xs3 ) )
= ( coindu531130065ldropn @ A @ N2 @ Xs3 ) ) ) ).
% ldropn_Suc_conv_ldropn
%----Type constructors (41)
thf(tcon_fun___Orderings_Oorder,axiom,
! [A6: $tType,A7: $tType] :
( ( order @ A7 @ ( type2 @ A7 ) )
=> ( order @ ( A6 > A7 ) @ ( type2 @ ( A6 > A7 ) ) ) ) ).
thf(tcon_fun___Orderings_Oord,axiom,
! [A6: $tType,A7: $tType] :
( ( ord @ A7 @ ( type2 @ A7 ) )
=> ( ord @ ( A6 > A7 ) @ ( type2 @ ( A6 > A7 ) ) ) ) ).
thf(tcon_Nat_Onat___Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct,axiom,
semiri456707255roduct @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__monoid__add__imp__le,axiom,
ordere516151231imp_le @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Ostrict__ordered__ab__semigroup__add,axiom,
strict2144017051up_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Oordered__cancel__ab__semigroup__add,axiom,
ordere223160158up_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__add__imp__le,axiom,
ordere236663937imp_le @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Ostrict__ordered__comm__monoid__add,axiom,
strict797366125id_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Ocanonically__ordered__monoid__add,axiom,
canoni770627133id_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__add,axiom,
ordere779506340up_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Oordered__comm__monoid__add,axiom,
ordere216010020id_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Ocancel__comm__monoid__add,axiom,
cancel1352612707id_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Ocancel__semigroup__add,axiom,
cancel_semigroup_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Oab__semigroup__add,axiom,
ab_semigroup_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Ocomm__monoid__add,axiom,
comm_monoid_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Rings_Ocomm__semiring__1,axiom,
comm_semiring_1 @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Osemigroup__add,axiom,
semigroup_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Orderings_Olinorder,axiom,
linorder @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Omonoid__add,axiom,
monoid_add @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Orderings_Oorder_1,axiom,
order @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Orderings_Oord_2,axiom,
ord @ nat @ ( type2 @ nat ) ).
thf(tcon_Nat_Onat___Groups_Ozero,axiom,
zero @ nat @ ( type2 @ nat ) ).
thf(tcon_Set_Oset___Orderings_Oorder_3,axiom,
! [A6: $tType] : ( order @ ( set @ A6 ) @ ( type2 @ ( set @ A6 ) ) ) ).
thf(tcon_Set_Oset___Orderings_Oord_4,axiom,
! [A6: $tType] : ( ord @ ( set @ A6 ) @ ( type2 @ ( set @ A6 ) ) ) ).
thf(tcon_HOL_Obool___Orderings_Olinorder_5,axiom,
linorder @ $o @ ( type2 @ $o ) ).
thf(tcon_HOL_Obool___Orderings_Oorder_6,axiom,
order @ $o @ ( type2 @ $o ) ).
thf(tcon_HOL_Obool___Orderings_Oord_7,axiom,
ord @ $o @ ( type2 @ $o ) ).
thf(tcon_Extended__Nat_Oenat___Groups_Ostrict__ordered__ab__semigroup__add_8,axiom,
strict2144017051up_add @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Groups_Ostrict__ordered__comm__monoid__add_9,axiom,
strict797366125id_add @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Groups_Ocanonically__ordered__monoid__add_10,axiom,
canoni770627133id_add @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Groups_Oordered__ab__semigroup__add_11,axiom,
ordere779506340up_add @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Groups_Oordered__comm__monoid__add_12,axiom,
ordere216010020id_add @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Groups_Oab__semigroup__add_13,axiom,
ab_semigroup_add @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Groups_Ocomm__monoid__add_14,axiom,
comm_monoid_add @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Rings_Ocomm__semiring__1_15,axiom,
comm_semiring_1 @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Groups_Osemigroup__add_16,axiom,
semigroup_add @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Orderings_Olinorder_17,axiom,
linorder @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Groups_Omonoid__add_18,axiom,
monoid_add @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Orderings_Oorder_19,axiom,
order @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Orderings_Oord_20,axiom,
ord @ extended_enat @ ( type2 @ extended_enat ) ).
thf(tcon_Extended__Nat_Oenat___Groups_Ozero_21,axiom,
zero @ extended_enat @ ( type2 @ extended_enat ) ).
%----Conjectures (1)
thf(conj_0,conjecture,
? [M5: nat,N6: nat] :
( ( ( coindu749330388e_lnth @ a @ ( coindu441856546concat @ a @ xssa ) @ ( suc @ na ) )
= ( coindu749330388e_lnth @ a @ ( coindu749330388e_lnth @ ( coindu1593790203_llist @ a ) @ xssa @ M5 ) @ N6 ) )
& ( ord_less @ extended_enat @ ( extended_enat2 @ N6 ) @ ( coindu1018505716length @ a @ ( coindu749330388e_lnth @ ( coindu1593790203_llist @ a ) @ xssa @ M5 ) ) )
& ( ord_less @ extended_enat @ ( extended_enat2 @ M5 ) @ ( coindu1018505716length @ ( coindu1593790203_llist @ a ) @ xssa ) )
& ( ( extended_enat2 @ ( suc @ na ) )
= ( plus_plus @ extended_enat
@ ( groups15040474setsum @ nat @ extended_enat
@ ^ [I: nat] : ( coindu1018505716length @ a @ ( coindu749330388e_lnth @ ( coindu1593790203_llist @ a ) @ xssa @ I ) )
@ ( set_ord_lessThan @ nat @ M5 ) )
@ ( extended_enat2 @ N6 ) ) ) ) ).
%------------------------------------------------------------------------------