TPTP Problem File: ITP233^2.p
View Solutions
- Solve Problem
%------------------------------------------------------------------------------
% File : ITP233^2 : TPTP v9.2.1. Bugfixed v9.2.1.
% Domain : Interactive Theorem Proving
% Problem : Sledgehammer problem VEBT_InsertCorrectness 00603_038671
% Version : [Des22] axioms.
% English :
% Refs : [BH+15] Blanchette et al. (2015), Mining the Archive of Formal
% : [Des22] Desharnais (2022), Email to Geoff Sutcliffe
% Source : [Des22]
% Names : 0067_VEBT_InsertCorrectness_00603_038671 [Des22]
% Status : Theorem
% Rating : ? v9.2.1
% Syntax : Number of formulae : 9557 (2665 unt; 742 typ; 0 def)
% Number of atoms : 29379 (9886 equ; 5 cnn)
% Maximal formula atoms : 71 ( 3 avg)
% Number of connectives : 180334 (2661 ~; 391 |;2475 &;160934 @)
% ( 0 <=>;13873 =>; 0 <=; 0 <~>)
% Maximal formula depth : 40 ( 8 avg)
% Number of types : 10 ( 9 usr)
% Number of type conns : 5360 (5360 >; 0 *; 0 +; 0 <<)
% Number of symbols : 737 ( 733 usr; 20 con; 0-9 aty)
% Number of variables : 32778 (2908 ^;28118 !; 977 ?;32778 :)
% ( 775 !>; 0 ?*; 0 @-; 0 @+)
% SPC : TH1_THM_EQU_NAR
% Comments : This file was generated by Isabelle (most likely Sledgehammer)
% from the van Emde Boas Trees session in the Archive of Formal
% proofs -
% www.isa-afp.org/browser_info/current/AFP/Van_Emde_Boas_Trees
% 2022-02-17 21:14:46.789
% Bugfixes : Added ()s around negated sides of equations.
%------------------------------------------------------------------------------
% Could-be-implicit typings (16)
thf(ty_t_VEBT__Definitions_OVEBT,type,
vEBT_VEBT: $tType ).
thf(ty_t_Product__Type_Ounit,type,
product_unit: $tType ).
thf(ty_t_Product__Type_Oprod,type,
product_prod: $tType > $tType > $tType ).
thf(ty_t_Extended__Nat_Oenat,type,
extended_enat: $tType ).
thf(ty_t_Complex_Ocomplex,type,
complex: $tType ).
thf(ty_t_Sum__Type_Osum,type,
sum_sum: $tType > $tType > $tType ).
thf(ty_t_Option_Ooption,type,
option: $tType > $tType ).
thf(ty_t_Filter_Ofilter,type,
filter: $tType > $tType ).
thf(ty_t_String_Ochar,type,
char: $tType ).
thf(ty_t_Real_Oreal,type,
real: $tType ).
thf(ty_t_List_Olist,type,
list: $tType > $tType ).
thf(ty_t_Set_Oset,type,
set: $tType > $tType ).
thf(ty_t_Num_Onum,type,
num: $tType ).
thf(ty_t_Nat_Onat,type,
nat: $tType ).
thf(ty_t_Int_Oint,type,
int: $tType ).
thf(ty_t_itself,type,
itself: $tType > $tType ).
% Explicit typings (726)
thf(sy_cl_HOL_Otype,type,
type:
!>[A: $tType] : $o ).
thf(sy_cl_Nat_Osize,type,
size:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Odvd,type,
dvd:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oone,type,
one:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oidom,type,
idom:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oring,type,
ring:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oplus,type,
plus:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ozero,type,
zero:
!>[A: $tType] : $o ).
thf(sy_cl_Num_Onumeral,type,
numeral:
!>[A: $tType] : $o ).
thf(sy_cl_Power_Opower,type,
power:
!>[A: $tType] : $o ).
thf(sy_cl_Fields_Ofield,type,
field:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ominus,type,
minus:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oabs__if,type,
abs_if:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oring__1,type,
ring_1:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ouminus,type,
uminus:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Obot,type,
bot:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Oord,type,
ord:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Osemidom,type,
semidom:
!>[A: $tType] : $o ).
thf(sy_cl_Fields_Oinverse,type,
inverse:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Osemiring,type,
semiring:
!>[A: $tType] : $o ).
thf(sy_cl_Nat_Oring__char__0,type,
ring_char_0:
!>[A: $tType] : $o ).
thf(sy_cl_Num_Oneg__numeral,type,
neg_numeral:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Oorder,type,
order:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Ocomm__ring,type,
comm_ring:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Omult__zero,type,
mult_zero:
!>[A: $tType] : $o ).
thf(sy_cl_GCD_Osemiring__Gcd,type,
semiring_Gcd:
!>[A: $tType] : $o ).
thf(sy_cl_GCD_Osemiring__gcd,type,
semiring_gcd:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ogroup__add,type,
group_add:
!>[A: $tType] : $o ).
thf(sy_cl_Lattices_Olattice,type,
lattice:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Ono__bot,type,
no_bot:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Ono__top,type,
no_top:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Osemiring__0,type,
semiring_0:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Osemiring__1,type,
semiring_1:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Omonoid__add,type,
monoid_add:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Ocomm__ring__1,type,
comm_ring_1:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oidom__divide,type,
idom_divide:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oidom__modulo,type,
idom_modulo:
!>[A: $tType] : $o ).
thf(sy_cl_Transcendental_Oln,type,
ln:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Omonoid__mult,type,
monoid_mult:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Olinorder,type,
linorder:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Opreorder,type,
preorder:
!>[A: $tType] : $o ).
thf(sy_cl_Parity_Oring__parity,type,
ring_parity:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oidom__abs__sgn,type,
idom_abs_sgn:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oordered__ring,type,
ordered_ring:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Ozero__neq__one,type,
zero_neq_one:
!>[A: $tType] : $o ).
thf(sy_cl_Enum_Ofinite__lattice,type,
finite_lattice:
!>[A: $tType] : $o ).
thf(sy_cl_Fields_Ofield__char__0,type,
field_char_0:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oab__group__add,type,
ab_group_add:
!>[A: $tType] : $o ).
thf(sy_cl_Nat_Osemiring__char__0,type,
semiring_char_0:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Oorder__bot,type,
order_bot:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Oorder__top,type,
order_top:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Owellorder,type,
wellorder:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Ocomm__semiring,type,
comm_semiring:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Ozero__less__one,type,
zero_less_one:
!>[A: $tType] : $o ).
thf(sy_cl_Fields_Odivision__ring,type,
division_ring:
!>[A: $tType] : $o ).
thf(sy_cl_Fields_Ofield__abs__sgn,type,
field_abs_sgn:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Osemigroup__add,type,
semigroup_add:
!>[A: $tType] : $o ).
thf(sy_cl_Num_Osemiring__numeral,type,
semiring_numeral:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Osemidom__divide,type,
semidom_divide:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Osemidom__modulo,type,
semidom_modulo:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Osemigroup__mult,type,
semigroup_mult:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Odense__order,type,
dense_order:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Ocomm__semiring__0,type,
comm_semiring_0:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Ocomm__semiring__1,type,
comm_semiring_1:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Olinordered__idom,type,
linordered_idom:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Olinordered__ring,type,
linordered_ring:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Osemiring__modulo,type,
semiring_modulo:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ocomm__monoid__add,type,
comm_monoid_add:
!>[A: $tType] : $o ).
thf(sy_cl_Parity_Osemiring__parity,type,
semiring_parity:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oordered__ring__abs,type,
ordered_ring_abs:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oordered__semiring,type,
ordered_semiring:
!>[A: $tType] : $o ).
thf(sy_cl_Fields_Olinordered__field,type,
linordered_field:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oab__semigroup__add,type,
ab_semigroup_add:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ocomm__monoid__diff,type,
comm_monoid_diff:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ocomm__monoid__mult,type,
comm_monoid_mult:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oalgebraic__semidom,type,
algebraic_semidom:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Osemiring__1__cancel,type,
semiring_1_cancel:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oab__semigroup__mult,type,
ab_semigroup_mult:
!>[A: $tType] : $o ).
thf(sy_cl_Lattices_Obounded__lattice,type,
bounded_lattice:
!>[A: $tType] : $o ).
thf(sy_cl_Lattices_Odistrib__lattice,type,
distrib_lattice:
!>[A: $tType] : $o ).
thf(sy_cl_Lattices_Osemilattice__inf,type,
semilattice_inf:
!>[A: $tType] : $o ).
thf(sy_cl_Lattices_Osemilattice__sup,type,
semilattice_sup:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Odense__linorder,type,
dense_linorder:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Olinordered__semidom,type,
linordered_semidom:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oordered__semiring__0,type,
ordered_semiring_0:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Obanach,type,
real_Vector_banach:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Olinordered__semiring,type,
linordered_semiring:
!>[A: $tType] : $o ).
thf(sy_cl_Complete__Partial__Order_Occpo,type,
comple9053668089753744459l_ccpo:
!>[A: $tType] : $o ).
thf(sy_cl_Enum_Ofinite__distrib__lattice,type,
finite8700451911770168679attice:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ocancel__semigroup__add,type,
cancel_semigroup_add:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oordered__ab__group__add,type,
ordered_ab_group_add:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Olinordered__semiring__1,type,
linord6961819062388156250ring_1:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oordered__comm__semiring,type,
ordere2520102378445227354miring:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Ot1__space,type,
topological_t1_space:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Ot2__space,type,
topological_t2_space:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Ot3__space,type,
topological_t3_space:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Ot4__space,type,
topological_t4_space:
!>[A: $tType] : $o ).
thf(sy_cl_Bit__Operations_Osemiring__bits,type,
bit_semiring_bits:
!>[A: $tType] : $o ).
thf(sy_cl_Lattices_Obounded__lattice__bot,type,
bounded_lattice_bot:
!>[A: $tType] : $o ).
thf(sy_cl_Lattices_Obounded__lattice__top,type,
bounded_lattice_top:
!>[A: $tType] : $o ).
thf(sy_cl_Limits_Otopological__group__add,type,
topolo1633459387980952147up_add:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Ocomm__semiring__1__cancel,type,
comm_s4317794764714335236cancel:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Olinordered__ring__strict,type,
linord4710134922213307826strict:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ocancel__comm__monoid__add,type,
cancel1802427076303600483id_add:
!>[A: $tType] : $o ).
thf(sy_cl_Limits_Otopological__monoid__add,type,
topolo6943815403480290642id_add:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Oreal__field,type,
real_V7773925162809079976_field:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Oring__1__no__zero__divisors,type,
ring_15535105094025558882visors:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ocancel__ab__semigroup__add,type,
cancel2418104881723323429up_add:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Olinordered__ab__group__add,type,
linord5086331880401160121up_add:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oordered__comm__monoid__add,type,
ordere6911136660526730532id_add:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Oreal__vector,type,
real_V4867850818363320053vector:
!>[A: $tType] : $o ).
thf(sy_cl_Archimedean__Field_Ofloor__ceiling,type,
archim2362893244070406136eiling:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oordered__ab__group__add__abs,type,
ordere166539214618696060dd_abs:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oordered__ab__semigroup__add,type,
ordere6658533253407199908up_add:
!>[A: $tType] : $o ).
thf(sy_cl_Limits_Otopological__ab__group__add,type,
topolo1287966508704411220up_add:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Ometric__space,type,
real_V7819770556892013058_space:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Osemiring__no__zero__divisors,type,
semiri3467727345109120633visors:
!>[A: $tType] : $o ).
thf(sy_cl_Boolean__Algebras_Oboolean__algebra,type,
boolea8198339166811842893lgebra:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Olinordered__semiring__strict,type,
linord8928482502909563296strict:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Operfect__space,type,
topolo8386298272705272623_space:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Ouniform__space,type,
topolo7287701948861334536_space:
!>[A: $tType] : $o ).
thf(sy_cl_Limits_Otopological__semigroup__mult,type,
topolo4211221413907600880p_mult:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Ocomplete__space,type,
real_V8037385150606011577_space:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Oreal__algebra__1,type,
real_V2191834092415804123ebra_1:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Olinordered__nonzero__semiring,type,
linord181362715937106298miring:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Osemiring__1__no__zero__divisors,type,
semiri2026040879449505780visors:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Oorder__topology,type,
topolo2564578578187576103pology:
!>[A: $tType] : $o ).
thf(sy_cl_Bit__Operations_Oring__bit__operations,type,
bit_ri3973907225187159222ations:
!>[A: $tType] : $o ).
thf(sy_cl_Complete__Lattices_Ocomplete__lattice,type,
comple6319245703460814977attice:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Olinordered__ab__semigroup__add,type,
linord4140545234300271783up_add:
!>[A: $tType] : $o ).
thf(sy_cl_Limits_Otopological__comm__monoid__add,type,
topolo5987344860129210374id_add:
!>[A: $tType] : $o ).
thf(sy_cl_Orderings_Ounbounded__dense__linorder,type,
unboun7993243217541854897norder:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Ouniformity__dist,type,
real_V768167426530841204y_dist:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Olinordered__semiring__1__strict,type,
linord715952674999750819strict:
!>[A: $tType] : $o ).
thf(sy_cl_Archimedean__Field_Oarchimedean__field,type,
archim462609752435547400_field:
!>[A: $tType] : $o ).
thf(sy_cl_Complete__Lattices_Ocomplete__linorder,type,
comple5582772986160207858norder:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Oreal__div__algebra,type,
real_V5047593784448816457lgebra:
!>[A: $tType] : $o ).
thf(sy_cl_Lattices_Obounded__semilattice__inf__top,type,
bounde4346867609351753570nf_top:
!>[A: $tType] : $o ).
thf(sy_cl_Lattices_Obounded__semilattice__sup__bot,type,
bounde4967611905675639751up_bot:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Oreal__normed__field,type,
real_V3459762299906320749_field:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Odiscrete__topology,type,
topolo8865339358273720382pology:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Olinorder__topology,type,
topolo1944317154257567458pology:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Otopological__space,type,
topolo4958980785337419405_space:
!>[A: $tType] : $o ).
thf(sy_cl_Euclidean__Division_Oeuclidean__semiring,type,
euclid3725896446679973847miring:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ocanonically__ordered__monoid__add,type,
canoni5634975068530333245id_add:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oordered__cancel__comm__monoid__add,type,
ordere8940638589300402666id_add:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ostrict__ordered__comm__monoid__add,type,
strict7427464778891057005id_add:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Oreal__normed__vector,type,
real_V822414075346904944vector:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Olinordered__comm__semiring__strict,type,
linord2810124833399127020strict:
!>[A: $tType] : $o ).
thf(sy_cl_Bit__Operations_Osemiring__bit__operations,type,
bit_se359711467146920520ations:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oordered__ab__semigroup__add__imp__le,type,
ordere2412721322843649153imp_le:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oordered__cancel__ab__semigroup__add,type,
ordere580206878836729694up_add:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oordered__cancel__comm__monoid__diff,type,
ordere1170586879665033532d_diff:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Ostrict__ordered__ab__semigroup__add,type,
strict9044650504122735259up_add:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Oordered__real__vector,type,
real_V5355595471888546746vector:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Oreal__normed__algebra,type,
real_V4412858255891104859lgebra:
!>[A: $tType] : $o ).
thf(sy_cl_Rings_Osemiring__no__zero__divisors__cancel,type,
semiri6575147826004484403cancel:
!>[A: $tType] : $o ).
thf(sy_cl_Euclidean__Division_Oeuclidean__ring__cancel,type,
euclid8851590272496341667cancel:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Oreal__normed__algebra__1,type,
real_V2822296259951069270ebra_1:
!>[A: $tType] : $o ).
thf(sy_cl_Divides_Ounique__euclidean__semiring__numeral,type,
unique1627219031080169319umeral:
!>[A: $tType] : $o ).
thf(sy_cl_Complete__Lattices_Ocomplete__distrib__lattice,type,
comple592849572758109894attice:
!>[A: $tType] : $o ).
thf(sy_cl_Real__Vector__Spaces_Oreal__normed__div__algebra,type,
real_V8999393235501362500lgebra:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Ofirst__countable__topology,type,
topolo3112930676232923870pology:
!>[A: $tType] : $o ).
thf(sy_cl_Euclidean__Division_Oeuclidean__semiring__cancel,type,
euclid4440199948858584721cancel:
!>[A: $tType] : $o ).
thf(sy_cl_Euclidean__Division_Ounique__euclidean__semiring,type,
euclid3128863361964157862miring:
!>[A: $tType] : $o ).
thf(sy_cl_Topological__Spaces_Olinear__continuum__topology,type,
topolo8458572112393995274pology:
!>[A: $tType] : $o ).
thf(sy_cl_Groups_Oordered__ab__semigroup__monoid__add__imp__le,type,
ordere1937475149494474687imp_le:
!>[A: $tType] : $o ).
thf(sy_cl_Conditionally__Complete__Lattices_Olinear__continuum,type,
condit5016429287641298734tinuum:
!>[A: $tType] : $o ).
thf(sy_cl_Euclidean__Division_Ounique__euclidean__semiring__with__nat,type,
euclid5411537665997757685th_nat:
!>[A: $tType] : $o ).
thf(sy_cl_Countable__Complete__Lattices_Ocountable__complete__lattice,type,
counta3822494911875563373attice:
!>[A: $tType] : $o ).
thf(sy_cl_Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct,type,
semiri1453513574482234551roduct:
!>[A: $tType] : $o ).
thf(sy_cl_Bit__Operations_Ounique__euclidean__semiring__with__bit__operations,type,
bit_un5681908812861735899ations:
!>[A: $tType] : $o ).
thf(sy_cl_Conditionally__Complete__Lattices_Oconditionally__complete__lattice,type,
condit1219197933456340205attice:
!>[A: $tType] : $o ).
thf(sy_cl_Countable__Complete__Lattices_Ocountable__complete__distrib__lattice,type,
counta4013691401010221786attice:
!>[A: $tType] : $o ).
thf(sy_cl_Conditionally__Complete__Lattices_Oconditionally__complete__linorder,type,
condit6923001295902523014norder:
!>[A: $tType] : $o ).
thf(sy_c_Archimedean__Field_Oceiling,type,
archimedean_ceiling:
!>[A: $tType] : ( A > int ) ).
thf(sy_c_Archimedean__Field_Ofloor__ceiling__class_Ofloor,type,
archim6421214686448440834_floor:
!>[A: $tType] : ( A > int ) ).
thf(sy_c_Archimedean__Field_Ofrac,type,
archimedean_frac:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Archimedean__Field_Oround,type,
archimedean_round:
!>[A: $tType] : ( A > int ) ).
thf(sy_c_BNF__Cardinal__Arithmetic_Ocexp,type,
bNF_Cardinal_cexp:
!>[B: $tType,A: $tType] : ( ( set @ ( product_prod @ B @ B ) ) > ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ ( A > B ) @ ( A > B ) ) ) ) ).
thf(sy_c_BNF__Cardinal__Arithmetic_Ocinfinite,type,
bNF_Ca4139267488887388095finite:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_BNF__Cardinal__Arithmetic_Oczero,type,
bNF_Cardinal_czero:
!>[A: $tType] : ( set @ ( product_prod @ A @ A ) ) ).
thf(sy_c_BNF__Cardinal__Order__Relation_OcardSuc,type,
bNF_Ca8387033319878233205ardSuc:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) ) ) ).
thf(sy_c_BNF__Cardinal__Order__Relation_Ocard__of,type,
bNF_Ca6860139660246222851ard_of:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_BNF__Cardinal__Order__Relation_Ocard__order__on,type,
bNF_Ca8970107618336181345der_on:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_BNF__Cardinal__Order__Relation_Ocofinal,type,
bNF_Ca7293521722713021262ofinal:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_BNF__Cardinal__Order__Relation_OnatLeq,type,
bNF_Ca8665028551170535155natLeq: set @ ( product_prod @ nat @ nat ) ).
thf(sy_c_BNF__Cardinal__Order__Relation_OnatLess,type,
bNF_Ca8459412986667044542atLess: set @ ( product_prod @ nat @ nat ) ).
thf(sy_c_BNF__Cardinal__Order__Relation_OregularCard,type,
bNF_Ca7133664381575040944arCard:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_BNF__Cardinal__Order__Relation_OrelChain,type,
bNF_Ca3754400796208372196lChain:
!>[A: $tType,B: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( A > B ) > $o ) ).
thf(sy_c_BNF__Def_OGr,type,
bNF_Gr:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > B ) > ( set @ ( product_prod @ A @ B ) ) ) ).
thf(sy_c_BNF__Def_Orel__fun,type,
bNF_rel_fun:
!>[A: $tType,C: $tType,B: $tType,D: $tType] : ( ( A > C > $o ) > ( B > D > $o ) > ( A > B ) > ( C > D ) > $o ) ).
thf(sy_c_BNF__Greatest__Fixpoint_Oimage2,type,
bNF_Greatest_image2:
!>[C: $tType,A: $tType,B: $tType] : ( ( set @ C ) > ( C > A ) > ( C > B ) > ( set @ ( product_prod @ A @ B ) ) ) ).
thf(sy_c_BNF__Greatest__Fixpoint_OrelImage,type,
bNF_Gr4221423524335903396lImage:
!>[B: $tType,A: $tType] : ( ( set @ ( product_prod @ B @ B ) ) > ( B > A ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_BNF__Greatest__Fixpoint_OrelInvImage,type,
bNF_Gr7122648621184425601vImage:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ B @ B ) ) > ( A > B ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_BNF__Greatest__Fixpoint_OtoCard__pred,type,
bNF_Gr1419584066657907630d_pred:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ B @ B ) ) > ( A > B ) > $o ) ).
thf(sy_c_BNF__Wellorder__Constructions_OFunc,type,
bNF_Wellorder_Func:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( set @ B ) > ( set @ ( A > B ) ) ) ).
thf(sy_c_BNF__Wellorder__Constructions_OFunc__map,type,
bNF_We4925052301507509544nc_map:
!>[B: $tType,C: $tType,A: $tType,D: $tType] : ( ( set @ B ) > ( C > A ) > ( B > D ) > ( D > C ) > B > A ) ).
thf(sy_c_BNF__Wellorder__Constructions_Obsqr,type,
bNF_Wellorder_bsqr:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ ( product_prod @ A @ A ) @ ( product_prod @ A @ A ) ) ) ) ).
thf(sy_c_BNF__Wellorder__Constructions_OordIso,type,
bNF_Wellorder_ordIso:
!>[A: $tType,A2: $tType] : ( set @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A2 @ A2 ) ) ) ) ).
thf(sy_c_BNF__Wellorder__Constructions_OordLeq,type,
bNF_Wellorder_ordLeq:
!>[A: $tType,A2: $tType] : ( set @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A2 @ A2 ) ) ) ) ).
thf(sy_c_BNF__Wellorder__Constructions_OordLess,type,
bNF_We4044943003108391690rdLess:
!>[A: $tType,A2: $tType] : ( set @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A2 @ A2 ) ) ) ) ).
thf(sy_c_BNF__Wellorder__Embedding_Oembed,type,
bNF_Wellorder_embed:
!>[A: $tType,A2: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ A2 @ A2 ) ) > ( A > A2 ) > $o ) ).
thf(sy_c_BNF__Wellorder__Relation_Owo__rel,type,
bNF_Wellorder_wo_rel:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_BNF__Wellorder__Relation_Owo__rel_OisMinim,type,
bNF_We4791949203932849705sMinim:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ A ) > A > $o ) ).
thf(sy_c_BNF__Wellorder__Relation_Owo__rel_Omax2,type,
bNF_We1388413361240627857o_max2:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > A > A > A ) ).
thf(sy_c_BNF__Wellorder__Relation_Owo__rel_Ominim,type,
bNF_We6954850376910717587_minim:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ A ) > A ) ).
thf(sy_c_BNF__Wellorder__Relation_Owo__rel_Osuc,type,
bNF_Wellorder_wo_suc:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ A ) > A ) ).
thf(sy_c_Basic__BNF__LFPs_Oprod_Osize__prod,type,
basic_BNF_size_prod:
!>[A: $tType,B: $tType] : ( ( A > nat ) > ( B > nat ) > ( product_prod @ A @ B ) > nat ) ).
thf(sy_c_Basic__BNFs_Ofsts,type,
basic_fsts:
!>[A: $tType,B: $tType] : ( ( product_prod @ A @ B ) > ( set @ A ) ) ).
thf(sy_c_Basic__BNFs_Osnds,type,
basic_snds:
!>[A: $tType,B: $tType] : ( ( product_prod @ A @ B ) > ( set @ B ) ) ).
thf(sy_c_Binomial_Obinomial,type,
binomial: nat > nat > nat ).
thf(sy_c_Binomial_Ogbinomial,type,
gbinomial:
!>[A: $tType] : ( A > nat > A ) ).
thf(sy_c_Bit__Operations_Oand__int__rel,type,
bit_and_int_rel: ( product_prod @ int @ int ) > ( product_prod @ int @ int ) > $o ).
thf(sy_c_Bit__Operations_Oconcat__bit,type,
bit_concat_bit: nat > int > int > int ).
thf(sy_c_Bit__Operations_Oring__bit__operations__class_Onot,type,
bit_ri4277139882892585799ns_not:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Bit__Operations_Oring__bit__operations__class_Osigned__take__bit,type,
bit_ri4674362597316999326ke_bit:
!>[A: $tType] : ( nat > A > A ) ).
thf(sy_c_Bit__Operations_Osemiring__bit__operations__class_Oand,type,
bit_se5824344872417868541ns_and:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Bit__Operations_Osemiring__bit__operations__class_Odrop__bit,type,
bit_se4197421643247451524op_bit:
!>[A: $tType] : ( nat > A > A ) ).
thf(sy_c_Bit__Operations_Osemiring__bit__operations__class_Oflip__bit,type,
bit_se8732182000553998342ip_bit:
!>[A: $tType] : ( nat > A > A ) ).
thf(sy_c_Bit__Operations_Osemiring__bit__operations__class_Omask,type,
bit_se2239418461657761734s_mask:
!>[A: $tType] : ( nat > A ) ).
thf(sy_c_Bit__Operations_Osemiring__bit__operations__class_Oor,type,
bit_se1065995026697491101ons_or:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Bit__Operations_Osemiring__bit__operations__class_Opush__bit,type,
bit_se4730199178511100633sh_bit:
!>[A: $tType] : ( nat > A > A ) ).
thf(sy_c_Bit__Operations_Osemiring__bit__operations__class_Oset__bit,type,
bit_se5668285175392031749et_bit:
!>[A: $tType] : ( nat > A > A ) ).
thf(sy_c_Bit__Operations_Osemiring__bit__operations__class_Otake__bit,type,
bit_se2584673776208193580ke_bit:
!>[A: $tType] : ( nat > A > A ) ).
thf(sy_c_Bit__Operations_Osemiring__bit__operations__class_Ounset__bit,type,
bit_se2638667681897837118et_bit:
!>[A: $tType] : ( nat > A > A ) ).
thf(sy_c_Bit__Operations_Osemiring__bit__operations__class_Oxor,type,
bit_se5824344971392196577ns_xor:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Bit__Operations_Osemiring__bits__class_Obit,type,
bit_se5641148757651400278ts_bit:
!>[A: $tType] : ( A > nat > $o ) ).
thf(sy_c_Bit__Operations_Osemiring__bits__class_Opossible__bit,type,
bit_se6407376104438227557le_bit:
!>[A: $tType] : ( ( itself @ A ) > nat > $o ) ).
thf(sy_c_Bit__Operations_Otake__bit__num,type,
bit_take_bit_num: nat > num > ( option @ num ) ).
thf(sy_c_Bit__Operations_Ounique__euclidean__semiring__with__bit__operations__class_Oand__num,type,
bit_un7362597486090784418nd_num: num > num > ( option @ num ) ).
thf(sy_c_Bit__Operations_Ounique__euclidean__semiring__with__bit__operations__class_Oxor__num,type,
bit_un2480387367778600638or_num: num > num > ( option @ num ) ).
thf(sy_c_Boolean__Algebras_Oabstract__boolean__algebra,type,
boolea2506097494486148201lgebra:
!>[A: $tType] : ( ( A > A > A ) > ( A > A > A ) > ( A > A ) > A > A > $o ) ).
thf(sy_c_Boolean__Algebras_Oabstract__boolean__algebra__sym__diff,type,
boolea3799213064322606851m_diff:
!>[A: $tType] : ( ( A > A > A ) > ( A > A > A ) > ( A > A ) > A > A > ( A > A > A ) > $o ) ).
thf(sy_c_Complete__Lattices_OInf__class_OInf,type,
complete_Inf_Inf:
!>[A: $tType] : ( ( set @ A ) > A ) ).
thf(sy_c_Complete__Lattices_OSup__class_OSup,type,
complete_Sup_Sup:
!>[A: $tType] : ( ( set @ A ) > A ) ).
thf(sy_c_Complete__Partial__Order_Occpo_Oadmissible,type,
comple1908693960933563346ssible:
!>[A: $tType] : ( ( ( set @ A ) > A ) > ( A > A > $o ) > ( A > $o ) > $o ) ).
thf(sy_c_Complete__Partial__Order_Occpo__class_Ofixp,type,
comple115746919287870866o_fixp:
!>[A: $tType] : ( ( A > A ) > A ) ).
thf(sy_c_Complete__Partial__Order_Occpo__class_Oiterates,type,
comple6359979572994053840erates:
!>[A: $tType] : ( ( A > A ) > ( set @ A ) ) ).
thf(sy_c_Complete__Partial__Order_Occpo__class_Oiteratesp,type,
comple7512665784863727008ratesp:
!>[A: $tType] : ( ( A > A ) > A > $o ) ).
thf(sy_c_Complete__Partial__Order_Ochain,type,
comple1602240252501008431_chain:
!>[A: $tType] : ( ( A > A > $o ) > ( set @ A ) > $o ) ).
thf(sy_c_Complete__Partial__Order_Omonotone,type,
comple7038119648293358887notone:
!>[A: $tType,B: $tType] : ( ( A > A > $o ) > ( B > B > $o ) > ( A > B ) > $o ) ).
thf(sy_c_Complex_OArg,type,
arg: complex > real ).
thf(sy_c_Complex_Ocis,type,
cis: real > complex ).
thf(sy_c_Conditionally__Complete__Lattices_Opreorder__class_Obdd__above,type,
condit941137186595557371_above:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Conditionally__Complete__Lattices_Opreorder__class_Obdd__below,type,
condit1013018076250108175_below:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Countable__Set_Ocountable,type,
countable_countable:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Countable__Set_Ofrom__nat__into,type,
counta4804993851260445106t_into:
!>[A: $tType] : ( ( set @ A ) > nat > A ) ).
thf(sy_c_Deriv_Odifferentiable,type,
differentiable:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( filter @ A ) > $o ) ).
thf(sy_c_Deriv_Ohas__derivative,type,
has_derivative:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( A > B ) > ( filter @ A ) > $o ) ).
thf(sy_c_Deriv_Ohas__field__derivative,type,
has_field_derivative:
!>[A: $tType] : ( ( A > A ) > A > ( filter @ A ) > $o ) ).
thf(sy_c_Deriv_Ohas__vector__derivative,type,
has_ve8173657378732805170vative:
!>[B: $tType] : ( ( real > B ) > B > ( filter @ real ) > $o ) ).
thf(sy_c_Divides_Odivmod__nat,type,
divmod_nat: nat > nat > ( product_prod @ nat @ nat ) ).
thf(sy_c_Divides_Ounique__euclidean__semiring__numeral__class_Odivides__aux,type,
unique5940410009612947441es_aux:
!>[A: $tType] : ( ( product_prod @ A @ A ) > $o ) ).
thf(sy_c_Divides_Ounique__euclidean__semiring__numeral__class_Odivmod,type,
unique8689654367752047608divmod:
!>[A: $tType] : ( num > num > ( product_prod @ A @ A ) ) ).
thf(sy_c_Divides_Ounique__euclidean__semiring__numeral__class_Odivmod__step,type,
unique1321980374590559556d_step:
!>[A: $tType] : ( num > ( product_prod @ A @ A ) > ( product_prod @ A @ A ) ) ).
thf(sy_c_Equiv__Relations_Ocongruent,type,
equiv_congruent:
!>[A: $tType,B: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( A > B ) > $o ) ).
thf(sy_c_Equiv__Relations_Ocongruent2,type,
equiv_congruent2:
!>[A: $tType,B: $tType,C: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ B @ B ) ) > ( A > B > C ) > $o ) ).
thf(sy_c_Equiv__Relations_Oequiv,type,
equiv_equiv:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Equiv__Relations_Oproj,type,
equiv_proj:
!>[B: $tType,A: $tType] : ( ( set @ ( product_prod @ B @ A ) ) > B > ( set @ A ) ) ).
thf(sy_c_Equiv__Relations_Oquotient,type,
equiv_quotient:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) > ( set @ ( set @ A ) ) ) ).
thf(sy_c_Euclidean__Division_Oeuclidean__semiring__class_Oeuclidean__size,type,
euclid6346220572633701492n_size:
!>[A: $tType] : ( A > nat ) ).
thf(sy_c_Euclidean__Division_Ounique__euclidean__semiring__class_Odivision__segment,type,
euclid7384307370059645450egment:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Extended__Nat_OeSuc,type,
extended_eSuc: extended_enat > extended_enat ).
thf(sy_c_Extended__Nat_Oenat,type,
extended_enat2: nat > extended_enat ).
thf(sy_c_Extended__Nat_Oenat_Ocase__enat,type,
extended_case_enat:
!>[T: $tType] : ( ( nat > T ) > T > extended_enat > T ) ).
thf(sy_c_Extended__Nat_Oinfinity__class_Oinfinity,type,
extend4730790105801354508finity:
!>[A: $tType] : A ).
thf(sy_c_Factorial_Ocomm__semiring__1__class_Opochhammer,type,
comm_s3205402744901411588hammer:
!>[A: $tType] : ( A > nat > A ) ).
thf(sy_c_Factorial_Osemiring__char__0__class_Ofact,type,
semiring_char_0_fact:
!>[A: $tType] : ( nat > A ) ).
thf(sy_c_Fields_Oinverse__class_Oinverse,type,
inverse_inverse:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Filter_Oat__bot,type,
at_bot:
!>[A: $tType] : ( filter @ A ) ).
thf(sy_c_Filter_Oat__top,type,
at_top:
!>[A: $tType] : ( filter @ A ) ).
thf(sy_c_Filter_Oeventually,type,
eventually:
!>[A: $tType] : ( ( A > $o ) > ( filter @ A ) > $o ) ).
thf(sy_c_Filter_Ofiltercomap,type,
filtercomap:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( filter @ B ) > ( filter @ A ) ) ).
thf(sy_c_Filter_Ofilterlim,type,
filterlim:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( filter @ B ) > ( filter @ A ) > $o ) ).
thf(sy_c_Filter_Ofiltermap,type,
filtermap:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( filter @ A ) > ( filter @ B ) ) ).
thf(sy_c_Filter_Ofinite__subsets__at__top,type,
finite5375528669736107172at_top:
!>[A: $tType] : ( ( set @ A ) > ( filter @ ( set @ A ) ) ) ).
thf(sy_c_Filter_Omap__filter__on,type,
map_filter_on:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > B ) > ( filter @ A ) > ( filter @ B ) ) ).
thf(sy_c_Filter_Oprincipal,type,
principal:
!>[A: $tType] : ( ( set @ A ) > ( filter @ A ) ) ).
thf(sy_c_Filter_Oprod__filter,type,
prod_filter:
!>[A: $tType,B: $tType] : ( ( filter @ A ) > ( filter @ B ) > ( filter @ ( product_prod @ A @ B ) ) ) ).
thf(sy_c_Finite__Set_OFpow,type,
finite_Fpow:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( set @ A ) ) ) ).
thf(sy_c_Finite__Set_Ocard,type,
finite_card:
!>[B: $tType] : ( ( set @ B ) > nat ) ).
thf(sy_c_Finite__Set_Ocomp__fun__commute,type,
finite6289374366891150609ommute:
!>[A: $tType,B: $tType] : ( ( A > B > B ) > $o ) ).
thf(sy_c_Finite__Set_Ocomp__fun__commute__on,type,
finite4664212375090638736ute_on:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > B > B ) > $o ) ).
thf(sy_c_Finite__Set_Ocomp__fun__idem__on,type,
finite673082921795544331dem_on:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > B > B ) > $o ) ).
thf(sy_c_Finite__Set_Ofinite,type,
finite_finite:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Finite__Set_Ofold,type,
finite_fold:
!>[A: $tType,B: $tType] : ( ( A > B > B ) > B > ( set @ A ) > B ) ).
thf(sy_c_Finite__Set_Ofold__graph,type,
finite_fold_graph:
!>[A: $tType,B: $tType] : ( ( A > B > B ) > B > ( set @ A ) > B > $o ) ).
thf(sy_c_Finite__Set_Ofolding__idem__on,type,
finite1890593828518410140dem_on:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > B > B ) > $o ) ).
thf(sy_c_Finite__Set_Ofolding__on,type,
finite_folding_on:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > B > B ) > $o ) ).
thf(sy_c_Finite__Set_Ofolding__on_OF,type,
finite_folding_F:
!>[A: $tType,B: $tType] : ( ( A > B > B ) > B > ( set @ A ) > B ) ).
thf(sy_c_Fun_Obij__betw,type,
bij_betw:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( set @ A ) > ( set @ B ) > $o ) ).
thf(sy_c_Fun_Ocomp,type,
comp:
!>[B: $tType,C: $tType,A: $tType] : ( ( B > C ) > ( A > B ) > A > C ) ).
thf(sy_c_Fun_Ofun__upd,type,
fun_upd:
!>[A: $tType,B: $tType] : ( ( A > B ) > A > B > A > B ) ).
thf(sy_c_Fun_Oid,type,
id:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Fun_Oinj__on,type,
inj_on:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( set @ A ) > $o ) ).
thf(sy_c_Fun_Omap__fun,type,
map_fun:
!>[C: $tType,A: $tType,B: $tType,D: $tType] : ( ( C > A ) > ( B > D ) > ( A > B ) > C > D ) ).
thf(sy_c_Fun_Ostrict__mono__on,type,
strict_mono_on:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( set @ A ) > $o ) ).
thf(sy_c_Fun_Othe__inv__into,type,
the_inv_into:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > B ) > B > A ) ).
thf(sy_c_Fun__Def_Opair__leq,type,
fun_pair_leq: set @ ( product_prod @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) ) ).
thf(sy_c_Fun__Def_Opair__less,type,
fun_pair_less: set @ ( product_prod @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) ) ).
thf(sy_c_GCD_OGcd__class_OGcd,type,
gcd_Gcd:
!>[A: $tType] : ( ( set @ A ) > A ) ).
thf(sy_c_GCD_Obezw,type,
bezw: nat > nat > ( product_prod @ int @ int ) ).
thf(sy_c_GCD_Obezw__rel,type,
bezw_rel: ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) > $o ).
thf(sy_c_GCD_Obounded__quasi__semilattice__set,type,
bounde6485984586167503788ce_set:
!>[A: $tType] : ( ( A > A > A ) > A > A > ( A > A ) > $o ) ).
thf(sy_c_GCD_Obounded__quasi__semilattice__set_OF,type,
bounde2362111253966948842tice_F:
!>[A: $tType] : ( ( A > A > A ) > A > A > ( set @ A ) > A ) ).
thf(sy_c_GCD_Ogcd__class_Ogcd,type,
gcd_gcd:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_GCD_Ogcd__nat__rel,type,
gcd_nat_rel: ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) > $o ).
thf(sy_c_GCD_Osemiring__1__class_Osemiring__char,type,
semiri4206861660011772517g_char:
!>[A: $tType] : ( ( itself @ A ) > nat ) ).
thf(sy_c_GCD_Osemiring__gcd__class_OGcd__fin,type,
semiring_gcd_Gcd_fin:
!>[A: $tType] : ( ( set @ A ) > A ) ).
thf(sy_c_Groups_Oabs__class_Oabs,type,
abs_abs:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Groups_Ominus__class_Ominus,type,
minus_minus:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Groups_Oone__class_Oone,type,
one_one:
!>[A: $tType] : A ).
thf(sy_c_Groups_Oplus__class_Oplus,type,
plus_plus:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Groups_Osgn__class_Osgn,type,
sgn_sgn:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Groups_Otimes__class_Otimes,type,
times_times:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Groups_Ouminus__class_Ouminus,type,
uminus_uminus:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Groups_Ozero__class_Ozero,type,
zero_zero:
!>[A: $tType] : A ).
thf(sy_c_Groups__Big_Ocomm__monoid__add__class_Osum,type,
groups7311177749621191930dd_sum:
!>[B: $tType,A: $tType] : ( ( B > A ) > ( set @ B ) > A ) ).
thf(sy_c_Groups__Big_Ocomm__monoid__add__class_Osum_H,type,
groups1027152243600224163dd_sum:
!>[C: $tType,A: $tType] : ( ( C > A ) > ( set @ C ) > A ) ).
thf(sy_c_Groups__Big_Ocomm__monoid__mult__class_Oprod,type,
groups7121269368397514597t_prod:
!>[B: $tType,A: $tType] : ( ( B > A ) > ( set @ B ) > A ) ).
thf(sy_c_Groups__List_Ocomm__semiring__0__class_Ohorner__sum,type,
groups4207007520872428315er_sum:
!>[B: $tType,A: $tType] : ( ( B > A ) > A > ( list @ B ) > A ) ).
thf(sy_c_Groups__List_Omonoid__add__class_Osum__list,type,
groups8242544230860333062m_list:
!>[A: $tType] : ( ( list @ A ) > A ) ).
thf(sy_c_Groups__List_Omonoid__mult__class_Oprod__list,type,
groups5270119922927024881d_list:
!>[A: $tType] : ( ( list @ A ) > A ) ).
thf(sy_c_HOL_ONO__MATCH,type,
nO_MATCH:
!>[A: $tType,B: $tType] : ( A > B > $o ) ).
thf(sy_c_HOL_OThe,type,
the:
!>[A: $tType] : ( ( A > $o ) > A ) ).
thf(sy_c_HOL_OUniq,type,
uniq:
!>[A: $tType] : ( ( A > $o ) > $o ) ).
thf(sy_c_HOL_Oundefined,type,
undefined:
!>[A: $tType] : A ).
thf(sy_c_Hilbert__Choice_Oinv__into,type,
hilbert_inv_into:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > B ) > B > A ) ).
thf(sy_c_If,type,
if:
!>[A: $tType] : ( $o > A > A > A ) ).
thf(sy_c_Inductive_Ocomplete__lattice__class_Ogfp,type,
complete_lattice_gfp:
!>[A: $tType] : ( ( A > A ) > A ) ).
thf(sy_c_Inductive_Ocomplete__lattice__class_Olfp,type,
complete_lattice_lfp:
!>[A: $tType] : ( ( A > A ) > A ) ).
thf(sy_c_Infinite__Set_Owellorder__class_Oenumerate,type,
infini527867602293511546merate:
!>[A: $tType] : ( ( set @ A ) > nat > A ) ).
thf(sy_c_Int_OAbs__Integ,type,
abs_Integ: ( product_prod @ nat @ nat ) > int ).
thf(sy_c_Int_ORep__Integ,type,
rep_Integ: int > ( product_prod @ nat @ nat ) ).
thf(sy_c_Int_Ocr__int,type,
cr_int: ( product_prod @ nat @ nat ) > int > $o ).
thf(sy_c_Int_Oint__ge__less__than,type,
int_ge_less_than: int > ( set @ ( product_prod @ int @ int ) ) ).
thf(sy_c_Int_Oint__ge__less__than2,type,
int_ge_less_than2: int > ( set @ ( product_prod @ int @ int ) ) ).
thf(sy_c_Int_Ointrel,type,
intrel: ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) > $o ).
thf(sy_c_Int_Onat,type,
nat2: int > nat ).
thf(sy_c_Int_Opcr__int,type,
pcr_int: ( product_prod @ nat @ nat ) > int > $o ).
thf(sy_c_Int_Opower__int,type,
power_int:
!>[A: $tType] : ( A > int > A ) ).
thf(sy_c_Int_Oring__1__class_OInts,type,
ring_1_Ints:
!>[A: $tType] : ( set @ A ) ).
thf(sy_c_Int_Oring__1__class_Oof__int,type,
ring_1_of_int:
!>[A: $tType] : ( int > A ) ).
thf(sy_c_Lattices_Oinf__class_Oinf,type,
inf_inf:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Lattices_Osemilattice__neutr__order,type,
semila1105856199041335345_order:
!>[A: $tType] : ( ( A > A > A ) > A > ( A > A > $o ) > ( A > A > $o ) > $o ) ).
thf(sy_c_Lattices_Osup__class_Osup,type,
sup_sup:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Lattices__Big_Olinorder_OMax,type,
lattices_Max:
!>[A: $tType] : ( ( A > A > $o ) > ( set @ A ) > A ) ).
thf(sy_c_Lattices__Big_Olinorder_OMin,type,
lattices_Min:
!>[A: $tType] : ( ( A > A > $o ) > ( set @ A ) > A ) ).
thf(sy_c_Lattices__Big_Olinorder__class_OMax,type,
lattic643756798349783984er_Max:
!>[A: $tType] : ( ( set @ A ) > A ) ).
thf(sy_c_Lattices__Big_Olinorder__class_OMin,type,
lattic643756798350308766er_Min:
!>[A: $tType] : ( ( set @ A ) > A ) ).
thf(sy_c_Lattices__Big_Oord__class_Oarg__min,type,
lattices_ord_arg_min:
!>[B: $tType,A: $tType] : ( ( B > A ) > ( B > $o ) > B ) ).
thf(sy_c_Lattices__Big_Oord__class_Oarg__min__on,type,
lattic7623131987881927897min_on:
!>[B: $tType,A: $tType] : ( ( B > A ) > ( set @ B ) > B ) ).
thf(sy_c_Lattices__Big_Oord__class_Ois__arg__min,type,
lattic501386751177426532rg_min:
!>[B: $tType,A: $tType] : ( ( B > A ) > ( B > $o ) > B > $o ) ).
thf(sy_c_Lattices__Big_Osemilattice__inf__class_OInf__fin,type,
lattic7752659483105999362nf_fin:
!>[A: $tType] : ( ( set @ A ) > A ) ).
thf(sy_c_Lattices__Big_Osemilattice__order__set,type,
lattic4895041142388067077er_set:
!>[A: $tType] : ( ( A > A > A ) > ( A > A > $o ) > ( A > A > $o ) > $o ) ).
thf(sy_c_Lattices__Big_Osemilattice__set,type,
lattic149705377957585745ce_set:
!>[A: $tType] : ( ( A > A > A ) > $o ) ).
thf(sy_c_Lattices__Big_Osemilattice__set_OF,type,
lattic1715443433743089157tice_F:
!>[A: $tType] : ( ( A > A > A ) > ( set @ A ) > A ) ).
thf(sy_c_Lattices__Big_Osemilattice__sup__class_OSup__fin,type,
lattic5882676163264333800up_fin:
!>[A: $tType] : ( ( set @ A ) > A ) ).
thf(sy_c_Lifting_OQuotient,type,
quotient:
!>[A: $tType,B: $tType] : ( ( A > A > $o ) > ( A > B ) > ( B > A ) > ( A > B > $o ) > $o ) ).
thf(sy_c_Limits_OBfun,type,
bfun:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( filter @ A ) > $o ) ).
thf(sy_c_Limits_Oat__infinity,type,
at_infinity:
!>[A: $tType] : ( filter @ A ) ).
thf(sy_c_List_OBleast,type,
bleast:
!>[A: $tType] : ( ( set @ A ) > ( A > $o ) > A ) ).
thf(sy_c_List_Oabort__Bleast,type,
abort_Bleast:
!>[A: $tType] : ( ( set @ A ) > ( A > $o ) > A ) ).
thf(sy_c_List_Oappend,type,
append:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Oarg__min__list,type,
arg_min_list:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( list @ A ) > A ) ).
thf(sy_c_List_Oarg__min__list__rel,type,
arg_min_list_rel:
!>[A: $tType,B: $tType] : ( ( product_prod @ ( A > B ) @ ( list @ A ) ) > ( product_prod @ ( A > B ) @ ( list @ A ) ) > $o ) ).
thf(sy_c_List_Obind,type,
bind:
!>[A: $tType,B: $tType] : ( ( list @ A ) > ( A > ( list @ B ) ) > ( list @ B ) ) ).
thf(sy_c_List_Obutlast,type,
butlast:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Ocan__select,type,
can_select:
!>[A: $tType] : ( ( A > $o ) > ( set @ A ) > $o ) ).
thf(sy_c_List_Oconcat,type,
concat:
!>[A: $tType] : ( ( list @ ( list @ A ) ) > ( list @ A ) ) ).
thf(sy_c_List_Ocoset,type,
coset:
!>[A: $tType] : ( ( list @ A ) > ( set @ A ) ) ).
thf(sy_c_List_Ocount__list,type,
count_list:
!>[A: $tType] : ( ( list @ A ) > A > nat ) ).
thf(sy_c_List_Odistinct,type,
distinct:
!>[A: $tType] : ( ( list @ A ) > $o ) ).
thf(sy_c_List_Odistinct__adj,type,
distinct_adj:
!>[A: $tType] : ( ( list @ A ) > $o ) ).
thf(sy_c_List_Odrop,type,
drop:
!>[A: $tType] : ( nat > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_OdropWhile,type,
dropWhile:
!>[A: $tType] : ( ( A > $o ) > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Oenumerate,type,
enumerate:
!>[A: $tType] : ( nat > ( list @ A ) > ( list @ ( product_prod @ nat @ A ) ) ) ).
thf(sy_c_List_Oextract,type,
extract:
!>[A: $tType] : ( ( A > $o ) > ( list @ A ) > ( option @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) ) ) ).
thf(sy_c_List_Ofilter,type,
filter2:
!>[A: $tType] : ( ( A > $o ) > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Ofind,type,
find:
!>[A: $tType] : ( ( A > $o ) > ( list @ A ) > ( option @ A ) ) ).
thf(sy_c_List_Ofold,type,
fold:
!>[A: $tType,B: $tType] : ( ( A > B > B ) > ( list @ A ) > B > B ) ).
thf(sy_c_List_Ofolding__insort__key,type,
folding_insort_key:
!>[A: $tType,B: $tType] : ( ( A > A > $o ) > ( A > A > $o ) > ( set @ B ) > ( B > A ) > $o ) ).
thf(sy_c_List_Ofoldl,type,
foldl:
!>[B: $tType,A: $tType] : ( ( B > A > B ) > B > ( list @ A ) > B ) ).
thf(sy_c_List_Ofoldr,type,
foldr:
!>[A: $tType,B: $tType] : ( ( A > B > B ) > ( list @ A ) > B > B ) ).
thf(sy_c_List_Ogen__length,type,
gen_length:
!>[A: $tType] : ( nat > ( list @ A ) > nat ) ).
thf(sy_c_List_Oinsert,type,
insert:
!>[A: $tType] : ( A > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Olast,type,
last:
!>[A: $tType] : ( ( list @ A ) > A ) ).
thf(sy_c_List_Olenlex,type,
lenlex:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) ) ).
thf(sy_c_List_Olex,type,
lex:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) ) ).
thf(sy_c_List_Olexn,type,
lexn:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > nat > ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) ) ).
thf(sy_c_List_Olexord,type,
lexord:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) ) ).
thf(sy_c_List_Olexordp,type,
lexordp:
!>[A: $tType] : ( ( A > A > $o ) > ( list @ A ) > ( list @ A ) > $o ) ).
thf(sy_c_List_Olinorder_Oinsort__key,type,
insort_key:
!>[A: $tType,B: $tType] : ( ( A > A > $o ) > ( B > A ) > B > ( list @ B ) > ( list @ B ) ) ).
thf(sy_c_List_Olinorder_Osorted__key__list__of__set,type,
sorted8670434370408473282of_set:
!>[A: $tType,B: $tType] : ( ( A > A > $o ) > ( B > A ) > ( set @ B ) > ( list @ B ) ) ).
thf(sy_c_List_Olinorder__class_Oinsort__insert__key,type,
linord329482645794927042rt_key:
!>[B: $tType,A: $tType] : ( ( B > A ) > B > ( list @ B ) > ( list @ B ) ) ).
thf(sy_c_List_Olinorder__class_Oinsort__key,type,
linorder_insort_key:
!>[B: $tType,A: $tType] : ( ( B > A ) > B > ( list @ B ) > ( list @ B ) ) ).
thf(sy_c_List_Olinorder__class_Osort__key,type,
linorder_sort_key:
!>[B: $tType,A: $tType] : ( ( B > A ) > ( list @ B ) > ( list @ B ) ) ).
thf(sy_c_List_Olinorder__class_Osorted__key__list__of__set,type,
linord144544945434240204of_set:
!>[B: $tType,A: $tType] : ( ( B > A ) > ( set @ B ) > ( list @ B ) ) ).
thf(sy_c_List_Olinorder__class_Osorted__list__of__set,type,
linord4507533701916653071of_set:
!>[A: $tType] : ( ( set @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Olinorder__class_Ostable__sort__key,type,
linord3483353639454293061rt_key:
!>[B: $tType,A: $tType] : ( ( ( B > A ) > ( list @ B ) > ( list @ B ) ) > $o ) ).
thf(sy_c_List_Olist_OCons,type,
cons:
!>[A: $tType] : ( A > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Olist_ONil,type,
nil:
!>[A: $tType] : ( list @ A ) ).
thf(sy_c_List_Olist_Ocase__list,type,
case_list:
!>[B: $tType,A: $tType] : ( B > ( A > ( list @ A ) > B ) > ( list @ A ) > B ) ).
thf(sy_c_List_Olist_Ohd,type,
hd:
!>[A: $tType] : ( ( list @ A ) > A ) ).
thf(sy_c_List_Olist_Olist__all,type,
list_all:
!>[A: $tType] : ( ( A > $o ) > ( list @ A ) > $o ) ).
thf(sy_c_List_Olist_Olist__all2,type,
list_all2:
!>[A: $tType,B: $tType] : ( ( A > B > $o ) > ( list @ A ) > ( list @ B ) > $o ) ).
thf(sy_c_List_Olist_Omap,type,
map:
!>[A: $tType,Aa: $tType] : ( ( A > Aa ) > ( list @ A ) > ( list @ Aa ) ) ).
thf(sy_c_List_Olist_Orec__list,type,
rec_list:
!>[C: $tType,A: $tType] : ( C > ( A > ( list @ A ) > C > C ) > ( list @ A ) > C ) ).
thf(sy_c_List_Olist_Oset,type,
set2:
!>[A: $tType] : ( ( list @ A ) > ( set @ A ) ) ).
thf(sy_c_List_Olist_Osize__list,type,
size_list:
!>[A: $tType] : ( ( A > nat ) > ( list @ A ) > nat ) ).
thf(sy_c_List_Olist_Otl,type,
tl:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Olist__ex,type,
list_ex:
!>[A: $tType] : ( ( A > $o ) > ( list @ A ) > $o ) ).
thf(sy_c_List_Olist__ex1,type,
list_ex1:
!>[A: $tType] : ( ( A > $o ) > ( list @ A ) > $o ) ).
thf(sy_c_List_Olist__update,type,
list_update:
!>[A: $tType] : ( ( list @ A ) > nat > A > ( list @ A ) ) ).
thf(sy_c_List_Olistrel,type,
listrel:
!>[A: $tType,B: $tType] : ( ( set @ ( product_prod @ A @ B ) ) > ( set @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) ) ) ).
thf(sy_c_List_Olistrel1,type,
listrel1:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) ) ).
thf(sy_c_List_Olistrel1p,type,
listrel1p:
!>[A: $tType] : ( ( A > A > $o ) > ( list @ A ) > ( list @ A ) > $o ) ).
thf(sy_c_List_Olistrelp,type,
listrelp:
!>[A: $tType,B: $tType] : ( ( A > B > $o ) > ( list @ A ) > ( list @ B ) > $o ) ).
thf(sy_c_List_Olists,type,
lists:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( list @ A ) ) ) ).
thf(sy_c_List_Olistset,type,
listset:
!>[A: $tType] : ( ( list @ ( set @ A ) ) > ( set @ ( list @ A ) ) ) ).
thf(sy_c_List_Omap__filter,type,
map_filter:
!>[A: $tType,B: $tType] : ( ( A > ( option @ B ) ) > ( list @ A ) > ( list @ B ) ) ).
thf(sy_c_List_Omap__project,type,
map_project:
!>[A: $tType,B: $tType] : ( ( A > ( option @ B ) ) > ( set @ A ) > ( set @ B ) ) ).
thf(sy_c_List_Omap__tailrec,type,
map_tailrec:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( list @ A ) > ( list @ B ) ) ).
thf(sy_c_List_Omap__tailrec__rev,type,
map_tailrec_rev:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( list @ A ) > ( list @ B ) > ( list @ B ) ) ).
thf(sy_c_List_Omap__tailrec__rev__rel,type,
map_tailrec_rev_rel:
!>[A: $tType,B: $tType] : ( ( product_prod @ ( A > B ) @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) ) > ( product_prod @ ( A > B ) @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) ) > $o ) ).
thf(sy_c_List_Omaps,type,
maps:
!>[A: $tType,B: $tType] : ( ( A > ( list @ B ) ) > ( list @ A ) > ( list @ B ) ) ).
thf(sy_c_List_Omeasures,type,
measures:
!>[A: $tType] : ( ( list @ ( A > nat ) ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_List_Omember,type,
member:
!>[A: $tType] : ( ( list @ A ) > A > $o ) ).
thf(sy_c_List_Omin__list,type,
min_list:
!>[A: $tType] : ( ( list @ A ) > A ) ).
thf(sy_c_List_Omin__list__rel,type,
min_list_rel:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) > $o ) ).
thf(sy_c_List_On__lists,type,
n_lists:
!>[A: $tType] : ( nat > ( list @ A ) > ( list @ ( list @ A ) ) ) ).
thf(sy_c_List_Onth,type,
nth:
!>[A: $tType] : ( ( list @ A ) > nat > A ) ).
thf(sy_c_List_Onths,type,
nths:
!>[A: $tType] : ( ( list @ A ) > ( set @ nat ) > ( list @ A ) ) ).
thf(sy_c_List_Onull,type,
null:
!>[A: $tType] : ( ( list @ A ) > $o ) ).
thf(sy_c_List_Oord_Olexordp,type,
lexordp2:
!>[A: $tType] : ( ( A > A > $o ) > ( list @ A ) > ( list @ A ) > $o ) ).
thf(sy_c_List_Oord__class_Olexordp,type,
ord_lexordp:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) > $o ) ).
thf(sy_c_List_Opartition,type,
partition:
!>[A: $tType] : ( ( A > $o ) > ( list @ A ) > ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) ).
thf(sy_c_List_Oproduct,type,
product:
!>[A: $tType,B: $tType] : ( ( list @ A ) > ( list @ B ) > ( list @ ( product_prod @ A @ B ) ) ) ).
thf(sy_c_List_Oproduct__lists,type,
product_lists:
!>[A: $tType] : ( ( list @ ( list @ A ) ) > ( list @ ( list @ A ) ) ) ).
thf(sy_c_List_Oremdups,type,
remdups:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Oremdups__adj,type,
remdups_adj:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Oremdups__adj__rel,type,
remdups_adj_rel:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) > $o ) ).
thf(sy_c_List_Oremove1,type,
remove1:
!>[A: $tType] : ( A > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_OremoveAll,type,
removeAll:
!>[A: $tType] : ( A > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Oreplicate,type,
replicate:
!>[A: $tType] : ( nat > A > ( list @ A ) ) ).
thf(sy_c_List_Orev,type,
rev:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Orotate,type,
rotate:
!>[A: $tType] : ( nat > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Orotate1,type,
rotate1:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Oset__Cons,type,
set_Cons:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( list @ A ) ) > ( set @ ( list @ A ) ) ) ).
thf(sy_c_List_Oshuffles,type,
shuffles:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) > ( set @ ( list @ A ) ) ) ).
thf(sy_c_List_Oshuffles__rel,type,
shuffles_rel:
!>[A: $tType] : ( ( product_prod @ ( list @ A ) @ ( list @ A ) ) > ( product_prod @ ( list @ A ) @ ( list @ A ) ) > $o ) ).
thf(sy_c_List_Osorted__wrt,type,
sorted_wrt:
!>[A: $tType] : ( ( A > A > $o ) > ( list @ A ) > $o ) ).
thf(sy_c_List_Osorted__wrt__rel,type,
sorted_wrt_rel:
!>[A: $tType] : ( ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) > ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) > $o ) ).
thf(sy_c_List_Osplice,type,
splice:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Osplice__rel,type,
splice_rel:
!>[A: $tType] : ( ( product_prod @ ( list @ A ) @ ( list @ A ) ) > ( product_prod @ ( list @ A ) @ ( list @ A ) ) > $o ) ).
thf(sy_c_List_Osubseqs,type,
subseqs:
!>[A: $tType] : ( ( list @ A ) > ( list @ ( list @ A ) ) ) ).
thf(sy_c_List_Osuccessively,type,
successively:
!>[A: $tType] : ( ( A > A > $o ) > ( list @ A ) > $o ) ).
thf(sy_c_List_Osuccessively__rel,type,
successively_rel:
!>[A: $tType] : ( ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) > ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) > $o ) ).
thf(sy_c_List_Otake,type,
take:
!>[A: $tType] : ( nat > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_OtakeWhile,type,
takeWhile:
!>[A: $tType] : ( ( A > $o ) > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Otranspose,type,
transpose:
!>[A: $tType] : ( ( list @ ( list @ A ) ) > ( list @ ( list @ A ) ) ) ).
thf(sy_c_List_Otranspose__rel,type,
transpose_rel:
!>[A: $tType] : ( ( list @ ( list @ A ) ) > ( list @ ( list @ A ) ) > $o ) ).
thf(sy_c_List_Ounion,type,
union:
!>[A: $tType] : ( ( list @ A ) > ( list @ A ) > ( list @ A ) ) ).
thf(sy_c_List_Oupt,type,
upt: nat > nat > ( list @ nat ) ).
thf(sy_c_List_Oupto,type,
upto: int > int > ( list @ int ) ).
thf(sy_c_List_Oupto__aux,type,
upto_aux: int > int > ( list @ int ) > ( list @ int ) ).
thf(sy_c_List_Oupto__rel,type,
upto_rel: ( product_prod @ int @ int ) > ( product_prod @ int @ int ) > $o ).
thf(sy_c_List_Ozip,type,
zip:
!>[A: $tType,B: $tType] : ( ( list @ A ) > ( list @ B ) > ( list @ ( product_prod @ A @ B ) ) ) ).
thf(sy_c_Map_Odom,type,
dom:
!>[A: $tType,B: $tType] : ( ( A > ( option @ B ) ) > ( set @ A ) ) ).
thf(sy_c_Map_Ograph,type,
graph:
!>[A: $tType,B: $tType] : ( ( A > ( option @ B ) ) > ( set @ ( product_prod @ A @ B ) ) ) ).
thf(sy_c_Map_Omap__add,type,
map_add:
!>[A: $tType,B: $tType] : ( ( A > ( option @ B ) ) > ( A > ( option @ B ) ) > A > ( option @ B ) ) ).
thf(sy_c_Map_Omap__of,type,
map_of:
!>[A: $tType,B: $tType] : ( ( list @ ( product_prod @ A @ B ) ) > A > ( option @ B ) ) ).
thf(sy_c_Map_Omap__upds,type,
map_upds:
!>[A: $tType,B: $tType] : ( ( A > ( option @ B ) ) > ( list @ A ) > ( list @ B ) > A > ( option @ B ) ) ).
thf(sy_c_Map_Oran,type,
ran:
!>[A: $tType,B: $tType] : ( ( A > ( option @ B ) ) > ( set @ B ) ) ).
thf(sy_c_Map_Orestrict__map,type,
restrict_map:
!>[A: $tType,B: $tType] : ( ( A > ( option @ B ) ) > ( set @ A ) > A > ( option @ B ) ) ).
thf(sy_c_Nat_OSuc,type,
suc: nat > nat ).
thf(sy_c_Nat_Ocompow,type,
compow:
!>[A: $tType] : ( nat > A > A ) ).
thf(sy_c_Nat_Ofunpow,type,
funpow:
!>[A: $tType] : ( nat > ( A > A ) > A > A ) ).
thf(sy_c_Nat_Onat_Ocase__nat,type,
case_nat:
!>[A: $tType] : ( A > ( nat > A ) > nat > A ) ).
thf(sy_c_Nat_Onat_Opred,type,
pred: nat > nat ).
thf(sy_c_Nat_Oold_Onat_Orec__nat,type,
rec_nat:
!>[T: $tType] : ( T > ( nat > T > T ) > nat > T ) ).
thf(sy_c_Nat_Oold_Onat_Orec__set__nat,type,
rec_set_nat:
!>[T: $tType] : ( T > ( nat > T > T ) > nat > T > $o ) ).
thf(sy_c_Nat_Osemiring__1__class_ONats,type,
semiring_1_Nats:
!>[A: $tType] : ( set @ A ) ).
thf(sy_c_Nat_Osemiring__1__class_Oof__nat,type,
semiring_1_of_nat:
!>[A: $tType] : ( nat > A ) ).
thf(sy_c_Nat_Osemiring__1__class_Oof__nat__aux,type,
semiri8178284476397505188at_aux:
!>[A: $tType] : ( ( A > A ) > nat > A > A ) ).
thf(sy_c_Nat_Osize__class_Osize,type,
size_size:
!>[A: $tType] : ( A > nat ) ).
thf(sy_c_Nat__Bijection_Olist__decode,type,
nat_list_decode: nat > ( list @ nat ) ).
thf(sy_c_Nat__Bijection_Olist__decode__rel,type,
nat_list_decode_rel: nat > nat > $o ).
thf(sy_c_Nat__Bijection_Olist__encode,type,
nat_list_encode: ( list @ nat ) > nat ).
thf(sy_c_Nat__Bijection_Olist__encode__rel,type,
nat_list_encode_rel: ( list @ nat ) > ( list @ nat ) > $o ).
thf(sy_c_Nat__Bijection_Oprod__decode,type,
nat_prod_decode: nat > ( product_prod @ nat @ nat ) ).
thf(sy_c_Nat__Bijection_Oprod__decode__aux,type,
nat_prod_decode_aux: nat > nat > ( product_prod @ nat @ nat ) ).
thf(sy_c_Nat__Bijection_Oprod__decode__aux__rel,type,
nat_pr5047031295181774490ux_rel: ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) > $o ).
thf(sy_c_Nat__Bijection_Oprod__encode,type,
nat_prod_encode: ( product_prod @ nat @ nat ) > nat ).
thf(sy_c_Nat__Bijection_Oset__decode,type,
nat_set_decode: nat > ( set @ nat ) ).
thf(sy_c_Nat__Bijection_Oset__encode,type,
nat_set_encode: ( set @ nat ) > nat ).
thf(sy_c_Nat__Bijection_Otriangle,type,
nat_triangle: nat > nat ).
thf(sy_c_NthRoot_Oroot,type,
root: nat > real > real ).
thf(sy_c_Num_Oinc,type,
inc: num > num ).
thf(sy_c_Num_Oneg__numeral__class_Odbl__dec,type,
neg_numeral_dbl_dec:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Num_Oneg__numeral__class_Odbl__inc,type,
neg_numeral_dbl_inc:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Num_Oneg__numeral__class_Osub,type,
neg_numeral_sub:
!>[A: $tType] : ( num > num > A ) ).
thf(sy_c_Num_Onum_OBit0,type,
bit0: num > num ).
thf(sy_c_Num_Onum_OBit1,type,
bit1: num > num ).
thf(sy_c_Num_Onum_OOne,type,
one2: num ).
thf(sy_c_Num_Onum_Osize__num,type,
size_num: num > nat ).
thf(sy_c_Num_Onum__of__nat,type,
num_of_nat: nat > num ).
thf(sy_c_Num_Onumeral__class_Onumeral,type,
numeral_numeral:
!>[A: $tType] : ( num > A ) ).
thf(sy_c_Num_Opow,type,
pow: num > num > num ).
thf(sy_c_Num_Opred__numeral,type,
pred_numeral: num > nat ).
thf(sy_c_Option_Ooption_ONone,type,
none:
!>[A: $tType] : ( option @ A ) ).
thf(sy_c_Option_Ooption_OSome,type,
some:
!>[A: $tType] : ( A > ( option @ A ) ) ).
thf(sy_c_Option_Ooption_Ocase__option,type,
case_option:
!>[B: $tType,A: $tType] : ( B > ( A > B ) > ( option @ A ) > B ) ).
thf(sy_c_Option_Ooption_Omap__option,type,
map_option:
!>[A: $tType,Aa: $tType] : ( ( A > Aa ) > ( option @ A ) > ( option @ Aa ) ) ).
thf(sy_c_Option_Ooption_Osize__option,type,
size_option:
!>[A: $tType] : ( ( A > nat ) > ( option @ A ) > nat ) ).
thf(sy_c_Option_Ooption_Othe,type,
the2:
!>[A: $tType] : ( ( option @ A ) > A ) ).
thf(sy_c_Option_Othese,type,
these:
!>[A: $tType] : ( ( set @ ( option @ A ) ) > ( set @ A ) ) ).
thf(sy_c_Order__Continuity_Ocountable__complete__lattice__class_Occlfp,type,
order_532582986084564980_cclfp:
!>[A: $tType] : ( ( A > A ) > A ) ).
thf(sy_c_Order__Continuity_Oinf__continuous,type,
order_inf_continuous:
!>[A: $tType,B: $tType] : ( ( A > B ) > $o ) ).
thf(sy_c_Order__Continuity_Osup__continuous,type,
order_sup_continuous:
!>[A: $tType,B: $tType] : ( ( A > B ) > $o ) ).
thf(sy_c_Order__Relation_OAbove,type,
order_Above:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ A ) > ( set @ A ) ) ).
thf(sy_c_Order__Relation_OAboveS,type,
order_AboveS:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ A ) > ( set @ A ) ) ).
thf(sy_c_Order__Relation_OUnder,type,
order_Under:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ A ) > ( set @ A ) ) ).
thf(sy_c_Order__Relation_OUnderS,type,
order_UnderS:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ A ) > ( set @ A ) ) ).
thf(sy_c_Order__Relation_OaboveS,type,
order_aboveS:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > A > ( set @ A ) ) ).
thf(sy_c_Order__Relation_Olinear__order__on,type,
order_679001287576687338der_on:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Order__Relation_Oofilter,type,
order_ofilter:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ A ) > $o ) ).
thf(sy_c_Order__Relation_Opartial__order__on,type,
order_7125193373082350890der_on:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Order__Relation_Opreorder__on,type,
order_preorder_on:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Order__Relation_Orelation__of,type,
order_relation_of:
!>[A: $tType] : ( ( A > A > $o ) > ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_Order__Relation_Ounder,type,
order_under:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > A > ( set @ A ) ) ).
thf(sy_c_Order__Relation_OunderS,type,
order_underS:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > A > ( set @ A ) ) ).
thf(sy_c_Order__Relation_Owell__order__on,type,
order_well_order_on:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Orderings_Obot__class_Obot,type,
bot_bot:
!>[A: $tType] : A ).
thf(sy_c_Orderings_Oord_Omax,type,
max:
!>[A: $tType] : ( ( A > A > $o ) > A > A > A ) ).
thf(sy_c_Orderings_Oord_Omin,type,
min:
!>[A: $tType] : ( ( A > A > $o ) > A > A > A ) ).
thf(sy_c_Orderings_Oord__class_OLeast,type,
ord_Least:
!>[A: $tType] : ( ( A > $o ) > A ) ).
thf(sy_c_Orderings_Oord__class_Oless,type,
ord_less:
!>[A: $tType] : ( A > A > $o ) ).
thf(sy_c_Orderings_Oord__class_Oless__eq,type,
ord_less_eq:
!>[A: $tType] : ( A > A > $o ) ).
thf(sy_c_Orderings_Oord__class_Omax,type,
ord_max:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Orderings_Oord__class_Omin,type,
ord_min:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Orderings_Oorder__class_OGreatest,type,
order_Greatest:
!>[A: $tType] : ( ( A > $o ) > A ) ).
thf(sy_c_Orderings_Oorder__class_Oantimono,type,
order_antimono:
!>[A: $tType,B: $tType] : ( ( A > B ) > $o ) ).
thf(sy_c_Orderings_Oorder__class_Omono,type,
order_mono:
!>[A: $tType,B: $tType] : ( ( A > B ) > $o ) ).
thf(sy_c_Orderings_Oorder__class_Ostrict__mono,type,
order_strict_mono:
!>[A: $tType,B: $tType] : ( ( A > B ) > $o ) ).
thf(sy_c_Orderings_Oordering__top,type,
ordering_top:
!>[A: $tType] : ( ( A > A > $o ) > ( A > A > $o ) > A > $o ) ).
thf(sy_c_Orderings_Otop__class_Otop,type,
top_top:
!>[A: $tType] : A ).
thf(sy_c_Partial__Function_Oflat__lub,type,
partial_flat_lub:
!>[A: $tType] : ( A > ( set @ A ) > A ) ).
thf(sy_c_Partial__Function_Ofun__ord,type,
partial_fun_ord:
!>[A: $tType,B: $tType,C: $tType] : ( ( A > B > $o ) > ( C > A ) > ( C > B ) > $o ) ).
thf(sy_c_Power_Opower_Opower,type,
power2:
!>[A: $tType] : ( A > ( A > A > A ) > A > nat > A ) ).
thf(sy_c_Power_Opower__class_Opower,type,
power_power:
!>[A: $tType] : ( A > nat > A ) ).
thf(sy_c_Product__Type_OPair,type,
product_Pair:
!>[A: $tType,B: $tType] : ( A > B > ( product_prod @ A @ B ) ) ).
thf(sy_c_Product__Type_OSigma,type,
product_Sigma:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > ( set @ B ) ) > ( set @ ( product_prod @ A @ B ) ) ) ).
thf(sy_c_Product__Type_Omap__prod,type,
product_map_prod:
!>[A: $tType,C: $tType,B: $tType,D: $tType] : ( ( A > C ) > ( B > D ) > ( product_prod @ A @ B ) > ( product_prod @ C @ D ) ) ).
thf(sy_c_Product__Type_Oold_Oprod_Orec__prod,type,
product_rec_prod:
!>[A: $tType,B: $tType,T: $tType] : ( ( A > B > T ) > ( product_prod @ A @ B ) > T ) ).
thf(sy_c_Product__Type_Oprod_Ocase__prod,type,
product_case_prod:
!>[A: $tType,B: $tType,C: $tType] : ( ( A > B > C ) > ( product_prod @ A @ B ) > C ) ).
thf(sy_c_Product__Type_Oprod_Ofst,type,
product_fst:
!>[A: $tType,B: $tType] : ( ( product_prod @ A @ B ) > A ) ).
thf(sy_c_Product__Type_Oprod_Osnd,type,
product_snd:
!>[A: $tType,B: $tType] : ( ( product_prod @ A @ B ) > B ) ).
thf(sy_c_Product__Type_Oprod_Oswap,type,
product_swap:
!>[A: $tType,B: $tType] : ( ( product_prod @ A @ B ) > ( product_prod @ B @ A ) ) ).
thf(sy_c_Product__Type_Oproduct,type,
product_product:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( set @ B ) > ( set @ ( product_prod @ A @ B ) ) ) ).
thf(sy_c_Product__Type_Ounit_OAbs__unit,type,
product_Abs_unit: $o > product_unit ).
thf(sy_c_Product__Type_Ounit_ORep__unit,type,
product_Rep_unit: product_unit > $o ).
thf(sy_c_Pure_Otype,type,
type2:
!>[A: $tType] : ( itself @ A ) ).
thf(sy_c_Rat_Ofield__char__0__class_ORats,type,
field_char_0_Rats:
!>[A: $tType] : ( set @ A ) ).
thf(sy_c_Real__Vector__Spaces_Obounded__bilinear,type,
real_V2442710119149674383linear:
!>[A: $tType,B: $tType,C: $tType] : ( ( A > B > C ) > $o ) ).
thf(sy_c_Real__Vector__Spaces_Obounded__linear,type,
real_V3181309239436604168linear:
!>[A: $tType,B: $tType] : ( ( A > B ) > $o ) ).
thf(sy_c_Real__Vector__Spaces_Oconstruct,type,
real_V4425403222259421789struct:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > B ) > A > B ) ).
thf(sy_c_Real__Vector__Spaces_Odependent,type,
real_V358717886546972837endent:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Real__Vector__Spaces_Odim,type,
real_Vector_dim:
!>[A: $tType] : ( ( set @ A ) > nat ) ).
thf(sy_c_Real__Vector__Spaces_Odist__class_Odist,type,
real_V557655796197034286t_dist:
!>[A: $tType] : ( A > A > real ) ).
thf(sy_c_Real__Vector__Spaces_Oextend__basis,type,
real_V4986007116245087402_basis:
!>[A: $tType] : ( ( set @ A ) > ( set @ A ) ) ).
thf(sy_c_Real__Vector__Spaces_Olinear,type,
real_Vector_linear:
!>[A: $tType,B: $tType] : ( ( A > B ) > $o ) ).
thf(sy_c_Real__Vector__Spaces_Onorm__class_Onorm,type,
real_V7770717601297561774m_norm:
!>[A: $tType] : ( A > real ) ).
thf(sy_c_Real__Vector__Spaces_Oof__real,type,
real_Vector_of_real:
!>[A: $tType] : ( real > A ) ).
thf(sy_c_Real__Vector__Spaces_Orepresentation,type,
real_V7696804695334737415tation:
!>[A: $tType] : ( ( set @ A ) > A > A > real ) ).
thf(sy_c_Real__Vector__Spaces_OscaleR__class_OscaleR,type,
real_V8093663219630862766scaleR:
!>[A: $tType] : ( real > A > A ) ).
thf(sy_c_Real__Vector__Spaces_Ospan,type,
real_Vector_span:
!>[A: $tType] : ( ( set @ A ) > ( set @ A ) ) ).
thf(sy_c_Real__Vector__Spaces_Osubspace,type,
real_Vector_subspace:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Relation_OField,type,
field2:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ A ) ) ).
thf(sy_c_Relation_OId,type,
id2:
!>[A: $tType] : ( set @ ( product_prod @ A @ A ) ) ).
thf(sy_c_Relation_OId__on,type,
id_on:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_Relation_OImage,type,
image:
!>[A: $tType,B: $tType] : ( ( set @ ( product_prod @ A @ B ) ) > ( set @ A ) > ( set @ B ) ) ).
thf(sy_c_Relation_Oantisym,type,
antisym:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Relation_Oantisymp,type,
antisymp:
!>[A: $tType] : ( ( A > A > $o ) > $o ) ).
thf(sy_c_Relation_Oconverse,type,
converse:
!>[A: $tType,B: $tType] : ( ( set @ ( product_prod @ A @ B ) ) > ( set @ ( product_prod @ B @ A ) ) ) ).
thf(sy_c_Relation_Oconversep,type,
conversep:
!>[A: $tType,B: $tType] : ( ( A > B > $o ) > B > A > $o ) ).
thf(sy_c_Relation_Oinv__image,type,
inv_image:
!>[B: $tType,A: $tType] : ( ( set @ ( product_prod @ B @ B ) ) > ( A > B ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_Relation_Oirrefl,type,
irrefl:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Relation_Oirreflp,type,
irreflp:
!>[A: $tType] : ( ( A > A > $o ) > $o ) ).
thf(sy_c_Relation_Orefl__on,type,
refl_on:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Relation_Orelcomp,type,
relcomp:
!>[A: $tType,B: $tType,C: $tType] : ( ( set @ ( product_prod @ A @ B ) ) > ( set @ ( product_prod @ B @ C ) ) > ( set @ ( product_prod @ A @ C ) ) ) ).
thf(sy_c_Relation_Osingle__valued,type,
single_valued:
!>[A: $tType,B: $tType] : ( ( set @ ( product_prod @ A @ B ) ) > $o ) ).
thf(sy_c_Relation_Osingle__valuedp,type,
single_valuedp:
!>[A: $tType,B: $tType] : ( ( A > B > $o ) > $o ) ).
thf(sy_c_Relation_Ototal__on,type,
total_on:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Relation_Otrans,type,
trans:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Relation_Otransp,type,
transp:
!>[A: $tType] : ( ( A > A > $o ) > $o ) ).
thf(sy_c_Rings_Oalgebraic__semidom__class_Ocoprime,type,
algebr8660921524188924756oprime:
!>[A: $tType] : ( A > A > $o ) ).
thf(sy_c_Rings_Odivide__class_Odivide,type,
divide_divide:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Rings_Odvd__class_Odvd,type,
dvd_dvd:
!>[A: $tType] : ( A > A > $o ) ).
thf(sy_c_Rings_Omodulo__class_Omodulo,type,
modulo_modulo:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Rings_Ozero__neq__one__class_Oof__bool,type,
zero_neq_one_of_bool:
!>[A: $tType] : ( $o > A ) ).
thf(sy_c_Series_Osuminf,type,
suminf:
!>[A: $tType] : ( ( nat > A ) > A ) ).
thf(sy_c_Series_Osummable,type,
summable:
!>[A: $tType] : ( ( nat > A ) > $o ) ).
thf(sy_c_Series_Osums,type,
sums:
!>[A: $tType] : ( ( nat > A ) > A > $o ) ).
thf(sy_c_Set_OBall,type,
ball:
!>[A: $tType] : ( ( set @ A ) > ( A > $o ) > $o ) ).
thf(sy_c_Set_OCollect,type,
collect:
!>[A: $tType] : ( ( A > $o ) > ( set @ A ) ) ).
thf(sy_c_Set_OPow,type,
pow2:
!>[A: $tType] : ( ( set @ A ) > ( set @ ( set @ A ) ) ) ).
thf(sy_c_Set_Obind,type,
bind2:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > ( set @ B ) ) > ( set @ B ) ) ).
thf(sy_c_Set_Odisjnt,type,
disjnt:
!>[A: $tType] : ( ( set @ A ) > ( set @ A ) > $o ) ).
thf(sy_c_Set_Ofilter,type,
filter3:
!>[A: $tType] : ( ( A > $o ) > ( set @ A ) > ( set @ A ) ) ).
thf(sy_c_Set_Oimage,type,
image2:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( set @ A ) > ( set @ B ) ) ).
thf(sy_c_Set_Oinsert,type,
insert2:
!>[A: $tType] : ( A > ( set @ A ) > ( set @ A ) ) ).
thf(sy_c_Set_Ois__empty,type,
is_empty:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Set_Ois__singleton,type,
is_singleton:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Set_Opairwise,type,
pairwise:
!>[A: $tType] : ( ( A > A > $o ) > ( set @ A ) > $o ) ).
thf(sy_c_Set_Oremove,type,
remove:
!>[A: $tType] : ( A > ( set @ A ) > ( set @ A ) ) ).
thf(sy_c_Set_Othe__elem,type,
the_elem:
!>[A: $tType] : ( ( set @ A ) > A ) ).
thf(sy_c_Set_Ovimage,type,
vimage:
!>[A: $tType,B: $tType] : ( ( A > B ) > ( set @ B ) > ( set @ A ) ) ).
thf(sy_c_Set__Interval_Ofold__atLeastAtMost__nat,type,
set_fo6178422350223883121st_nat:
!>[A: $tType] : ( ( nat > A > A ) > nat > nat > A > A ) ).
thf(sy_c_Set__Interval_Ofold__atLeastAtMost__nat__rel,type,
set_fo1817059534552279752at_rel:
!>[A: $tType] : ( ( product_prod @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) ) > ( product_prod @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) ) > $o ) ).
thf(sy_c_Set__Interval_Oord__class_OatLeast,type,
set_ord_atLeast:
!>[A: $tType] : ( A > ( set @ A ) ) ).
thf(sy_c_Set__Interval_Oord__class_OatLeastAtMost,type,
set_or1337092689740270186AtMost:
!>[A: $tType] : ( A > A > ( set @ A ) ) ).
thf(sy_c_Set__Interval_Oord__class_OatLeastLessThan,type,
set_or7035219750837199246ssThan:
!>[A: $tType] : ( A > A > ( set @ A ) ) ).
thf(sy_c_Set__Interval_Oord__class_OatMost,type,
set_ord_atMost:
!>[A: $tType] : ( A > ( set @ A ) ) ).
thf(sy_c_Set__Interval_Oord__class_OgreaterThan,type,
set_ord_greaterThan:
!>[A: $tType] : ( A > ( set @ A ) ) ).
thf(sy_c_Set__Interval_Oord__class_OgreaterThanAtMost,type,
set_or3652927894154168847AtMost:
!>[A: $tType] : ( A > A > ( set @ A ) ) ).
thf(sy_c_Set__Interval_Oord__class_OgreaterThanLessThan,type,
set_or5935395276787703475ssThan:
!>[A: $tType] : ( A > A > ( set @ A ) ) ).
thf(sy_c_Set__Interval_Oord__class_OlessThan,type,
set_ord_lessThan:
!>[A: $tType] : ( A > ( set @ A ) ) ).
thf(sy_c_String_Ocomm__semiring__1__class_Oof__char,type,
comm_s6883823935334413003f_char:
!>[A: $tType] : ( char > A ) ).
thf(sy_c_String_Ounique__euclidean__semiring__with__bit__operations__class_Ochar__of,type,
unique5772411509450598832har_of:
!>[A: $tType] : ( A > char ) ).
thf(sy_c_Sum__Type_OPlus,type,
sum_Plus:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( set @ B ) > ( set @ ( sum_sum @ A @ B ) ) ) ).
thf(sy_c_Topological__Spaces_Ocontinuous,type,
topolo3448309680560233919inuous:
!>[A: $tType,B: $tType] : ( ( filter @ A ) > ( A > B ) > $o ) ).
thf(sy_c_Topological__Spaces_Ocontinuous__on,type,
topolo81223032696312382ous_on:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > B ) > $o ) ).
thf(sy_c_Topological__Spaces_Omonoseq,type,
topological_monoseq:
!>[A: $tType] : ( ( nat > A ) > $o ) ).
thf(sy_c_Topological__Spaces_Oopen__class_Oopen,type,
topolo1002775350975398744n_open:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Topological__Spaces_Ot2__space__class_OLim,type,
topolo3827282254853284352ce_Lim:
!>[F: $tType,A: $tType] : ( ( filter @ F ) > ( F > A ) > A ) ).
thf(sy_c_Topological__Spaces_Otopological__space__class_Oat__within,type,
topolo174197925503356063within:
!>[A: $tType] : ( A > ( set @ A ) > ( filter @ A ) ) ).
thf(sy_c_Topological__Spaces_Otopological__space__class_Oclosed,type,
topolo7761053866217962861closed:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Topological__Spaces_Otopological__space__class_Ocompact,type,
topolo2193935891317330818ompact:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Topological__Spaces_Otopological__space__class_Oconnected,type,
topolo1966860045006549960nected:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Topological__Spaces_Otopological__space__class_Onhds,type,
topolo7230453075368039082e_nhds:
!>[A: $tType] : ( A > ( filter @ A ) ) ).
thf(sy_c_Topological__Spaces_Ouniform__space__class_OCauchy,type,
topolo3814608138187158403Cauchy:
!>[A: $tType] : ( ( nat > A ) > $o ) ).
thf(sy_c_Topological__Spaces_Ouniform__space__class_Ocauchy__filter,type,
topolo6773858410816713723filter:
!>[A: $tType] : ( ( filter @ A ) > $o ) ).
thf(sy_c_Topological__Spaces_Ouniform__space__class_Ocomplete,type,
topolo2479028161051973599mplete:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Topological__Spaces_Ouniform__space__class_Ototally__bounded,type,
topolo6688025880775521714ounded:
!>[A: $tType] : ( ( set @ A ) > $o ) ).
thf(sy_c_Topological__Spaces_Ouniformity__class_Ouniformity,type,
topolo7806501430040627800ormity:
!>[A: $tType] : ( filter @ ( product_prod @ A @ A ) ) ).
thf(sy_c_Topological__Spaces_Ouniformly__continuous__on,type,
topolo6026614971017936543ous_on:
!>[A: $tType,B: $tType] : ( ( set @ A ) > ( A > B ) > $o ) ).
thf(sy_c_Transcendental_Oarcosh,type,
arcosh:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transcendental_Oarctan,type,
arctan: real > real ).
thf(sy_c_Transcendental_Oarsinh,type,
arsinh:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transcendental_Oartanh,type,
artanh:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transcendental_Ocos,type,
cos:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transcendental_Ocos__coeff,type,
cos_coeff: nat > real ).
thf(sy_c_Transcendental_Ocosh,type,
cosh:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transcendental_Ocot,type,
cot:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transcendental_Odiffs,type,
diffs:
!>[A: $tType] : ( ( nat > A ) > nat > A ) ).
thf(sy_c_Transcendental_Oexp,type,
exp:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transcendental_Oln__class_Oln,type,
ln_ln:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transcendental_Olog,type,
log: real > real > real ).
thf(sy_c_Transcendental_Opi,type,
pi: real ).
thf(sy_c_Transcendental_Opowr,type,
powr:
!>[A: $tType] : ( A > A > A ) ).
thf(sy_c_Transcendental_Osin,type,
sin:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transcendental_Osin__coeff,type,
sin_coeff: nat > real ).
thf(sy_c_Transcendental_Osinh,type,
sinh:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transcendental_Otan,type,
tan:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transcendental_Otanh,type,
tanh:
!>[A: $tType] : ( A > A ) ).
thf(sy_c_Transfer_Obi__total,type,
bi_total:
!>[A: $tType,B: $tType] : ( ( A > B > $o ) > $o ) ).
thf(sy_c_Transitive__Closure_Oacyclic,type,
transitive_acyclic:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Transitive__Closure_Ontrancl,type,
transitive_ntrancl:
!>[A: $tType] : ( nat > ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_Transitive__Closure_Ortrancl,type,
transitive_rtrancl:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_Transitive__Closure_Otrancl,type,
transitive_trancl:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_Typedef_Otype__definition,type,
type_definition:
!>[B: $tType,A: $tType] : ( ( B > A ) > ( A > B ) > ( set @ A ) > $o ) ).
thf(sy_c_VEBT__Definitions_OVEBT_OLeaf,type,
vEBT_Leaf: $o > $o > vEBT_VEBT ).
thf(sy_c_VEBT__Definitions_OVEBT_ONode,type,
vEBT_Node: ( option @ ( product_prod @ nat @ nat ) ) > nat > ( list @ vEBT_VEBT ) > vEBT_VEBT > vEBT_VEBT ).
thf(sy_c_VEBT__Definitions_OVEBT_Orec__VEBT,type,
vEBT_rec_VEBT:
!>[A: $tType] : ( ( ( option @ ( product_prod @ nat @ nat ) ) > nat > ( list @ ( product_prod @ vEBT_VEBT @ A ) ) > vEBT_VEBT > A > A ) > ( $o > $o > A ) > vEBT_VEBT > A ) ).
thf(sy_c_VEBT__Definitions_OVEBT_Osize__VEBT,type,
vEBT_size_VEBT: vEBT_VEBT > nat ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Oboth__member__options,type,
vEBT_V8194947554948674370ptions: vEBT_VEBT > nat > $o ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Oelim__dead,type,
vEBT_VEBT_elim_dead: vEBT_VEBT > extended_enat > vEBT_VEBT ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Oelim__dead__rel,type,
vEBT_V312737461966249ad_rel: ( product_prod @ vEBT_VEBT @ extended_enat ) > ( product_prod @ vEBT_VEBT @ extended_enat ) > $o ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Ohigh,type,
vEBT_VEBT_high: nat > nat > nat ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Oin__children,type,
vEBT_V5917875025757280293ildren: nat > ( list @ vEBT_VEBT ) > nat > $o ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Olow,type,
vEBT_VEBT_low: nat > nat > nat ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Omembermima,type,
vEBT_VEBT_membermima: vEBT_VEBT > nat > $o ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Omembermima__rel,type,
vEBT_V4351362008482014158ma_rel: ( product_prod @ vEBT_VEBT @ nat ) > ( product_prod @ vEBT_VEBT @ nat ) > $o ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Onaive__member,type,
vEBT_V5719532721284313246member: vEBT_VEBT > nat > $o ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Onaive__member__rel,type,
vEBT_V5765760719290551771er_rel: ( product_prod @ vEBT_VEBT @ nat ) > ( product_prod @ vEBT_VEBT @ nat ) > $o ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Ovalid_H,type,
vEBT_VEBT_valid: vEBT_VEBT > nat > $o ).
thf(sy_c_VEBT__Definitions_OVEBT__internal_Ovalid_H__rel,type,
vEBT_VEBT_valid_rel: ( product_prod @ vEBT_VEBT @ nat ) > ( product_prod @ vEBT_VEBT @ nat ) > $o ).
thf(sy_c_VEBT__Definitions_Oinvar__vebt,type,
vEBT_invar_vebt: vEBT_VEBT > nat > $o ).
thf(sy_c_VEBT__Definitions_Oset__vebt,type,
vEBT_set_vebt: vEBT_VEBT > ( set @ nat ) ).
thf(sy_c_VEBT__Definitions_Ovebt__buildup,type,
vEBT_vebt_buildup: nat > vEBT_VEBT ).
thf(sy_c_VEBT__Definitions_Ovebt__buildup__rel,type,
vEBT_v4011308405150292612up_rel: nat > nat > $o ).
thf(sy_c_VEBT__Insert_Ovebt__insert,type,
vEBT_vebt_insert: vEBT_VEBT > nat > vEBT_VEBT ).
thf(sy_c_VEBT__Insert_Ovebt__insert__rel,type,
vEBT_vebt_insert_rel: ( product_prod @ vEBT_VEBT @ nat ) > ( product_prod @ vEBT_VEBT @ nat ) > $o ).
thf(sy_c_VEBT__Member_OVEBT__internal_Obit__concat,type,
vEBT_VEBT_bit_concat: nat > nat > nat > nat ).
thf(sy_c_VEBT__Member_OVEBT__internal_OminNull,type,
vEBT_VEBT_minNull: vEBT_VEBT > $o ).
thf(sy_c_VEBT__Member_OVEBT__internal_Oset__vebt_H,type,
vEBT_VEBT_set_vebt: vEBT_VEBT > ( set @ nat ) ).
thf(sy_c_VEBT__Member_Ovebt__member,type,
vEBT_vebt_member: vEBT_VEBT > nat > $o ).
thf(sy_c_VEBT__Member_Ovebt__member__rel,type,
vEBT_vebt_member_rel: ( product_prod @ vEBT_VEBT @ nat ) > ( product_prod @ vEBT_VEBT @ nat ) > $o ).
thf(sy_c_Wellfounded_Oaccp,type,
accp:
!>[A: $tType] : ( ( A > A > $o ) > A > $o ) ).
thf(sy_c_Wellfounded_Oless__than,type,
less_than: set @ ( product_prod @ nat @ nat ) ).
thf(sy_c_Wellfounded_Olex__prod,type,
lex_prod:
!>[A: $tType,B: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ B @ B ) ) > ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) ) ).
thf(sy_c_Wellfounded_Omax__ext,type,
max_ext:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) ) ) ).
thf(sy_c_Wellfounded_Omax__extp,type,
max_extp:
!>[A: $tType] : ( ( A > A > $o ) > ( set @ A ) > ( set @ A ) > $o ) ).
thf(sy_c_Wellfounded_Omeasure,type,
measure:
!>[A: $tType] : ( ( A > nat ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_Wellfounded_Omin__ext,type,
min_ext:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) ) ) ).
thf(sy_c_Wellfounded_Omlex__prod,type,
mlex_prod:
!>[A: $tType] : ( ( A > nat ) > ( set @ ( product_prod @ A @ A ) ) > ( set @ ( product_prod @ A @ A ) ) ) ).
thf(sy_c_Wellfounded_Opred__nat,type,
pred_nat: set @ ( product_prod @ nat @ nat ) ).
thf(sy_c_Wellfounded_Owf,type,
wf:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > $o ) ).
thf(sy_c_Wfrec_Osame__fst,type,
same_fst:
!>[A: $tType,B: $tType] : ( ( A > $o ) > ( A > ( set @ ( product_prod @ B @ B ) ) ) > ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) ) ).
thf(sy_c_Zorn_OChains,type,
chains:
!>[A: $tType] : ( ( set @ ( product_prod @ A @ A ) ) > ( set @ ( set @ A ) ) ) ).
thf(sy_c_Zorn_Ochains,type,
chains2:
!>[A: $tType] : ( ( set @ ( set @ A ) ) > ( set @ ( set @ ( set @ A ) ) ) ) ).
thf(sy_c_Zorn_Oinit__seg__of,type,
init_seg_of:
!>[A: $tType] : ( set @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) ) ) ).
thf(sy_c_Zorn_Opred__on_Ochain,type,
pred_chain:
!>[A: $tType] : ( ( set @ A ) > ( A > A > $o ) > ( set @ A ) > $o ) ).
thf(sy_c_fChoice,type,
fChoice:
!>[A: $tType] : ( ( A > $o ) > A ) ).
thf(sy_c_member,type,
member2:
!>[A: $tType] : ( A > ( set @ A ) > $o ) ).
thf(sy_v_deg____,type,
deg: nat ).
thf(sy_v_i____,type,
i: nat ).
thf(sy_v_m____,type,
m: nat ).
thf(sy_v_ma____,type,
ma: nat ).
thf(sy_v_mi____,type,
mi: nat ).
thf(sy_v_na____,type,
na: nat ).
thf(sy_v_summary____,type,
summary: vEBT_VEBT ).
thf(sy_v_treeList____,type,
treeList: list @ vEBT_VEBT ).
thf(sy_v_xa____,type,
xa: nat ).
% Relevant facts (8187)
thf(fact_0_True,axiom,
( i
= ( vEBT_VEBT_high @ xa @ na ) ) ).
% True
thf(fact_1__C166_C,axiom,
vEBT_V8194947554948674370ptions @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) @ ( vEBT_VEBT_low @ xa @ na ) ) @ ( vEBT_VEBT_low @ xa @ na ) ).
% "166"
thf(fact_2_bit__split__inv,axiom,
! [X: nat,D2: nat] :
( ( vEBT_VEBT_bit_concat @ ( vEBT_VEBT_high @ X @ D2 ) @ ( vEBT_VEBT_low @ X @ D2 ) @ D2 )
= X ) ).
% bit_split_inv
thf(fact_3__C164_C,axiom,
( ( nth @ vEBT_VEBT @ ( list_update @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) @ ( vEBT_VEBT_low @ xa @ na ) ) ) @ i )
= ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) @ ( vEBT_VEBT_low @ xa @ na ) ) ) ).
% "164"
thf(fact_4__C162_C,axiom,
~ ? [X_1: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) @ X_1 ) ).
% "162"
thf(fact_5_insprop,axiom,
( ( nth @ vEBT_VEBT @ ( list_update @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) @ ( vEBT_VEBT_low @ xa @ na ) ) ) @ ( vEBT_VEBT_high @ xa @ na ) )
= ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) @ ( vEBT_VEBT_low @ xa @ na ) ) ) ).
% insprop
thf(fact_6_tc,axiom,
vEBT_VEBT_minNull @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) ).
% tc
thf(fact_7_in__children__def,axiom,
( vEBT_V5917875025757280293ildren
= ( ^ [N: nat,TreeList: list @ vEBT_VEBT,X2: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList @ ( vEBT_VEBT_high @ X2 @ N ) ) @ ( vEBT_VEBT_low @ X2 @ N ) ) ) ) ).
% in_children_def
thf(fact_8__C161_C,axiom,
~ ? [X_1: nat] : ( vEBT_vebt_member @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) @ X_1 ) ).
% "161"
thf(fact_9__C165_C,axiom,
vEBT_invar_vebt @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) @ ( vEBT_VEBT_low @ xa @ na ) ) @ na ).
% "165"
thf(fact_10_list__update__id,axiom,
! [A: $tType,Xs: list @ A,I: nat] :
( ( list_update @ A @ Xs @ I @ ( nth @ A @ Xs @ I ) )
= Xs ) ).
% list_update_id
thf(fact_11_nth__list__update__neq,axiom,
! [A: $tType,I: nat,J: nat,Xs: list @ A,X: A] :
( ( I != J )
=> ( ( nth @ A @ ( list_update @ A @ Xs @ I @ X ) @ J )
= ( nth @ A @ Xs @ J ) ) ) ).
% nth_list_update_neq
thf(fact_12__C163_C,axiom,
~ ( vEBT_V8194947554948674370ptions @ summary @ i ) ).
% "163"
thf(fact_13_list__update__overwrite,axiom,
! [A: $tType,Xs: list @ A,I: nat,X: A,Y: A] :
( ( list_update @ A @ ( list_update @ A @ Xs @ I @ X ) @ I @ Y )
= ( list_update @ A @ Xs @ I @ Y ) ) ).
% list_update_overwrite
thf(fact_14_not__min__Null__member,axiom,
! [T2: vEBT_VEBT] :
( ~ ( vEBT_VEBT_minNull @ T2 )
=> ? [X_12: nat] : ( vEBT_V8194947554948674370ptions @ T2 @ X_12 ) ) ).
% not_min_Null_member
thf(fact_15_nsprop,axiom,
( ~ ( vEBT_VEBT_minNull @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) )
=> ( summary
= ( vEBT_vebt_insert @ summary @ ( vEBT_VEBT_high @ xa @ na ) ) ) ) ).
% nsprop
thf(fact_16__C11_C,axiom,
! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ ( list_update @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) @ ( vEBT_VEBT_low @ xa @ na ) ) ) ) )
=> ( vEBT_invar_vebt @ X3 @ na ) ) ).
% "11"
thf(fact_17_list__update__swap,axiom,
! [A: $tType,I: nat,I2: nat,Xs: list @ A,X: A,X4: A] :
( ( I != I2 )
=> ( ( list_update @ A @ ( list_update @ A @ Xs @ I @ X ) @ I2 @ X4 )
= ( list_update @ A @ ( list_update @ A @ Xs @ I2 @ X4 ) @ I @ X ) ) ) ).
% list_update_swap
thf(fact_18_False,axiom,
~ ( ( xa = mi )
| ( xa = ma ) ) ).
% False
thf(fact_19_min__Null__member,axiom,
! [T2: vEBT_VEBT,X: nat] :
( ( vEBT_VEBT_minNull @ T2 )
=> ~ ( vEBT_vebt_member @ T2 @ X ) ) ).
% min_Null_member
thf(fact_20_valid__member__both__member__options,axiom,
! [T2: vEBT_VEBT,N2: nat,X: nat] :
( ( vEBT_invar_vebt @ T2 @ N2 )
=> ( ( vEBT_V8194947554948674370ptions @ T2 @ X )
=> ( vEBT_vebt_member @ T2 @ X ) ) ) ).
% valid_member_both_member_options
thf(fact_21_both__member__options__equiv__member,axiom,
! [T2: vEBT_VEBT,N2: nat,X: nat] :
( ( vEBT_invar_vebt @ T2 @ N2 )
=> ( ( vEBT_V8194947554948674370ptions @ T2 @ X )
= ( vEBT_vebt_member @ T2 @ X ) ) ) ).
% both_member_options_equiv_member
thf(fact_22__C5_C,axiom,
( ( mi = ma )
=> ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ treeList ) )
=> ~ ? [X_1: nat] : ( vEBT_V8194947554948674370ptions @ X3 @ X_1 ) ) ) ).
% "5"
thf(fact_23_member__correct,axiom,
! [T2: vEBT_VEBT,N2: nat,X: nat] :
( ( vEBT_invar_vebt @ T2 @ N2 )
=> ( ( vEBT_vebt_member @ T2 @ X )
= ( member2 @ nat @ X @ ( vEBT_set_vebt @ T2 ) ) ) ) ).
% member_correct
thf(fact_24__C0_C,axiom,
! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ treeList ) )
=> ( vEBT_invar_vebt @ X3 @ na ) ) ).
% "0"
thf(fact_25_mimaxrel,axiom,
( ( xa != mi )
& ( xa != ma ) ) ).
% mimaxrel
thf(fact_26__C1_C,axiom,
vEBT_invar_vebt @ summary @ m ).
% "1"
thf(fact_27_abcdef,axiom,
ord_less @ nat @ mi @ xa ).
% abcdef
thf(fact_28__C5_Ohyps_C_I7_J,axiom,
ord_less_eq @ nat @ mi @ ma ).
% "5.hyps"(7)
thf(fact_29__C12_C,axiom,
vEBT_invar_vebt @ ( if @ vEBT_VEBT @ ( vEBT_VEBT_minNull @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) ) @ ( vEBT_vebt_insert @ summary @ ( vEBT_VEBT_high @ xa @ na ) ) @ summary ) @ m ).
% "12"
thf(fact_30_set__vebt__set__vebt_H__valid,axiom,
! [T2: vEBT_VEBT,N2: nat] :
( ( vEBT_invar_vebt @ T2 @ N2 )
=> ( ( vEBT_set_vebt @ T2 )
= ( vEBT_VEBT_set_vebt @ T2 ) ) ) ).
% set_vebt_set_vebt'_valid
thf(fact_31_valid__eq,axiom,
vEBT_VEBT_valid = vEBT_invar_vebt ).
% valid_eq
thf(fact_32_valid__eq1,axiom,
! [T2: vEBT_VEBT,D2: nat] :
( ( vEBT_invar_vebt @ T2 @ D2 )
=> ( vEBT_VEBT_valid @ T2 @ D2 ) ) ).
% valid_eq1
thf(fact_33_valid__eq2,axiom,
! [T2: vEBT_VEBT,D2: nat] :
( ( vEBT_VEBT_valid @ T2 @ D2 )
=> ( vEBT_invar_vebt @ T2 @ D2 ) ) ).
% valid_eq2
thf(fact_34_valid__0__not,axiom,
! [T2: vEBT_VEBT] :
~ ( vEBT_invar_vebt @ T2 @ ( zero_zero @ nat ) ) ).
% valid_0_not
thf(fact_35_valid__tree__deg__neq__0,axiom,
! [T2: vEBT_VEBT] :
~ ( vEBT_invar_vebt @ T2 @ ( zero_zero @ nat ) ) ).
% valid_tree_deg_neq_0
thf(fact_36__C10_C,axiom,
( ( vEBT_vebt_insert @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ mi @ ma ) ) @ deg @ treeList @ summary ) @ xa )
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ mi @ ( ord_max @ nat @ xa @ ma ) ) ) @ deg @ ( list_update @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) @ ( vEBT_VEBT_low @ xa @ na ) ) ) @ ( if @ vEBT_VEBT @ ( vEBT_VEBT_minNull @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) ) @ ( vEBT_vebt_insert @ summary @ ( vEBT_VEBT_high @ xa @ na ) ) @ summary ) ) ) ).
% "10"
thf(fact_37_in__set__member,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
= ( member @ A @ Xs @ X ) ) ).
% in_set_member
thf(fact_38_deg__deg__n,axiom,
! [Info: option @ ( product_prod @ nat @ nat ),Deg: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,N2: nat] :
( ( vEBT_invar_vebt @ ( vEBT_Node @ Info @ Deg @ TreeList2 @ Summary ) @ N2 )
=> ( Deg = N2 ) ) ).
% deg_deg_n
thf(fact_39_in__set__insert,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( insert @ A @ X @ Xs )
= Xs ) ) ).
% in_set_insert
thf(fact_40_list__ex1__iff,axiom,
! [A: $tType] :
( ( list_ex1 @ A )
= ( ^ [P: A > $o,Xs2: list @ A] :
? [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs2 ) )
& ( P @ X2 )
& ! [Y2: A] :
( ( ( member2 @ A @ Y2 @ ( set2 @ A @ Xs2 ) )
& ( P @ Y2 ) )
=> ( Y2 = X2 ) ) ) ) ) ).
% list_ex1_iff
thf(fact_41_deg__not__0,axiom,
! [T2: vEBT_VEBT,N2: nat] :
( ( vEBT_invar_vebt @ T2 @ N2 )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ).
% deg_not_0
thf(fact_42_mi__eq__ma__no__ch,axiom,
! [Mi: nat,Ma: nat,Deg: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT] :
( ( vEBT_invar_vebt @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ Deg @ TreeList2 @ Summary ) @ Deg )
=> ( ( Mi = Ma )
=> ( ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ~ ? [X_1: nat] : ( vEBT_V8194947554948674370ptions @ X3 @ X_1 ) )
& ~ ? [X_1: nat] : ( vEBT_V8194947554948674370ptions @ Summary @ X_1 ) ) ) ) ).
% mi_eq_ma_no_ch
thf(fact_43__C3_C,axiom,
( deg
= ( plus_plus @ nat @ na @ m ) ) ).
% "3"
thf(fact_44_buildup__gives__valid,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( vEBT_invar_vebt @ ( vEBT_vebt_buildup @ N2 ) @ N2 ) ) ).
% buildup_gives_valid
thf(fact_45_mem__Collect__eq,axiom,
! [A: $tType,A3: A,P2: A > $o] :
( ( member2 @ A @ A3 @ ( collect @ A @ P2 ) )
= ( P2 @ A3 ) ) ).
% mem_Collect_eq
thf(fact_46_Collect__mem__eq,axiom,
! [A: $tType,A4: set @ A] :
( ( collect @ A
@ ^ [X2: A] : ( member2 @ A @ X2 @ A4 ) )
= A4 ) ).
% Collect_mem_eq
thf(fact_47_Collect__cong,axiom,
! [A: $tType,P2: A > $o,Q: A > $o] :
( ! [X5: A] :
( ( P2 @ X5 )
= ( Q @ X5 ) )
=> ( ( collect @ A @ P2 )
= ( collect @ A @ Q ) ) ) ).
% Collect_cong
thf(fact_48_ext,axiom,
! [B: $tType,A: $tType,F2: A > B,G: A > B] :
( ! [X5: A] :
( ( F2 @ X5 )
= ( G @ X5 ) )
=> ( F2 = G ) ) ).
% ext
thf(fact_49_max__0R,axiom,
! [N2: nat] :
( ( ord_max @ nat @ N2 @ ( zero_zero @ nat ) )
= N2 ) ).
% max_0R
thf(fact_50_max__0L,axiom,
! [N2: nat] :
( ( ord_max @ nat @ ( zero_zero @ nat ) @ N2 )
= N2 ) ).
% max_0L
thf(fact_51_max__nat_Oright__neutral,axiom,
! [A3: nat] :
( ( ord_max @ nat @ A3 @ ( zero_zero @ nat ) )
= A3 ) ).
% max_nat.right_neutral
thf(fact_52_max__nat_Oneutr__eq__iff,axiom,
! [A3: nat,B2: nat] :
( ( ( zero_zero @ nat )
= ( ord_max @ nat @ A3 @ B2 ) )
= ( ( A3
= ( zero_zero @ nat ) )
& ( B2
= ( zero_zero @ nat ) ) ) ) ).
% max_nat.neutr_eq_iff
thf(fact_53_max__nat_Oleft__neutral,axiom,
! [A3: nat] :
( ( ord_max @ nat @ ( zero_zero @ nat ) @ A3 )
= A3 ) ).
% max_nat.left_neutral
thf(fact_54_max__nat_Oeq__neutr__iff,axiom,
! [A3: nat,B2: nat] :
( ( ( ord_max @ nat @ A3 @ B2 )
= ( zero_zero @ nat ) )
= ( ( A3
= ( zero_zero @ nat ) )
& ( B2
= ( zero_zero @ nat ) ) ) ) ).
% max_nat.eq_neutr_iff
thf(fact_55_max__less__iff__conj,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less @ A @ ( ord_max @ A @ X @ Y ) @ Z )
= ( ( ord_less @ A @ X @ Z )
& ( ord_less @ A @ Y @ Z ) ) ) ) ).
% max_less_iff_conj
thf(fact_56_max_Oabsorb4,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_max @ A @ A3 @ B2 )
= B2 ) ) ) ).
% max.absorb4
thf(fact_57_max_Oabsorb3,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ( ord_max @ A @ A3 @ B2 )
= A3 ) ) ) ).
% max.absorb3
thf(fact_58_max_Obounded__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less_eq @ A @ ( ord_max @ A @ B2 @ C2 ) @ A3 )
= ( ( ord_less_eq @ A @ B2 @ A3 )
& ( ord_less_eq @ A @ C2 @ A3 ) ) ) ) ).
% max.bounded_iff
thf(fact_59_max_Oabsorb2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_max @ A @ A3 @ B2 )
= B2 ) ) ) ).
% max.absorb2
thf(fact_60_max_Oidem,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A] :
( ( ord_max @ A @ A3 @ A3 )
= A3 ) ) ).
% max.idem
thf(fact_61_max_Oleft__idem,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_max @ A @ A3 @ ( ord_max @ A @ A3 @ B2 ) )
= ( ord_max @ A @ A3 @ B2 ) ) ) ).
% max.left_idem
thf(fact_62_max_Oright__idem,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_max @ A @ ( ord_max @ A @ A3 @ B2 ) @ B2 )
= ( ord_max @ A @ A3 @ B2 ) ) ) ).
% max.right_idem
thf(fact_63_bot__nat__0_Onot__eq__extremum,axiom,
! [A3: nat] :
( ( A3
!= ( zero_zero @ nat ) )
= ( ord_less @ nat @ ( zero_zero @ nat ) @ A3 ) ) ).
% bot_nat_0.not_eq_extremum
thf(fact_64_neq0__conv,axiom,
! [N2: nat] :
( ( N2
!= ( zero_zero @ nat ) )
= ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ).
% neq0_conv
thf(fact_65_less__nat__zero__code,axiom,
! [N2: nat] :
~ ( ord_less @ nat @ N2 @ ( zero_zero @ nat ) ) ).
% less_nat_zero_code
thf(fact_66_bot__nat__0_Oextremum,axiom,
! [A3: nat] : ( ord_less_eq @ nat @ ( zero_zero @ nat ) @ A3 ) ).
% bot_nat_0.extremum
thf(fact_67_le0,axiom,
! [N2: nat] : ( ord_less_eq @ nat @ ( zero_zero @ nat ) @ N2 ) ).
% le0
thf(fact_68_add__is__0,axiom,
! [M: nat,N2: nat] :
( ( ( plus_plus @ nat @ M @ N2 )
= ( zero_zero @ nat ) )
= ( ( M
= ( zero_zero @ nat ) )
& ( N2
= ( zero_zero @ nat ) ) ) ) ).
% add_is_0
thf(fact_69_Nat_Oadd__0__right,axiom,
! [M: nat] :
( ( plus_plus @ nat @ M @ ( zero_zero @ nat ) )
= M ) ).
% Nat.add_0_right
thf(fact_70_nat__add__left__cancel__less,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ ( plus_plus @ nat @ K @ M ) @ ( plus_plus @ nat @ K @ N2 ) )
= ( ord_less @ nat @ M @ N2 ) ) ).
% nat_add_left_cancel_less
thf(fact_71_max_Oabsorb1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( ord_max @ A @ A3 @ B2 )
= A3 ) ) ) ).
% max.absorb1
thf(fact_72_nat__add__left__cancel__le,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( plus_plus @ nat @ K @ M ) @ ( plus_plus @ nat @ K @ N2 ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ).
% nat_add_left_cancel_le
thf(fact_73_add__gr__0,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( plus_plus @ nat @ M @ N2 ) )
= ( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
| ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ).
% add_gr_0
thf(fact_74_plus__nat_Oadd__0,axiom,
! [N2: nat] :
( ( plus_plus @ nat @ ( zero_zero @ nat ) @ N2 )
= N2 ) ).
% plus_nat.add_0
thf(fact_75_add__eq__self__zero,axiom,
! [M: nat,N2: nat] :
( ( ( plus_plus @ nat @ M @ N2 )
= M )
=> ( N2
= ( zero_zero @ nat ) ) ) ).
% add_eq_self_zero
thf(fact_76_add__lessD1,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less @ nat @ ( plus_plus @ nat @ I @ J ) @ K )
=> ( ord_less @ nat @ I @ K ) ) ).
% add_lessD1
thf(fact_77_add__less__mono,axiom,
! [I: nat,J: nat,K: nat,L: nat] :
( ( ord_less @ nat @ I @ J )
=> ( ( ord_less @ nat @ K @ L )
=> ( ord_less @ nat @ ( plus_plus @ nat @ I @ K ) @ ( plus_plus @ nat @ J @ L ) ) ) ) ).
% add_less_mono
thf(fact_78_not__add__less1,axiom,
! [I: nat,J: nat] :
~ ( ord_less @ nat @ ( plus_plus @ nat @ I @ J ) @ I ) ).
% not_add_less1
thf(fact_79_not__add__less2,axiom,
! [J: nat,I: nat] :
~ ( ord_less @ nat @ ( plus_plus @ nat @ J @ I ) @ I ) ).
% not_add_less2
thf(fact_80_add__less__mono1,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less @ nat @ I @ J )
=> ( ord_less @ nat @ ( plus_plus @ nat @ I @ K ) @ ( plus_plus @ nat @ J @ K ) ) ) ).
% add_less_mono1
thf(fact_81_trans__less__add1,axiom,
! [I: nat,J: nat,M: nat] :
( ( ord_less @ nat @ I @ J )
=> ( ord_less @ nat @ I @ ( plus_plus @ nat @ J @ M ) ) ) ).
% trans_less_add1
thf(fact_82_trans__less__add2,axiom,
! [I: nat,J: nat,M: nat] :
( ( ord_less @ nat @ I @ J )
=> ( ord_less @ nat @ I @ ( plus_plus @ nat @ M @ J ) ) ) ).
% trans_less_add2
thf(fact_83_less__add__eq__less,axiom,
! [K: nat,L: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ K @ L )
=> ( ( ( plus_plus @ nat @ M @ L )
= ( plus_plus @ nat @ K @ N2 ) )
=> ( ord_less @ nat @ M @ N2 ) ) ) ).
% less_add_eq_less
thf(fact_84_add__leE,axiom,
! [M: nat,K: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( plus_plus @ nat @ M @ K ) @ N2 )
=> ~ ( ( ord_less_eq @ nat @ M @ N2 )
=> ~ ( ord_less_eq @ nat @ K @ N2 ) ) ) ).
% add_leE
thf(fact_85_le__add1,axiom,
! [N2: nat,M: nat] : ( ord_less_eq @ nat @ N2 @ ( plus_plus @ nat @ N2 @ M ) ) ).
% le_add1
thf(fact_86_le__add2,axiom,
! [N2: nat,M: nat] : ( ord_less_eq @ nat @ N2 @ ( plus_plus @ nat @ M @ N2 ) ) ).
% le_add2
thf(fact_87_add__leD1,axiom,
! [M: nat,K: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( plus_plus @ nat @ M @ K ) @ N2 )
=> ( ord_less_eq @ nat @ M @ N2 ) ) ).
% add_leD1
thf(fact_88_add__leD2,axiom,
! [M: nat,K: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( plus_plus @ nat @ M @ K ) @ N2 )
=> ( ord_less_eq @ nat @ K @ N2 ) ) ).
% add_leD2
thf(fact_89_le__Suc__ex,axiom,
! [K: nat,L: nat] :
( ( ord_less_eq @ nat @ K @ L )
=> ? [N3: nat] :
( L
= ( plus_plus @ nat @ K @ N3 ) ) ) ).
% le_Suc_ex
thf(fact_90_add__le__mono,axiom,
! [I: nat,J: nat,K: nat,L: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( ord_less_eq @ nat @ K @ L )
=> ( ord_less_eq @ nat @ ( plus_plus @ nat @ I @ K ) @ ( plus_plus @ nat @ J @ L ) ) ) ) ).
% add_le_mono
thf(fact_91_add__le__mono1,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ord_less_eq @ nat @ ( plus_plus @ nat @ I @ K ) @ ( plus_plus @ nat @ J @ K ) ) ) ).
% add_le_mono1
thf(fact_92_trans__le__add1,axiom,
! [I: nat,J: nat,M: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ord_less_eq @ nat @ I @ ( plus_plus @ nat @ J @ M ) ) ) ).
% trans_le_add1
thf(fact_93_trans__le__add2,axiom,
! [I: nat,J: nat,M: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ord_less_eq @ nat @ I @ ( plus_plus @ nat @ M @ J ) ) ) ).
% trans_le_add2
thf(fact_94_nat__le__iff__add,axiom,
( ( ord_less_eq @ nat )
= ( ^ [M2: nat,N: nat] :
? [K2: nat] :
( N
= ( plus_plus @ nat @ M2 @ K2 ) ) ) ) ).
% nat_le_iff_add
thf(fact_95_nat__add__max__left,axiom,
! [M: nat,N2: nat,Q2: nat] :
( ( plus_plus @ nat @ ( ord_max @ nat @ M @ N2 ) @ Q2 )
= ( ord_max @ nat @ ( plus_plus @ nat @ M @ Q2 ) @ ( plus_plus @ nat @ N2 @ Q2 ) ) ) ).
% nat_add_max_left
thf(fact_96_nat__add__max__right,axiom,
! [M: nat,N2: nat,Q2: nat] :
( ( plus_plus @ nat @ M @ ( ord_max @ nat @ N2 @ Q2 ) )
= ( ord_max @ nat @ ( plus_plus @ nat @ M @ N2 ) @ ( plus_plus @ nat @ M @ Q2 ) ) ) ).
% nat_add_max_right
thf(fact_97_subset__code_I1_J,axiom,
! [A: $tType,Xs: list @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs ) @ B3 )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ( member2 @ A @ X2 @ B3 ) ) ) ) ).
% subset_code(1)
thf(fact_98_less__imp__add__positive,axiom,
! [I: nat,J: nat] :
( ( ord_less @ nat @ I @ J )
=> ? [K3: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ K3 )
& ( ( plus_plus @ nat @ I @ K3 )
= J ) ) ) ).
% less_imp_add_positive
thf(fact_99_mono__nat__linear__lb,axiom,
! [F2: nat > nat,M: nat,K: nat] :
( ! [M3: nat,N3: nat] :
( ( ord_less @ nat @ M3 @ N3 )
=> ( ord_less @ nat @ ( F2 @ M3 ) @ ( F2 @ N3 ) ) )
=> ( ord_less_eq @ nat @ ( plus_plus @ nat @ ( F2 @ M ) @ K ) @ ( F2 @ ( plus_plus @ nat @ M @ K ) ) ) ) ).
% mono_nat_linear_lb
thf(fact_100_set__update__subsetI,axiom,
! [A: $tType,Xs: list @ A,A4: set @ A,X: A,I: nat] :
( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs ) @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ ( list_update @ A @ Xs @ I @ X ) ) @ A4 ) ) ) ).
% set_update_subsetI
thf(fact_101_measure__induct,axiom,
! [B: $tType,A: $tType] :
( ( wellorder @ B )
=> ! [F2: A > B,P2: A > $o,A3: A] :
( ! [X5: A] :
( ! [Y3: A] :
( ( ord_less @ B @ ( F2 @ Y3 ) @ ( F2 @ X5 ) )
=> ( P2 @ Y3 ) )
=> ( P2 @ X5 ) )
=> ( P2 @ A3 ) ) ) ).
% measure_induct
thf(fact_102_measure__induct__rule,axiom,
! [B: $tType,A: $tType] :
( ( wellorder @ B )
=> ! [F2: A > B,P2: A > $o,A3: A] :
( ! [X5: A] :
( ! [Y3: A] :
( ( ord_less @ B @ ( F2 @ Y3 ) @ ( F2 @ X5 ) )
=> ( P2 @ Y3 ) )
=> ( P2 @ X5 ) )
=> ( P2 @ A3 ) ) ) ).
% measure_induct_rule
thf(fact_103_nat__neq__iff,axiom,
! [M: nat,N2: nat] :
( ( M != N2 )
= ( ( ord_less @ nat @ M @ N2 )
| ( ord_less @ nat @ N2 @ M ) ) ) ).
% nat_neq_iff
thf(fact_104_less__not__refl,axiom,
! [N2: nat] :
~ ( ord_less @ nat @ N2 @ N2 ) ).
% less_not_refl
thf(fact_105_less__not__refl2,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ N2 @ M )
=> ( M != N2 ) ) ).
% less_not_refl2
thf(fact_106_less__not__refl3,axiom,
! [S: nat,T2: nat] :
( ( ord_less @ nat @ S @ T2 )
=> ( S != T2 ) ) ).
% less_not_refl3
thf(fact_107_less__irrefl__nat,axiom,
! [N2: nat] :
~ ( ord_less @ nat @ N2 @ N2 ) ).
% less_irrefl_nat
thf(fact_108_nat__less__induct,axiom,
! [P2: nat > $o,N2: nat] :
( ! [N3: nat] :
( ! [M4: nat] :
( ( ord_less @ nat @ M4 @ N3 )
=> ( P2 @ M4 ) )
=> ( P2 @ N3 ) )
=> ( P2 @ N2 ) ) ).
% nat_less_induct
thf(fact_109_infinite__descent,axiom,
! [P2: nat > $o,N2: nat] :
( ! [N3: nat] :
( ~ ( P2 @ N3 )
=> ? [M4: nat] :
( ( ord_less @ nat @ M4 @ N3 )
& ~ ( P2 @ M4 ) ) )
=> ( P2 @ N2 ) ) ).
% infinite_descent
thf(fact_110_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_111_infinite__descent__measure,axiom,
! [A: $tType,P2: A > $o,V: A > nat,X: A] :
( ! [X5: A] :
( ~ ( P2 @ X5 )
=> ? [Y3: A] :
( ( ord_less @ nat @ ( V @ Y3 ) @ ( V @ X5 ) )
& ~ ( P2 @ Y3 ) ) )
=> ( P2 @ X ) ) ).
% infinite_descent_measure
thf(fact_112_le__refl,axiom,
! [N2: nat] : ( ord_less_eq @ nat @ N2 @ N2 ) ).
% le_refl
thf(fact_113_le__trans,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( ord_less_eq @ nat @ J @ K )
=> ( ord_less_eq @ nat @ I @ K ) ) ) ).
% le_trans
thf(fact_114_eq__imp__le,axiom,
! [M: nat,N2: nat] :
( ( M = N2 )
=> ( ord_less_eq @ nat @ M @ N2 ) ) ).
% eq_imp_le
thf(fact_115_le__antisym,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( ord_less_eq @ nat @ N2 @ M )
=> ( M = N2 ) ) ) ).
% le_antisym
thf(fact_116_nat__le__linear,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
| ( ord_less_eq @ nat @ N2 @ M ) ) ).
% nat_le_linear
thf(fact_117_Nat_Oex__has__greatest__nat,axiom,
! [P2: nat > $o,K: nat,B2: nat] :
( ( P2 @ K )
=> ( ! [Y4: nat] :
( ( P2 @ Y4 )
=> ( ord_less_eq @ nat @ Y4 @ B2 ) )
=> ? [X5: nat] :
( ( P2 @ X5 )
& ! [Y3: nat] :
( ( P2 @ Y3 )
=> ( ord_less_eq @ nat @ Y3 @ X5 ) ) ) ) ) ).
% Nat.ex_has_greatest_nat
thf(fact_118_max_Oassoc,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_max @ A @ ( ord_max @ A @ A3 @ B2 ) @ C2 )
= ( ord_max @ A @ A3 @ ( ord_max @ A @ B2 @ C2 ) ) ) ) ).
% max.assoc
thf(fact_119_max_Ocommute,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_max @ A )
= ( ^ [A5: A,B4: A] : ( ord_max @ A @ B4 @ A5 ) ) ) ) ).
% max.commute
thf(fact_120_max_Oleft__commute,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_max @ A @ B2 @ ( ord_max @ A @ A3 @ C2 ) )
= ( ord_max @ A @ A3 @ ( ord_max @ A @ B2 @ C2 ) ) ) ) ).
% max.left_commute
thf(fact_121_bot__nat__0_Oextremum__strict,axiom,
! [A3: nat] :
~ ( ord_less @ nat @ A3 @ ( zero_zero @ nat ) ) ).
% bot_nat_0.extremum_strict
thf(fact_122_gr0I,axiom,
! [N2: nat] :
( ( N2
!= ( zero_zero @ nat ) )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ).
% gr0I
thf(fact_123_not__gr0,axiom,
! [N2: nat] :
( ( ~ ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) )
= ( N2
= ( zero_zero @ nat ) ) ) ).
% not_gr0
thf(fact_124_not__less0,axiom,
! [N2: nat] :
~ ( ord_less @ nat @ N2 @ ( zero_zero @ nat ) ) ).
% not_less0
thf(fact_125_less__zeroE,axiom,
! [N2: nat] :
~ ( ord_less @ nat @ N2 @ ( zero_zero @ nat ) ) ).
% less_zeroE
thf(fact_126_gr__implies__not0,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ( N2
!= ( zero_zero @ nat ) ) ) ).
% gr_implies_not0
thf(fact_127_infinite__descent0,axiom,
! [P2: nat > $o,N2: nat] :
( ( P2 @ ( zero_zero @ nat ) )
=> ( ! [N3: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 )
=> ( ~ ( P2 @ N3 )
=> ? [M4: nat] :
( ( ord_less @ nat @ M4 @ N3 )
& ~ ( P2 @ M4 ) ) ) )
=> ( P2 @ N2 ) ) ) ).
% infinite_descent0
thf(fact_128_infinite__descent0__measure,axiom,
! [A: $tType,V: A > nat,P2: A > $o,X: A] :
( ! [X5: A] :
( ( ( V @ X5 )
= ( zero_zero @ nat ) )
=> ( P2 @ X5 ) )
=> ( ! [X5: A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( V @ X5 ) )
=> ( ~ ( P2 @ X5 )
=> ? [Y3: A] :
( ( ord_less @ nat @ ( V @ Y3 ) @ ( V @ X5 ) )
& ~ ( P2 @ Y3 ) ) ) )
=> ( P2 @ X ) ) ) ).
% infinite_descent0_measure
thf(fact_129_less__eq__nat_Osimps_I1_J,axiom,
! [N2: nat] : ( ord_less_eq @ nat @ ( zero_zero @ nat ) @ N2 ) ).
% less_eq_nat.simps(1)
thf(fact_130_bot__nat__0_Oextremum__unique,axiom,
! [A3: nat] :
( ( ord_less_eq @ nat @ A3 @ ( zero_zero @ nat ) )
= ( A3
= ( zero_zero @ nat ) ) ) ).
% bot_nat_0.extremum_unique
thf(fact_131_bot__nat__0_Oextremum__uniqueI,axiom,
! [A3: nat] :
( ( ord_less_eq @ nat @ A3 @ ( zero_zero @ nat ) )
=> ( A3
= ( zero_zero @ nat ) ) ) ).
% bot_nat_0.extremum_uniqueI
thf(fact_132_le__0__eq,axiom,
! [N2: nat] :
( ( ord_less_eq @ nat @ N2 @ ( zero_zero @ nat ) )
= ( N2
= ( zero_zero @ nat ) ) ) ).
% le_0_eq
thf(fact_133_nat__less__le,axiom,
( ( ord_less @ nat )
= ( ^ [M2: nat,N: nat] :
( ( ord_less_eq @ nat @ M2 @ N )
& ( M2 != N ) ) ) ) ).
% nat_less_le
thf(fact_134_less__imp__le__nat,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ( ord_less_eq @ nat @ M @ N2 ) ) ).
% less_imp_le_nat
thf(fact_135_le__eq__less__or__eq,axiom,
( ( ord_less_eq @ nat )
= ( ^ [M2: nat,N: nat] :
( ( ord_less @ nat @ M2 @ N )
| ( M2 = N ) ) ) ) ).
% le_eq_less_or_eq
thf(fact_136_less__or__eq__imp__le,axiom,
! [M: nat,N2: nat] :
( ( ( ord_less @ nat @ M @ N2 )
| ( M = N2 ) )
=> ( ord_less_eq @ nat @ M @ N2 ) ) ).
% less_or_eq_imp_le
thf(fact_137_le__neq__implies__less,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( M != N2 )
=> ( ord_less @ nat @ M @ N2 ) ) ) ).
% le_neq_implies_less
thf(fact_138_less__mono__imp__le__mono,axiom,
! [F2: nat > nat,I: nat,J: nat] :
( ! [I3: nat,J2: nat] :
( ( ord_less @ nat @ I3 @ J2 )
=> ( ord_less @ nat @ ( F2 @ I3 ) @ ( F2 @ J2 ) ) )
=> ( ( ord_less_eq @ nat @ I @ J )
=> ( ord_less_eq @ nat @ ( F2 @ I ) @ ( F2 @ J ) ) ) ) ).
% less_mono_imp_le_mono
thf(fact_139_max_Omono,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [C2: A,A3: A,D2: A,B2: A] :
( ( ord_less_eq @ A @ C2 @ A3 )
=> ( ( ord_less_eq @ A @ D2 @ B2 )
=> ( ord_less_eq @ A @ ( ord_max @ A @ C2 @ D2 ) @ ( ord_max @ A @ A3 @ B2 ) ) ) ) ) ).
% max.mono
thf(fact_140_max_OorderE,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( A3
= ( ord_max @ A @ A3 @ B2 ) ) ) ) ).
% max.orderE
thf(fact_141_max_OorderI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( A3
= ( ord_max @ A @ A3 @ B2 ) )
=> ( ord_less_eq @ A @ B2 @ A3 ) ) ) ).
% max.orderI
thf(fact_142_max_OboundedE,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less_eq @ A @ ( ord_max @ A @ B2 @ C2 ) @ A3 )
=> ~ ( ( ord_less_eq @ A @ B2 @ A3 )
=> ~ ( ord_less_eq @ A @ C2 @ A3 ) ) ) ) ).
% max.boundedE
thf(fact_143_max_OboundedI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( ord_less_eq @ A @ C2 @ A3 )
=> ( ord_less_eq @ A @ ( ord_max @ A @ B2 @ C2 ) @ A3 ) ) ) ) ).
% max.boundedI
thf(fact_144_max_Oorder__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [B4: A,A5: A] :
( A5
= ( ord_max @ A @ A5 @ B4 ) ) ) ) ) ).
% max.order_iff
thf(fact_145_max_Ocobounded1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ A @ A3 @ ( ord_max @ A @ A3 @ B2 ) ) ) ).
% max.cobounded1
thf(fact_146_max_Ocobounded2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,A3: A] : ( ord_less_eq @ A @ B2 @ ( ord_max @ A @ A3 @ B2 ) ) ) ).
% max.cobounded2
thf(fact_147_le__max__iff__disj,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Z: A,X: A,Y: A] :
( ( ord_less_eq @ A @ Z @ ( ord_max @ A @ X @ Y ) )
= ( ( ord_less_eq @ A @ Z @ X )
| ( ord_less_eq @ A @ Z @ Y ) ) ) ) ).
% le_max_iff_disj
thf(fact_148_max_Oabsorb__iff1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [B4: A,A5: A] :
( ( ord_max @ A @ A5 @ B4 )
= A5 ) ) ) ) ).
% max.absorb_iff1
thf(fact_149_max_Oabsorb__iff2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [A5: A,B4: A] :
( ( ord_max @ A @ A5 @ B4 )
= B4 ) ) ) ) ).
% max.absorb_iff2
thf(fact_150_max_OcoboundedI1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ C2 @ A3 )
=> ( ord_less_eq @ A @ C2 @ ( ord_max @ A @ A3 @ B2 ) ) ) ) ).
% max.coboundedI1
thf(fact_151_max_OcoboundedI2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less_eq @ A @ C2 @ B2 )
=> ( ord_less_eq @ A @ C2 @ ( ord_max @ A @ A3 @ B2 ) ) ) ) ).
% max.coboundedI2
thf(fact_152_less__max__iff__disj,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Z: A,X: A,Y: A] :
( ( ord_less @ A @ Z @ ( ord_max @ A @ X @ Y ) )
= ( ( ord_less @ A @ Z @ X )
| ( ord_less @ A @ Z @ Y ) ) ) ) ).
% less_max_iff_disj
thf(fact_153_max_Ostrict__boundedE,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less @ A @ ( ord_max @ A @ B2 @ C2 ) @ A3 )
=> ~ ( ( ord_less @ A @ B2 @ A3 )
=> ~ ( ord_less @ A @ C2 @ A3 ) ) ) ) ).
% max.strict_boundedE
thf(fact_154_max_Ostrict__order__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_less @ A )
= ( ^ [B4: A,A5: A] :
( ( A5
= ( ord_max @ A @ A5 @ B4 ) )
& ( A5 != B4 ) ) ) ) ) ).
% max.strict_order_iff
thf(fact_155_max_Ostrict__coboundedI1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ C2 @ A3 )
=> ( ord_less @ A @ C2 @ ( ord_max @ A @ A3 @ B2 ) ) ) ) ).
% max.strict_coboundedI1
thf(fact_156_max_Ostrict__coboundedI2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less @ A @ C2 @ B2 )
=> ( ord_less @ A @ C2 @ ( ord_max @ A @ A3 @ B2 ) ) ) ) ).
% max.strict_coboundedI2
thf(fact_157_ex__least__nat__le,axiom,
! [P2: nat > $o,N2: nat] :
( ( P2 @ N2 )
=> ( ~ ( P2 @ ( zero_zero @ nat ) )
=> ? [K3: nat] :
( ( ord_less_eq @ nat @ K3 @ N2 )
& ! [I4: nat] :
( ( ord_less @ nat @ I4 @ K3 )
=> ~ ( P2 @ I4 ) )
& ( P2 @ K3 ) ) ) ) ).
% ex_least_nat_le
thf(fact_158_add__less__same__cancel1,axiom,
! [A: $tType] :
( ( ordere1937475149494474687imp_le @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ ( plus_plus @ A @ B2 @ A3 ) @ B2 )
= ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% add_less_same_cancel1
thf(fact_159_add__less__same__cancel2,axiom,
! [A: $tType] :
( ( ordere1937475149494474687imp_le @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ A3 @ B2 ) @ B2 )
= ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% add_less_same_cancel2
thf(fact_160_less__add__same__cancel1,axiom,
! [A: $tType] :
( ( ordere1937475149494474687imp_le @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( plus_plus @ A @ A3 @ B2 ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ B2 ) ) ) ).
% less_add_same_cancel1
thf(fact_161_less__add__same__cancel2,axiom,
! [A: $tType] :
( ( ordere1937475149494474687imp_le @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( plus_plus @ A @ B2 @ A3 ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ B2 ) ) ) ).
% less_add_same_cancel2
thf(fact_162_double__add__less__zero__iff__single__add__less__zero,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( plus_plus @ A @ A3 @ A3 ) @ ( zero_zero @ A ) )
= ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% double_add_less_zero_iff_single_add_less_zero
thf(fact_163_zero__less__double__add__iff__zero__less__single__add,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ A3 @ A3 ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% zero_less_double_add_iff_zero_less_single_add
thf(fact_164_add__le__same__cancel1,axiom,
! [A: $tType] :
( ( ordere1937475149494474687imp_le @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ B2 @ A3 ) @ B2 )
= ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% add_le_same_cancel1
thf(fact_165_add__le__same__cancel2,axiom,
! [A: $tType] :
( ( ordere1937475149494474687imp_le @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ A3 @ B2 ) @ B2 )
= ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% add_le_same_cancel2
thf(fact_166_le__add__same__cancel1,axiom,
! [A: $tType] :
( ( ordere1937475149494474687imp_le @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ ( plus_plus @ A @ A3 @ B2 ) )
= ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 ) ) ) ).
% le_add_same_cancel1
thf(fact_167_le__add__same__cancel2,axiom,
! [A: $tType] :
( ( ordere1937475149494474687imp_le @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ ( plus_plus @ A @ B2 @ A3 ) )
= ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 ) ) ) ).
% le_add_same_cancel2
thf(fact_168_double__add__le__zero__iff__single__add__le__zero,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ A3 @ A3 ) @ ( zero_zero @ A ) )
= ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% double_add_le_zero_iff_single_add_le_zero
thf(fact_169_zero__le__double__add__iff__zero__le__single__add,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ A3 @ A3 ) )
= ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% zero_le_double_add_iff_zero_le_single_add
thf(fact_170_add__right__cancel,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ( plus_plus @ A @ B2 @ A3 )
= ( plus_plus @ A @ C2 @ A3 ) )
= ( B2 = C2 ) ) ) ).
% add_right_cancel
thf(fact_171_add__left__cancel,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ( plus_plus @ A @ A3 @ B2 )
= ( plus_plus @ A @ A3 @ C2 ) )
= ( B2 = C2 ) ) ) ).
% add_left_cancel
thf(fact_172_le__zero__eq,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [N2: A] :
( ( ord_less_eq @ A @ N2 @ ( zero_zero @ A ) )
= ( N2
= ( zero_zero @ A ) ) ) ) ).
% le_zero_eq
thf(fact_173_not__gr__zero,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [N2: A] :
( ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ N2 ) )
= ( N2
= ( zero_zero @ A ) ) ) ) ).
% not_gr_zero
thf(fact_174_add__le__cancel__right,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ C2 ) )
= ( ord_less_eq @ A @ A3 @ B2 ) ) ) ).
% add_le_cancel_right
thf(fact_175_add__le__cancel__left,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ C2 @ A3 ) @ ( plus_plus @ A @ C2 @ B2 ) )
= ( ord_less_eq @ A @ A3 @ B2 ) ) ) ).
% add_le_cancel_left
thf(fact_176_add__0,axiom,
! [A: $tType] :
( ( monoid_add @ A )
=> ! [A3: A] :
( ( plus_plus @ A @ ( zero_zero @ A ) @ A3 )
= A3 ) ) ).
% add_0
thf(fact_177_zero__eq__add__iff__both__eq__0,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [X: A,Y: A] :
( ( ( zero_zero @ A )
= ( plus_plus @ A @ X @ Y ) )
= ( ( X
= ( zero_zero @ A ) )
& ( Y
= ( zero_zero @ A ) ) ) ) ) ).
% zero_eq_add_iff_both_eq_0
thf(fact_178_add__eq__0__iff__both__eq__0,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ 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_179_add__cancel__right__right,axiom,
! [A: $tType] :
( ( cancel1802427076303600483id_add @ A )
=> ! [A3: A,B2: A] :
( ( A3
= ( plus_plus @ A @ A3 @ B2 ) )
= ( B2
= ( zero_zero @ A ) ) ) ) ).
% add_cancel_right_right
thf(fact_180_add__cancel__right__left,axiom,
! [A: $tType] :
( ( cancel1802427076303600483id_add @ A )
=> ! [A3: A,B2: A] :
( ( A3
= ( plus_plus @ A @ B2 @ A3 ) )
= ( B2
= ( zero_zero @ A ) ) ) ) ).
% add_cancel_right_left
thf(fact_181_add__cancel__left__right,axiom,
! [A: $tType] :
( ( cancel1802427076303600483id_add @ A )
=> ! [A3: A,B2: A] :
( ( ( plus_plus @ A @ A3 @ B2 )
= A3 )
= ( B2
= ( zero_zero @ A ) ) ) ) ).
% add_cancel_left_right
thf(fact_182_add__cancel__left__left,axiom,
! [A: $tType] :
( ( cancel1802427076303600483id_add @ A )
=> ! [B2: A,A3: A] :
( ( ( plus_plus @ A @ B2 @ A3 )
= A3 )
= ( B2
= ( zero_zero @ A ) ) ) ) ).
% add_cancel_left_left
thf(fact_183_double__zero__sym,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( ( zero_zero @ A )
= ( plus_plus @ A @ A3 @ A3 ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% double_zero_sym
thf(fact_184_add_Oright__neutral,axiom,
! [A: $tType] :
( ( monoid_add @ A )
=> ! [A3: A] :
( ( plus_plus @ A @ A3 @ ( zero_zero @ A ) )
= A3 ) ) ).
% add.right_neutral
thf(fact_185_add__less__cancel__right,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ C2 ) )
= ( ord_less @ A @ A3 @ B2 ) ) ) ).
% add_less_cancel_right
thf(fact_186_add__less__cancel__left,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ C2 @ A3 ) @ ( plus_plus @ A @ C2 @ B2 ) )
= ( ord_less @ A @ A3 @ B2 ) ) ) ).
% add_less_cancel_left
thf(fact_187_zero__reorient,axiom,
! [A: $tType] :
( ( zero @ A )
=> ! [X: A] :
( ( ( zero_zero @ A )
= X )
= ( X
= ( zero_zero @ A ) ) ) ) ).
% zero_reorient
thf(fact_188_add__right__imp__eq,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ( plus_plus @ A @ B2 @ A3 )
= ( plus_plus @ A @ C2 @ A3 ) )
=> ( B2 = C2 ) ) ) ).
% add_right_imp_eq
thf(fact_189_add__left__imp__eq,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ( plus_plus @ A @ A3 @ B2 )
= ( plus_plus @ A @ A3 @ C2 ) )
=> ( B2 = C2 ) ) ) ).
% add_left_imp_eq
thf(fact_190_add_Oleft__commute,axiom,
! [A: $tType] :
( ( ab_semigroup_add @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( plus_plus @ A @ B2 @ ( plus_plus @ A @ A3 @ C2 ) )
= ( plus_plus @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) ) ) ) ).
% add.left_commute
thf(fact_191_add_Ocommute,axiom,
! [A: $tType] :
( ( ab_semigroup_add @ A )
=> ( ( plus_plus @ A )
= ( ^ [A5: A,B4: A] : ( plus_plus @ A @ B4 @ A5 ) ) ) ) ).
% add.commute
thf(fact_192_add_Oright__cancel,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ( plus_plus @ A @ B2 @ A3 )
= ( plus_plus @ A @ C2 @ A3 ) )
= ( B2 = C2 ) ) ) ).
% add.right_cancel
thf(fact_193_add_Oleft__cancel,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ( plus_plus @ A @ A3 @ B2 )
= ( plus_plus @ A @ A3 @ C2 ) )
= ( B2 = C2 ) ) ) ).
% add.left_cancel
thf(fact_194_add_Oassoc,axiom,
! [A: $tType] :
( ( semigroup_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( plus_plus @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) ) ) ) ).
% add.assoc
thf(fact_195_group__cancel_Oadd2,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [B3: A,K: A,B2: A,A3: A] :
( ( B3
= ( plus_plus @ A @ K @ B2 ) )
=> ( ( plus_plus @ A @ A3 @ B3 )
= ( plus_plus @ A @ K @ ( plus_plus @ A @ A3 @ B2 ) ) ) ) ) ).
% group_cancel.add2
thf(fact_196_group__cancel_Oadd1,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: A,K: A,A3: A,B2: A] :
( ( A4
= ( plus_plus @ A @ K @ A3 ) )
=> ( ( plus_plus @ A @ A4 @ B2 )
= ( plus_plus @ A @ K @ ( plus_plus @ A @ A3 @ B2 ) ) ) ) ) ).
% group_cancel.add1
thf(fact_197_add__mono__thms__linordered__semiring_I4_J,axiom,
! [A: $tType] :
( ( ordere6658533253407199908up_add @ A )
=> ! [I: A,J: A,K: A,L: A] :
( ( ( I = J )
& ( K = L ) )
=> ( ( plus_plus @ A @ I @ K )
= ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_semiring(4)
thf(fact_198_ab__semigroup__add__class_Oadd__ac_I1_J,axiom,
! [A: $tType] :
( ( ab_semigroup_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( plus_plus @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) ) ) ) ).
% ab_semigroup_add_class.add_ac(1)
thf(fact_199_zero__le,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [X: A] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ X ) ) ).
% zero_le
thf(fact_200_zero__less__iff__neq__zero,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [N2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ N2 )
= ( N2
!= ( zero_zero @ A ) ) ) ) ).
% zero_less_iff_neq_zero
thf(fact_201_gr__implies__not__zero,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [M: A,N2: A] :
( ( ord_less @ A @ M @ N2 )
=> ( N2
!= ( zero_zero @ A ) ) ) ) ).
% gr_implies_not_zero
thf(fact_202_not__less__zero,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [N2: A] :
~ ( ord_less @ A @ N2 @ ( zero_zero @ A ) ) ) ).
% not_less_zero
thf(fact_203_gr__zeroI,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [N2: A] :
( ( N2
!= ( zero_zero @ A ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ N2 ) ) ) ).
% gr_zeroI
thf(fact_204_add__le__imp__le__right,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ C2 ) )
=> ( ord_less_eq @ A @ A3 @ B2 ) ) ) ).
% add_le_imp_le_right
thf(fact_205_add__le__imp__le__left,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ C2 @ A3 ) @ ( plus_plus @ A @ C2 @ B2 ) )
=> ( ord_less_eq @ A @ A3 @ B2 ) ) ) ).
% add_le_imp_le_left
thf(fact_206_le__iff__add,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [A5: A,B4: A] :
? [C3: A] :
( B4
= ( plus_plus @ A @ A5 @ C3 ) ) ) ) ) ).
% le_iff_add
thf(fact_207_add__right__mono,axiom,
! [A: $tType] :
( ( ordere6658533253407199908up_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ord_less_eq @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ C2 ) ) ) ) ).
% add_right_mono
thf(fact_208_less__eqE,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ~ ! [C4: A] :
( B2
!= ( plus_plus @ A @ A3 @ C4 ) ) ) ) ).
% less_eqE
thf(fact_209_add__left__mono,axiom,
! [A: $tType] :
( ( ordere6658533253407199908up_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ord_less_eq @ A @ ( plus_plus @ A @ C2 @ A3 ) @ ( plus_plus @ A @ C2 @ B2 ) ) ) ) ).
% add_left_mono
thf(fact_210_add__mono,axiom,
! [A: $tType] :
( ( ordere6658533253407199908up_add @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ D2 )
=> ( ord_less_eq @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ D2 ) ) ) ) ) ).
% add_mono
thf(fact_211_add__mono__thms__linordered__semiring_I1_J,axiom,
! [A: $tType] :
( ( ordere6658533253407199908up_add @ A )
=> ! [I: A,J: A,K: A,L: A] :
( ( ( ord_less_eq @ A @ I @ J )
& ( ord_less_eq @ A @ K @ L ) )
=> ( ord_less_eq @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_semiring(1)
thf(fact_212_add__mono__thms__linordered__semiring_I2_J,axiom,
! [A: $tType] :
( ( ordere6658533253407199908up_add @ A )
=> ! [I: A,J: A,K: A,L: A] :
( ( ( I = J )
& ( ord_less_eq @ A @ K @ L ) )
=> ( ord_less_eq @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_semiring(2)
thf(fact_213_add__mono__thms__linordered__semiring_I3_J,axiom,
! [A: $tType] :
( ( ordere6658533253407199908up_add @ A )
=> ! [I: A,J: A,K: A,L: A] :
( ( ( ord_less_eq @ A @ I @ J )
& ( K = L ) )
=> ( ord_less_eq @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_semiring(3)
thf(fact_214_add_Ogroup__left__neutral,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A] :
( ( plus_plus @ A @ ( zero_zero @ A ) @ A3 )
= A3 ) ) ).
% add.group_left_neutral
thf(fact_215_add_Ocomm__neutral,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [A3: A] :
( ( plus_plus @ A @ A3 @ ( zero_zero @ A ) )
= A3 ) ) ).
% add.comm_neutral
thf(fact_216_comm__monoid__add__class_Oadd__0,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [A3: A] :
( ( plus_plus @ A @ ( zero_zero @ A ) @ A3 )
= A3 ) ) ).
% comm_monoid_add_class.add_0
thf(fact_217_add__less__imp__less__right,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ C2 ) )
=> ( ord_less @ A @ A3 @ B2 ) ) ) ).
% add_less_imp_less_right
thf(fact_218_add__less__imp__less__left,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ C2 @ A3 ) @ ( plus_plus @ A @ C2 @ B2 ) )
=> ( ord_less @ A @ A3 @ B2 ) ) ) ).
% add_less_imp_less_left
thf(fact_219_add__strict__right__mono,axiom,
! [A: $tType] :
( ( ordere580206878836729694up_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ord_less @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ C2 ) ) ) ) ).
% add_strict_right_mono
thf(fact_220_add__strict__left__mono,axiom,
! [A: $tType] :
( ( ordere580206878836729694up_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ord_less @ A @ ( plus_plus @ A @ C2 @ A3 ) @ ( plus_plus @ A @ C2 @ B2 ) ) ) ) ).
% add_strict_left_mono
thf(fact_221_add__strict__mono,axiom,
! [A: $tType] :
( ( strict9044650504122735259up_add @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ C2 @ D2 )
=> ( ord_less @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ D2 ) ) ) ) ) ).
% add_strict_mono
thf(fact_222_add__mono__thms__linordered__field_I1_J,axiom,
! [A: $tType] :
( ( ordere580206878836729694up_add @ A )
=> ! [I: A,J: A,K: A,L: A] :
( ( ( ord_less @ A @ I @ J )
& ( K = L ) )
=> ( ord_less @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_field(1)
thf(fact_223_add__mono__thms__linordered__field_I2_J,axiom,
! [A: $tType] :
( ( ordere580206878836729694up_add @ A )
=> ! [I: A,J: A,K: A,L: A] :
( ( ( I = J )
& ( ord_less @ A @ K @ L ) )
=> ( ord_less @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_field(2)
thf(fact_224_add__mono__thms__linordered__field_I5_J,axiom,
! [A: $tType] :
( ( ordere580206878836729694up_add @ A )
=> ! [I: A,J: A,K: A,L: A] :
( ( ( ord_less @ A @ I @ J )
& ( ord_less @ A @ K @ L ) )
=> ( ord_less @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_field(5)
thf(fact_225_max__add__distrib__right,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [X: A,Y: A,Z: A] :
( ( plus_plus @ A @ X @ ( ord_max @ A @ Y @ Z ) )
= ( ord_max @ A @ ( plus_plus @ A @ X @ Y ) @ ( plus_plus @ A @ X @ Z ) ) ) ) ).
% max_add_distrib_right
thf(fact_226_max__add__distrib__left,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [X: A,Y: A,Z: A] :
( ( plus_plus @ A @ ( ord_max @ A @ X @ Y ) @ Z )
= ( ord_max @ A @ ( plus_plus @ A @ X @ Z ) @ ( plus_plus @ A @ Y @ Z ) ) ) ) ).
% max_add_distrib_left
thf(fact_227_add__nonpos__eq__0__iff,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ Y @ ( zero_zero @ A ) )
=> ( ( ( plus_plus @ A @ X @ Y )
= ( zero_zero @ A ) )
= ( ( X
= ( zero_zero @ A ) )
& ( Y
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% add_nonpos_eq_0_iff
thf(fact_228_add__nonneg__eq__0__iff,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( ( ( plus_plus @ A @ X @ Y )
= ( zero_zero @ A ) )
= ( ( X
= ( zero_zero @ A ) )
& ( Y
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% add_nonneg_eq_0_iff
thf(fact_229_add__nonpos__nonpos,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( zero_zero @ A ) ) ) ) ) ).
% add_nonpos_nonpos
thf(fact_230_add__nonneg__nonneg,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ A3 @ B2 ) ) ) ) ) ).
% add_nonneg_nonneg
thf(fact_231_add__increasing2,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ord_less_eq @ A @ B2 @ ( plus_plus @ A @ A3 @ C2 ) ) ) ) ) ).
% add_increasing2
thf(fact_232_add__decreasing2,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ord_less_eq @ A @ ( plus_plus @ A @ A3 @ C2 ) @ B2 ) ) ) ) ).
% add_decreasing2
thf(fact_233_add__increasing,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ B2 @ C2 )
=> ( ord_less_eq @ A @ B2 @ ( plus_plus @ A @ A3 @ C2 ) ) ) ) ) ).
% add_increasing
thf(fact_234_add__decreasing,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ C2 @ B2 )
=> ( ord_less_eq @ A @ ( plus_plus @ A @ A3 @ C2 ) @ B2 ) ) ) ) ).
% add_decreasing
thf(fact_235_add__less__le__mono,axiom,
! [A: $tType] :
( ( ordere580206878836729694up_add @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ D2 )
=> ( ord_less @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ D2 ) ) ) ) ) ).
% add_less_le_mono
thf(fact_236_add__le__less__mono,axiom,
! [A: $tType] :
( ( ordere580206878836729694up_add @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ C2 @ D2 )
=> ( ord_less @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ D2 ) ) ) ) ) ).
% add_le_less_mono
thf(fact_237_add__mono__thms__linordered__field_I3_J,axiom,
! [A: $tType] :
( ( ordere580206878836729694up_add @ A )
=> ! [I: A,J: A,K: A,L: A] :
( ( ( ord_less @ A @ I @ J )
& ( ord_less_eq @ A @ K @ L ) )
=> ( ord_less @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_field(3)
thf(fact_238_add__mono__thms__linordered__field_I4_J,axiom,
! [A: $tType] :
( ( ordere580206878836729694up_add @ A )
=> ! [I: A,J: A,K: A,L: A] :
( ( ( ord_less_eq @ A @ I @ J )
& ( ord_less @ A @ K @ L ) )
=> ( ord_less @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ L ) ) ) ) ).
% add_mono_thms_linordered_field(4)
thf(fact_239_pos__add__strict,axiom,
! [A: $tType] :
( ( strict7427464778891057005id_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ B2 @ C2 )
=> ( ord_less @ A @ B2 @ ( plus_plus @ A @ A3 @ C2 ) ) ) ) ) ).
% pos_add_strict
thf(fact_240_canonically__ordered__monoid__add__class_OlessE,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ~ ! [C4: A] :
( ( B2
= ( plus_plus @ A @ A3 @ C4 ) )
=> ( C4
= ( zero_zero @ A ) ) ) ) ) ).
% canonically_ordered_monoid_add_class.lessE
thf(fact_241_add__pos__pos,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ A3 @ B2 ) ) ) ) ) ).
% add_pos_pos
thf(fact_242_add__neg__neg,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( zero_zero @ A ) ) ) ) ) ).
% add_neg_neg
thf(fact_243_add__strict__increasing2,axiom,
! [A: $tType] :
( ( ordere8940638589300402666id_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ B2 @ C2 )
=> ( ord_less @ A @ B2 @ ( plus_plus @ A @ A3 @ C2 ) ) ) ) ) ).
% add_strict_increasing2
thf(fact_244_add__strict__increasing,axiom,
! [A: $tType] :
( ( ordere8940638589300402666id_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ B2 @ C2 )
=> ( ord_less @ A @ B2 @ ( plus_plus @ A @ A3 @ C2 ) ) ) ) ) ).
% add_strict_increasing
thf(fact_245_add__pos__nonneg,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ A3 @ B2 ) ) ) ) ) ).
% add_pos_nonneg
thf(fact_246_add__nonpos__neg,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( zero_zero @ A ) ) ) ) ) ).
% add_nonpos_neg
thf(fact_247_add__nonneg__pos,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ A3 @ B2 ) ) ) ) ) ).
% add_nonneg_pos
thf(fact_248_add__neg__nonpos,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( zero_zero @ A ) ) ) ) ) ).
% add_neg_nonpos
thf(fact_249_double__eq__0__iff,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( ( plus_plus @ A @ A3 @ A3 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% double_eq_0_iff
thf(fact_250_vebt__member_Osimps_I3_J,axiom,
! [V2: product_prod @ nat @ nat,Uy: list @ vEBT_VEBT,Uz: vEBT_VEBT,X: nat] :
~ ( vEBT_vebt_member @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V2 ) @ ( zero_zero @ nat ) @ Uy @ Uz ) @ X ) ).
% vebt_member.simps(3)
thf(fact_251_buildup__nothing__in__leaf,axiom,
! [N2: nat,X: nat] :
~ ( vEBT_V5719532721284313246member @ ( vEBT_vebt_buildup @ N2 ) @ X ) ).
% buildup_nothing_in_leaf
thf(fact_252_field__le__epsilon,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ! [E: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ E )
=> ( ord_less_eq @ A @ X @ ( plus_plus @ A @ Y @ E ) ) )
=> ( ord_less_eq @ A @ X @ Y ) ) ) ).
% field_le_epsilon
thf(fact_253_VEBT__internal_OminNull_Osimps_I5_J,axiom,
! [Uz: product_prod @ nat @ nat,Va: nat,Vb: list @ vEBT_VEBT,Vc: vEBT_VEBT] :
~ ( vEBT_VEBT_minNull @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ Uz ) @ Va @ Vb @ Vc ) ) ).
% VEBT_internal.minNull.simps(5)
thf(fact_254_vebt__insert_Osimps_I2_J,axiom,
! [Info: option @ ( product_prod @ nat @ nat ),Ts: list @ vEBT_VEBT,S: vEBT_VEBT,X: nat] :
( ( vEBT_vebt_insert @ ( vEBT_Node @ Info @ ( zero_zero @ nat ) @ Ts @ S ) @ X )
= ( vEBT_Node @ Info @ ( zero_zero @ nat ) @ Ts @ S ) ) ).
% vebt_insert.simps(2)
thf(fact_255__C8_C,axiom,
( ( suc @ na )
= m ) ).
% "8"
thf(fact_256_can__select__set__list__ex1,axiom,
! [A: $tType,P2: A > $o,A4: list @ A] :
( ( can_select @ A @ P2 @ ( set2 @ A @ A4 ) )
= ( list_ex1 @ A @ P2 @ A4 ) ) ).
% can_select_set_list_ex1
thf(fact_257_ex__has__greatest__nat__lemma,axiom,
! [A: $tType,P2: A > $o,K: A,F2: A > nat,N2: nat] :
( ( P2 @ K )
=> ( ! [X5: A] :
( ( P2 @ X5 )
=> ? [Y3: A] :
( ( P2 @ Y3 )
& ~ ( ord_less_eq @ nat @ ( F2 @ Y3 ) @ ( F2 @ X5 ) ) ) )
=> ? [Y4: A] :
( ( P2 @ Y4 )
& ~ ( ord_less @ nat @ ( F2 @ Y4 ) @ ( plus_plus @ nat @ ( F2 @ K ) @ N2 ) ) ) ) ) ).
% ex_has_greatest_nat_lemma
thf(fact_258_add__less__zeroD,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ ( plus_plus @ A @ X @ Y ) @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ X @ ( zero_zero @ A ) )
| ( ord_less @ A @ Y @ ( zero_zero @ A ) ) ) ) ) ).
% add_less_zeroD
thf(fact_259_buildup__gives__empty,axiom,
! [N2: nat] :
( ( vEBT_VEBT_set_vebt @ ( vEBT_vebt_buildup @ N2 ) )
= ( bot_bot @ ( set @ nat ) ) ) ).
% buildup_gives_empty
thf(fact_260_even__odd__cases,axiom,
! [X: nat] :
( ! [N3: nat] :
( X
!= ( plus_plus @ nat @ N3 @ N3 ) )
=> ~ ! [N3: nat] :
( X
!= ( plus_plus @ nat @ N3 @ ( suc @ N3 ) ) ) ) ).
% even_odd_cases
thf(fact_261_deg__SUcn__Node,axiom,
! [Tree: vEBT_VEBT,N2: nat] :
( ( vEBT_invar_vebt @ Tree @ ( suc @ ( suc @ N2 ) ) )
=> ? [Info2: option @ ( product_prod @ nat @ nat ),TreeList3: list @ vEBT_VEBT,S2: vEBT_VEBT] :
( Tree
= ( vEBT_Node @ Info2 @ ( suc @ ( suc @ N2 ) ) @ TreeList3 @ S2 ) ) ) ).
% deg_SUcn_Node
thf(fact_262_old_Onat_Oinject,axiom,
! [Nat: nat,Nat2: nat] :
( ( ( suc @ Nat )
= ( suc @ Nat2 ) )
= ( Nat = Nat2 ) ) ).
% old.nat.inject
thf(fact_263_nat_Oinject,axiom,
! [X22: nat,Y22: nat] :
( ( ( suc @ X22 )
= ( suc @ Y22 ) )
= ( X22 = Y22 ) ) ).
% nat.inject
thf(fact_264_lessI,axiom,
! [N2: nat] : ( ord_less @ nat @ N2 @ ( suc @ N2 ) ) ).
% lessI
thf(fact_265_Suc__mono,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ( ord_less @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) ) ).
% Suc_mono
thf(fact_266_Suc__less__eq,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( suc @ M ) @ ( suc @ N2 ) )
= ( ord_less @ nat @ M @ N2 ) ) ).
% Suc_less_eq
thf(fact_267_Suc__le__mono,axiom,
! [N2: nat,M: nat] :
( ( ord_less_eq @ nat @ ( suc @ N2 ) @ ( suc @ M ) )
= ( ord_less_eq @ nat @ N2 @ M ) ) ).
% Suc_le_mono
thf(fact_268_add__Suc__right,axiom,
! [M: nat,N2: nat] :
( ( plus_plus @ nat @ M @ ( suc @ N2 ) )
= ( suc @ ( plus_plus @ nat @ M @ N2 ) ) ) ).
% add_Suc_right
thf(fact_269_max__Suc__Suc,axiom,
! [M: nat,N2: nat] :
( ( ord_max @ nat @ ( suc @ M ) @ ( suc @ N2 ) )
= ( suc @ ( ord_max @ nat @ M @ N2 ) ) ) ).
% max_Suc_Suc
thf(fact_270_less__Suc0,axiom,
! [N2: nat] :
( ( ord_less @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) )
= ( N2
= ( zero_zero @ nat ) ) ) ).
% less_Suc0
thf(fact_271_zero__less__Suc,axiom,
! [N2: nat] : ( ord_less @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) ) ).
% zero_less_Suc
thf(fact_272_n__not__Suc__n,axiom,
! [N2: nat] :
( N2
!= ( suc @ N2 ) ) ).
% n_not_Suc_n
thf(fact_273_Suc__inject,axiom,
! [X: nat,Y: nat] :
( ( ( suc @ X )
= ( suc @ Y ) )
=> ( X = Y ) ) ).
% Suc_inject
thf(fact_274_can__select__def,axiom,
! [A: $tType] :
( ( can_select @ A )
= ( ^ [P: A > $o,A6: set @ A] :
? [X2: A] :
( ( member2 @ A @ X2 @ A6 )
& ( P @ X2 )
& ! [Y2: A] :
( ( ( member2 @ A @ Y2 @ A6 )
& ( P @ Y2 ) )
=> ( Y2 = X2 ) ) ) ) ) ).
% can_select_def
thf(fact_275_nat_Odistinct_I1_J,axiom,
! [X22: nat] :
( ( zero_zero @ nat )
!= ( suc @ X22 ) ) ).
% nat.distinct(1)
thf(fact_276_old_Onat_Odistinct_I2_J,axiom,
! [Nat3: nat] :
( ( suc @ Nat3 )
!= ( zero_zero @ nat ) ) ).
% old.nat.distinct(2)
thf(fact_277_old_Onat_Odistinct_I1_J,axiom,
! [Nat2: nat] :
( ( zero_zero @ nat )
!= ( suc @ Nat2 ) ) ).
% old.nat.distinct(1)
thf(fact_278_nat_OdiscI,axiom,
! [Nat: nat,X22: nat] :
( ( Nat
= ( suc @ X22 ) )
=> ( Nat
!= ( zero_zero @ nat ) ) ) ).
% nat.discI
thf(fact_279_old_Onat_Oexhaust,axiom,
! [Y: nat] :
( ( Y
!= ( zero_zero @ nat ) )
=> ~ ! [Nat4: nat] :
( Y
!= ( suc @ Nat4 ) ) ) ).
% old.nat.exhaust
thf(fact_280_nat__induct,axiom,
! [P2: nat > $o,N2: nat] :
( ( P2 @ ( zero_zero @ nat ) )
=> ( ! [N3: nat] :
( ( P2 @ N3 )
=> ( P2 @ ( suc @ N3 ) ) )
=> ( P2 @ N2 ) ) ) ).
% nat_induct
thf(fact_281_diff__induct,axiom,
! [P2: nat > nat > $o,M: nat,N2: nat] :
( ! [X5: nat] : ( P2 @ X5 @ ( zero_zero @ nat ) )
=> ( ! [Y4: nat] : ( P2 @ ( zero_zero @ nat ) @ ( suc @ Y4 ) )
=> ( ! [X5: nat,Y4: nat] :
( ( P2 @ X5 @ Y4 )
=> ( P2 @ ( suc @ X5 ) @ ( suc @ Y4 ) ) )
=> ( P2 @ M @ N2 ) ) ) ) ).
% diff_induct
thf(fact_282_zero__induct,axiom,
! [P2: nat > $o,K: nat] :
( ( P2 @ K )
=> ( ! [N3: nat] :
( ( P2 @ ( suc @ N3 ) )
=> ( P2 @ N3 ) )
=> ( P2 @ ( zero_zero @ nat ) ) ) ) ).
% zero_induct
thf(fact_283_Suc__neq__Zero,axiom,
! [M: nat] :
( ( suc @ M )
!= ( zero_zero @ nat ) ) ).
% Suc_neq_Zero
thf(fact_284_Zero__neq__Suc,axiom,
! [M: nat] :
( ( zero_zero @ nat )
!= ( suc @ M ) ) ).
% Zero_neq_Suc
thf(fact_285_Zero__not__Suc,axiom,
! [M: nat] :
( ( zero_zero @ nat )
!= ( suc @ M ) ) ).
% Zero_not_Suc
thf(fact_286_not0__implies__Suc,axiom,
! [N2: nat] :
( ( N2
!= ( zero_zero @ nat ) )
=> ? [M3: nat] :
( N2
= ( suc @ M3 ) ) ) ).
% not0_implies_Suc
thf(fact_287_Nat_OlessE,axiom,
! [I: nat,K: nat] :
( ( ord_less @ nat @ I @ K )
=> ( ( K
!= ( suc @ I ) )
=> ~ ! [J2: nat] :
( ( ord_less @ nat @ I @ J2 )
=> ( K
!= ( suc @ J2 ) ) ) ) ) ).
% Nat.lessE
thf(fact_288_Suc__lessD,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( suc @ M ) @ N2 )
=> ( ord_less @ nat @ M @ N2 ) ) ).
% Suc_lessD
thf(fact_289_Suc__lessE,axiom,
! [I: nat,K: nat] :
( ( ord_less @ nat @ ( suc @ I ) @ K )
=> ~ ! [J2: nat] :
( ( ord_less @ nat @ I @ J2 )
=> ( K
!= ( suc @ J2 ) ) ) ) ).
% Suc_lessE
thf(fact_290_Suc__lessI,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ( ( ( suc @ M )
!= N2 )
=> ( ord_less @ nat @ ( suc @ M ) @ N2 ) ) ) ).
% Suc_lessI
thf(fact_291_less__SucE,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ ( suc @ N2 ) )
=> ( ~ ( ord_less @ nat @ M @ N2 )
=> ( M = N2 ) ) ) ).
% less_SucE
thf(fact_292_less__SucI,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ( ord_less @ nat @ M @ ( suc @ N2 ) ) ) ).
% less_SucI
thf(fact_293_Ex__less__Suc,axiom,
! [N2: nat,P2: nat > $o] :
( ( ? [I5: nat] :
( ( ord_less @ nat @ I5 @ ( suc @ N2 ) )
& ( P2 @ I5 ) ) )
= ( ( P2 @ N2 )
| ? [I5: nat] :
( ( ord_less @ nat @ I5 @ N2 )
& ( P2 @ I5 ) ) ) ) ).
% Ex_less_Suc
thf(fact_294_less__Suc__eq,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ ( suc @ N2 ) )
= ( ( ord_less @ nat @ M @ N2 )
| ( M = N2 ) ) ) ).
% less_Suc_eq
thf(fact_295_not__less__eq,axiom,
! [M: nat,N2: nat] :
( ( ~ ( ord_less @ nat @ M @ N2 ) )
= ( ord_less @ nat @ N2 @ ( suc @ M ) ) ) ).
% not_less_eq
thf(fact_296_All__less__Suc,axiom,
! [N2: nat,P2: nat > $o] :
( ( ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( suc @ N2 ) )
=> ( P2 @ I5 ) ) )
= ( ( P2 @ N2 )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ N2 )
=> ( P2 @ I5 ) ) ) ) ).
% All_less_Suc
thf(fact_297_Suc__less__eq2,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( suc @ N2 ) @ M )
= ( ? [M5: nat] :
( ( M
= ( suc @ M5 ) )
& ( ord_less @ nat @ N2 @ M5 ) ) ) ) ).
% Suc_less_eq2
thf(fact_298_less__antisym,axiom,
! [N2: nat,M: nat] :
( ~ ( ord_less @ nat @ N2 @ M )
=> ( ( ord_less @ nat @ N2 @ ( suc @ M ) )
=> ( M = N2 ) ) ) ).
% less_antisym
thf(fact_299_Suc__less__SucD,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( suc @ M ) @ ( suc @ N2 ) )
=> ( ord_less @ nat @ M @ N2 ) ) ).
% Suc_less_SucD
thf(fact_300_less__trans__Suc,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less @ nat @ I @ J )
=> ( ( ord_less @ nat @ J @ K )
=> ( ord_less @ nat @ ( suc @ I ) @ K ) ) ) ).
% less_trans_Suc
thf(fact_301_less__Suc__induct,axiom,
! [I: nat,J: nat,P2: nat > nat > $o] :
( ( ord_less @ nat @ I @ J )
=> ( ! [I3: nat] : ( P2 @ I3 @ ( suc @ I3 ) )
=> ( ! [I3: nat,J2: nat,K3: nat] :
( ( ord_less @ nat @ I3 @ J2 )
=> ( ( ord_less @ nat @ J2 @ K3 )
=> ( ( P2 @ I3 @ J2 )
=> ( ( P2 @ J2 @ K3 )
=> ( P2 @ I3 @ K3 ) ) ) ) )
=> ( P2 @ I @ J ) ) ) ) ).
% less_Suc_induct
thf(fact_302_strict__inc__induct,axiom,
! [I: nat,J: nat,P2: nat > $o] :
( ( ord_less @ nat @ I @ J )
=> ( ! [I3: nat] :
( ( J
= ( suc @ I3 ) )
=> ( P2 @ I3 ) )
=> ( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ J )
=> ( ( P2 @ ( suc @ I3 ) )
=> ( P2 @ I3 ) ) )
=> ( P2 @ I ) ) ) ) ).
% strict_inc_induct
thf(fact_303_not__less__less__Suc__eq,axiom,
! [N2: nat,M: nat] :
( ~ ( ord_less @ nat @ N2 @ M )
=> ( ( ord_less @ nat @ N2 @ ( suc @ M ) )
= ( N2 = M ) ) ) ).
% not_less_less_Suc_eq
thf(fact_304_Suc__leD,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( suc @ M ) @ N2 )
=> ( ord_less_eq @ nat @ M @ N2 ) ) ).
% Suc_leD
thf(fact_305_le__SucE,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ ( suc @ N2 ) )
=> ( ~ ( ord_less_eq @ nat @ M @ N2 )
=> ( M
= ( suc @ N2 ) ) ) ) ).
% le_SucE
thf(fact_306_le__SucI,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ord_less_eq @ nat @ M @ ( suc @ N2 ) ) ) ).
% le_SucI
thf(fact_307_Suc__le__D,axiom,
! [N2: nat,M6: nat] :
( ( ord_less_eq @ nat @ ( suc @ N2 ) @ M6 )
=> ? [M3: nat] :
( M6
= ( suc @ M3 ) ) ) ).
% Suc_le_D
thf(fact_308_le__Suc__eq,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ ( suc @ N2 ) )
= ( ( ord_less_eq @ nat @ M @ N2 )
| ( M
= ( suc @ N2 ) ) ) ) ).
% le_Suc_eq
thf(fact_309_Suc__n__not__le__n,axiom,
! [N2: nat] :
~ ( ord_less_eq @ nat @ ( suc @ N2 ) @ N2 ) ).
% Suc_n_not_le_n
thf(fact_310_not__less__eq__eq,axiom,
! [M: nat,N2: nat] :
( ( ~ ( ord_less_eq @ nat @ M @ N2 ) )
= ( ord_less_eq @ nat @ ( suc @ N2 ) @ M ) ) ).
% not_less_eq_eq
thf(fact_311_full__nat__induct,axiom,
! [P2: nat > $o,N2: nat] :
( ! [N3: nat] :
( ! [M4: nat] :
( ( ord_less_eq @ nat @ ( suc @ M4 ) @ N3 )
=> ( P2 @ M4 ) )
=> ( P2 @ N3 ) )
=> ( P2 @ N2 ) ) ).
% full_nat_induct
thf(fact_312_nat__induct__at__least,axiom,
! [M: nat,N2: nat,P2: nat > $o] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( P2 @ M )
=> ( ! [N3: nat] :
( ( ord_less_eq @ nat @ M @ N3 )
=> ( ( P2 @ N3 )
=> ( P2 @ ( suc @ N3 ) ) ) )
=> ( P2 @ N2 ) ) ) ) ).
% nat_induct_at_least
thf(fact_313_transitive__stepwise__le,axiom,
! [M: nat,N2: nat,R: nat > nat > $o] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ! [X5: nat] : ( R @ X5 @ X5 )
=> ( ! [X5: nat,Y4: nat,Z2: nat] :
( ( R @ X5 @ Y4 )
=> ( ( R @ Y4 @ Z2 )
=> ( R @ X5 @ Z2 ) ) )
=> ( ! [N3: nat] : ( R @ N3 @ ( suc @ N3 ) )
=> ( R @ M @ N2 ) ) ) ) ) ).
% transitive_stepwise_le
thf(fact_314_nat__arith_Osuc1,axiom,
! [A4: nat,K: nat,A3: nat] :
( ( A4
= ( plus_plus @ nat @ K @ A3 ) )
=> ( ( suc @ A4 )
= ( plus_plus @ nat @ K @ ( suc @ A3 ) ) ) ) ).
% nat_arith.suc1
thf(fact_315_add__Suc,axiom,
! [M: nat,N2: nat] :
( ( plus_plus @ nat @ ( suc @ M ) @ N2 )
= ( suc @ ( plus_plus @ nat @ M @ N2 ) ) ) ).
% add_Suc
thf(fact_316_add__Suc__shift,axiom,
! [M: nat,N2: nat] :
( ( plus_plus @ nat @ ( suc @ M ) @ N2 )
= ( plus_plus @ nat @ M @ ( suc @ N2 ) ) ) ).
% add_Suc_shift
thf(fact_317_lift__Suc__mono__less,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [F2: nat > A,N2: nat,N4: nat] :
( ! [N3: nat] : ( ord_less @ A @ ( F2 @ N3 ) @ ( F2 @ ( suc @ N3 ) ) )
=> ( ( ord_less @ nat @ N2 @ N4 )
=> ( ord_less @ A @ ( F2 @ N2 ) @ ( F2 @ N4 ) ) ) ) ) ).
% lift_Suc_mono_less
thf(fact_318_lift__Suc__mono__less__iff,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [F2: nat > A,N2: nat,M: nat] :
( ! [N3: nat] : ( ord_less @ A @ ( F2 @ N3 ) @ ( F2 @ ( suc @ N3 ) ) )
=> ( ( ord_less @ A @ ( F2 @ N2 ) @ ( F2 @ M ) )
= ( ord_less @ nat @ N2 @ M ) ) ) ) ).
% lift_Suc_mono_less_iff
thf(fact_319_lift__Suc__mono__le,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [F2: nat > A,N2: nat,N4: nat] :
( ! [N3: nat] : ( ord_less_eq @ A @ ( F2 @ N3 ) @ ( F2 @ ( suc @ N3 ) ) )
=> ( ( ord_less_eq @ nat @ N2 @ N4 )
=> ( ord_less_eq @ A @ ( F2 @ N2 ) @ ( F2 @ N4 ) ) ) ) ) ).
% lift_Suc_mono_le
thf(fact_320_lift__Suc__antimono__le,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [F2: nat > A,N2: nat,N4: nat] :
( ! [N3: nat] : ( ord_less_eq @ A @ ( F2 @ ( suc @ N3 ) ) @ ( F2 @ N3 ) )
=> ( ( ord_less_eq @ nat @ N2 @ N4 )
=> ( ord_less_eq @ A @ ( F2 @ N4 ) @ ( F2 @ N2 ) ) ) ) ) ).
% lift_Suc_antimono_le
thf(fact_321_Ex__less__Suc2,axiom,
! [N2: nat,P2: nat > $o] :
( ( ? [I5: nat] :
( ( ord_less @ nat @ I5 @ ( suc @ N2 ) )
& ( P2 @ I5 ) ) )
= ( ( P2 @ ( zero_zero @ nat ) )
| ? [I5: nat] :
( ( ord_less @ nat @ I5 @ N2 )
& ( P2 @ ( suc @ I5 ) ) ) ) ) ).
% Ex_less_Suc2
thf(fact_322_gr0__conv__Suc,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
= ( ? [M2: nat] :
( N2
= ( suc @ M2 ) ) ) ) ).
% gr0_conv_Suc
thf(fact_323_All__less__Suc2,axiom,
! [N2: nat,P2: nat > $o] :
( ( ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( suc @ N2 ) )
=> ( P2 @ I5 ) ) )
= ( ( P2 @ ( zero_zero @ nat ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ N2 )
=> ( P2 @ ( suc @ I5 ) ) ) ) ) ).
% All_less_Suc2
thf(fact_324_gr0__implies__Suc,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ? [M3: nat] :
( N2
= ( suc @ M3 ) ) ) ).
% gr0_implies_Suc
thf(fact_325_less__Suc__eq__0__disj,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ ( suc @ N2 ) )
= ( ( M
= ( zero_zero @ nat ) )
| ? [J3: nat] :
( ( M
= ( suc @ J3 ) )
& ( ord_less @ nat @ J3 @ N2 ) ) ) ) ).
% less_Suc_eq_0_disj
thf(fact_326_Suc__leI,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ( ord_less_eq @ nat @ ( suc @ M ) @ N2 ) ) ).
% Suc_leI
thf(fact_327_Suc__le__eq,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( suc @ M ) @ N2 )
= ( ord_less @ nat @ M @ N2 ) ) ).
% Suc_le_eq
thf(fact_328_dec__induct,axiom,
! [I: nat,J: nat,P2: nat > $o] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( P2 @ I )
=> ( ! [N3: nat] :
( ( ord_less_eq @ nat @ I @ N3 )
=> ( ( ord_less @ nat @ N3 @ J )
=> ( ( P2 @ N3 )
=> ( P2 @ ( suc @ N3 ) ) ) ) )
=> ( P2 @ J ) ) ) ) ).
% dec_induct
thf(fact_329_inc__induct,axiom,
! [I: nat,J: nat,P2: nat > $o] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( P2 @ J )
=> ( ! [N3: nat] :
( ( ord_less_eq @ nat @ I @ N3 )
=> ( ( ord_less @ nat @ N3 @ J )
=> ( ( P2 @ ( suc @ N3 ) )
=> ( P2 @ N3 ) ) ) )
=> ( P2 @ I ) ) ) ) ).
% inc_induct
thf(fact_330_Suc__le__lessD,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( suc @ M ) @ N2 )
=> ( ord_less @ nat @ M @ N2 ) ) ).
% Suc_le_lessD
thf(fact_331_le__less__Suc__eq,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( ord_less @ nat @ N2 @ ( suc @ M ) )
= ( N2 = M ) ) ) ).
% le_less_Suc_eq
thf(fact_332_less__Suc__eq__le,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ ( suc @ N2 ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ).
% less_Suc_eq_le
thf(fact_333_less__eq__Suc__le,axiom,
( ( ord_less @ nat )
= ( ^ [N: nat] : ( ord_less_eq @ nat @ ( suc @ N ) ) ) ) ).
% less_eq_Suc_le
thf(fact_334_le__imp__less__Suc,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ord_less @ nat @ M @ ( suc @ N2 ) ) ) ).
% le_imp_less_Suc
thf(fact_335_one__is__add,axiom,
! [M: nat,N2: nat] :
( ( ( suc @ ( zero_zero @ nat ) )
= ( plus_plus @ nat @ M @ N2 ) )
= ( ( ( M
= ( suc @ ( zero_zero @ nat ) ) )
& ( N2
= ( zero_zero @ nat ) ) )
| ( ( M
= ( zero_zero @ nat ) )
& ( N2
= ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ).
% one_is_add
thf(fact_336_add__is__1,axiom,
! [M: nat,N2: nat] :
( ( ( plus_plus @ nat @ M @ N2 )
= ( suc @ ( zero_zero @ nat ) ) )
= ( ( ( M
= ( suc @ ( zero_zero @ nat ) ) )
& ( N2
= ( zero_zero @ nat ) ) )
| ( ( M
= ( zero_zero @ nat ) )
& ( N2
= ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ).
% add_is_1
thf(fact_337_less__imp__Suc__add,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ? [K3: nat] :
( N2
= ( suc @ ( plus_plus @ nat @ M @ K3 ) ) ) ) ).
% less_imp_Suc_add
thf(fact_338_less__iff__Suc__add,axiom,
( ( ord_less @ nat )
= ( ^ [M2: nat,N: nat] :
? [K2: nat] :
( N
= ( suc @ ( plus_plus @ nat @ M2 @ K2 ) ) ) ) ) ).
% less_iff_Suc_add
thf(fact_339_less__add__Suc2,axiom,
! [I: nat,M: nat] : ( ord_less @ nat @ I @ ( suc @ ( plus_plus @ nat @ M @ I ) ) ) ).
% less_add_Suc2
thf(fact_340_less__add__Suc1,axiom,
! [I: nat,M: nat] : ( ord_less @ nat @ I @ ( suc @ ( plus_plus @ nat @ I @ M ) ) ) ).
% less_add_Suc1
thf(fact_341_less__natE,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ~ ! [Q3: nat] :
( N2
!= ( suc @ ( plus_plus @ nat @ M @ Q3 ) ) ) ) ).
% less_natE
thf(fact_342_vebt__insert_Osimps_I3_J,axiom,
! [Info: option @ ( product_prod @ nat @ nat ),Ts: list @ vEBT_VEBT,S: vEBT_VEBT,X: nat] :
( ( vEBT_vebt_insert @ ( vEBT_Node @ Info @ ( suc @ ( zero_zero @ nat ) ) @ Ts @ S ) @ X )
= ( vEBT_Node @ Info @ ( suc @ ( zero_zero @ nat ) ) @ Ts @ S ) ) ).
% vebt_insert.simps(3)
thf(fact_343_ex__least__nat__less,axiom,
! [P2: nat > $o,N2: nat] :
( ( P2 @ N2 )
=> ( ~ ( P2 @ ( zero_zero @ nat ) )
=> ? [K3: nat] :
( ( ord_less @ nat @ K3 @ N2 )
& ! [I4: nat] :
( ( ord_less_eq @ nat @ I4 @ K3 )
=> ~ ( P2 @ I4 ) )
& ( P2 @ ( suc @ K3 ) ) ) ) ) ).
% ex_least_nat_less
thf(fact_344_linordered__field__no__lb,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X3: A] :
? [Y4: A] : ( ord_less @ A @ Y4 @ X3 ) ) ).
% linordered_field_no_lb
thf(fact_345_linordered__field__no__ub,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X3: A] :
? [X_12: A] : ( ord_less @ A @ X3 @ X_12 ) ) ).
% linordered_field_no_ub
thf(fact_346_linorder__neqE__linordered__idom,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] :
( ( X != Y )
=> ( ~ ( ord_less @ A @ X @ Y )
=> ( ord_less @ A @ Y @ X ) ) ) ) ).
% linorder_neqE_linordered_idom
thf(fact_347_vebt__member_Osimps_I4_J,axiom,
! [V2: product_prod @ nat @ nat,Vb: list @ vEBT_VEBT,Vc: vEBT_VEBT,X: nat] :
~ ( vEBT_vebt_member @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V2 ) @ ( suc @ ( zero_zero @ nat ) ) @ Vb @ Vc ) @ X ) ).
% vebt_member.simps(4)
thf(fact_348_ex__has__least__nat,axiom,
! [A: $tType,P2: A > $o,K: A,M: A > nat] :
( ( P2 @ K )
=> ? [X5: A] :
( ( P2 @ X5 )
& ! [Y3: A] :
( ( P2 @ Y3 )
=> ( ord_less_eq @ nat @ ( M @ X5 ) @ ( M @ Y3 ) ) ) ) ) ).
% ex_has_least_nat
thf(fact_349_Lattices__Big_Oex__has__greatest__nat,axiom,
! [A: $tType,P2: A > $o,K: A,F2: A > nat,B2: nat] :
( ( P2 @ K )
=> ( ! [Y4: A] :
( ( P2 @ Y4 )
=> ( ord_less @ nat @ ( F2 @ Y4 ) @ B2 ) )
=> ? [X5: A] :
( ( P2 @ X5 )
& ! [Y3: A] :
( ( P2 @ Y3 )
=> ( ord_less_eq @ nat @ ( F2 @ Y3 ) @ ( F2 @ X5 ) ) ) ) ) ) ).
% Lattices_Big.ex_has_greatest_nat
thf(fact_350_member__valid__both__member__options,axiom,
! [Tree: vEBT_VEBT,N2: nat,X: nat] :
( ( vEBT_invar_vebt @ Tree @ N2 )
=> ( ( vEBT_vebt_member @ Tree @ X )
=> ( ( vEBT_V5719532721284313246member @ Tree @ X )
| ( vEBT_VEBT_membermima @ Tree @ X ) ) ) ) ).
% member_valid_both_member_options
thf(fact_351_max__bot,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ! [X: A] :
( ( ord_max @ A @ ( bot_bot @ A ) @ X )
= X ) ) ).
% max_bot
thf(fact_352_max__bot2,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ! [X: A] :
( ( ord_max @ A @ X @ ( bot_bot @ A ) )
= X ) ) ).
% max_bot2
thf(fact_353_subset__empty,axiom,
! [A: $tType,A4: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ ( bot_bot @ ( set @ A ) ) )
= ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ).
% subset_empty
thf(fact_354_empty__subsetI,axiom,
! [A: $tType,A4: set @ A] : ( ord_less_eq @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) @ A4 ) ).
% empty_subsetI
thf(fact_355_both__member__options__def,axiom,
( vEBT_V8194947554948674370ptions
= ( ^ [T3: vEBT_VEBT,X2: nat] :
( ( vEBT_V5719532721284313246member @ T3 @ X2 )
| ( vEBT_VEBT_membermima @ T3 @ X2 ) ) ) ) ).
% both_member_options_def
thf(fact_356_VEBT__internal_Onaive__member_Osimps_I2_J,axiom,
! [Uu: option @ ( product_prod @ nat @ nat ),Uv: list @ vEBT_VEBT,Uw: vEBT_VEBT,Ux: nat] :
~ ( vEBT_V5719532721284313246member @ ( vEBT_Node @ Uu @ ( zero_zero @ nat ) @ Uv @ Uw ) @ Ux ) ).
% VEBT_internal.naive_member.simps(2)
thf(fact_357_VEBT_Oinject_I1_J,axiom,
! [X11: option @ ( product_prod @ nat @ nat ),X12: nat,X13: list @ vEBT_VEBT,X14: vEBT_VEBT,Y11: option @ ( product_prod @ nat @ nat ),Y12: nat,Y13: list @ vEBT_VEBT,Y14: vEBT_VEBT] :
( ( ( vEBT_Node @ X11 @ X12 @ X13 @ X14 )
= ( vEBT_Node @ Y11 @ Y12 @ Y13 @ Y14 ) )
= ( ( X11 = Y11 )
& ( X12 = Y12 )
& ( X13 = Y13 )
& ( X14 = Y14 ) ) ) ).
% VEBT.inject(1)
thf(fact_358_option_Oinject,axiom,
! [A: $tType,X22: A,Y22: A] :
( ( ( some @ A @ X22 )
= ( some @ A @ Y22 ) )
= ( X22 = Y22 ) ) ).
% option.inject
thf(fact_359_subsetI,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( member2 @ A @ X5 @ B3 ) )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ).
% subsetI
thf(fact_360_psubsetI,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( A4 != B3 )
=> ( ord_less @ ( set @ A ) @ A4 @ B3 ) ) ) ).
% psubsetI
thf(fact_361_buildup__nothing__in__min__max,axiom,
! [N2: nat,X: nat] :
~ ( vEBT_VEBT_membermima @ ( vEBT_vebt_buildup @ N2 ) @ X ) ).
% buildup_nothing_in_min_max
thf(fact_362_dual__order_Orefl,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A] : ( ord_less_eq @ A @ A3 @ A3 ) ) ).
% dual_order.refl
thf(fact_363_order__refl,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A] : ( ord_less_eq @ A @ X @ X ) ) ).
% order_refl
thf(fact_364_bot__apply,axiom,
! [C: $tType,D: $tType] :
( ( bot @ C )
=> ( ( bot_bot @ ( D > C ) )
= ( ^ [X2: D] : ( bot_bot @ C ) ) ) ) ).
% bot_apply
thf(fact_365_empty__Collect__eq,axiom,
! [A: $tType,P2: A > $o] :
( ( ( bot_bot @ ( set @ A ) )
= ( collect @ A @ P2 ) )
= ( ! [X2: A] :
~ ( P2 @ X2 ) ) ) ).
% empty_Collect_eq
thf(fact_366_Collect__empty__eq,axiom,
! [A: $tType,P2: A > $o] :
( ( ( collect @ A @ P2 )
= ( bot_bot @ ( set @ A ) ) )
= ( ! [X2: A] :
~ ( P2 @ X2 ) ) ) ).
% Collect_empty_eq
thf(fact_367_all__not__in__conv,axiom,
! [A: $tType,A4: set @ A] :
( ( ! [X2: A] :
~ ( member2 @ A @ X2 @ A4 ) )
= ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ).
% all_not_in_conv
thf(fact_368_empty__iff,axiom,
! [A: $tType,C2: A] :
~ ( member2 @ A @ C2 @ ( bot_bot @ ( set @ A ) ) ) ).
% empty_iff
thf(fact_369_subset__antisym,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( A4 = B3 ) ) ) ).
% subset_antisym
thf(fact_370_bot__set__def,axiom,
! [A: $tType] :
( ( bot_bot @ ( set @ A ) )
= ( collect @ A @ ( bot_bot @ ( A > $o ) ) ) ) ).
% bot_set_def
thf(fact_371_bot__nat__def,axiom,
( ( bot_bot @ nat )
= ( zero_zero @ nat ) ) ).
% bot_nat_def
thf(fact_372_order__antisym__conv,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ Y @ X )
=> ( ( ord_less_eq @ A @ X @ Y )
= ( X = Y ) ) ) ) ).
% order_antisym_conv
thf(fact_373_linorder__le__cases,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ~ ( ord_less_eq @ A @ X @ Y )
=> ( ord_less_eq @ A @ Y @ X ) ) ) ).
% linorder_le_cases
thf(fact_374_ord__le__eq__subst,axiom,
! [A: $tType,B: $tType] :
( ( ( ord @ B )
& ( ord @ A ) )
=> ! [A3: A,B2: A,F2: A > B,C2: B] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ( F2 @ B2 )
= C2 )
=> ( ! [X5: A,Y4: A] :
( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ord_less_eq @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less_eq @ B @ ( F2 @ A3 ) @ C2 ) ) ) ) ) ).
% ord_le_eq_subst
thf(fact_375_ord__eq__le__subst,axiom,
! [A: $tType,B: $tType] :
( ( ( ord @ B )
& ( ord @ A ) )
=> ! [A3: A,F2: B > A,B2: B,C2: B] :
( ( A3
= ( F2 @ B2 ) )
=> ( ( ord_less_eq @ B @ B2 @ C2 )
=> ( ! [X5: B,Y4: B] :
( ( ord_less_eq @ B @ X5 @ Y4 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less_eq @ A @ A3 @ ( F2 @ C2 ) ) ) ) ) ) ).
% ord_eq_le_subst
thf(fact_376_linorder__linear,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
| ( ord_less_eq @ A @ Y @ X ) ) ) ).
% linorder_linear
thf(fact_377_order__eq__refl,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A] :
( ( X = Y )
=> ( ord_less_eq @ A @ X @ Y ) ) ) ).
% order_eq_refl
thf(fact_378_order__subst2,axiom,
! [A: $tType,C: $tType] :
( ( ( order @ C )
& ( order @ A ) )
=> ! [A3: A,B2: A,F2: A > C,C2: C] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ C @ ( F2 @ B2 ) @ C2 )
=> ( ! [X5: A,Y4: A] :
( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ord_less_eq @ C @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less_eq @ C @ ( F2 @ A3 ) @ C2 ) ) ) ) ) ).
% order_subst2
thf(fact_379_order__subst1,axiom,
! [A: $tType,B: $tType] :
( ( ( order @ B )
& ( order @ A ) )
=> ! [A3: A,F2: B > A,B2: B,C2: B] :
( ( ord_less_eq @ A @ A3 @ ( F2 @ B2 ) )
=> ( ( ord_less_eq @ B @ B2 @ C2 )
=> ( ! [X5: B,Y4: B] :
( ( ord_less_eq @ B @ X5 @ Y4 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less_eq @ A @ A3 @ ( F2 @ C2 ) ) ) ) ) ) ).
% order_subst1
thf(fact_380_Orderings_Oorder__eq__iff,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( ^ [Y5: A,Z3: A] : ( Y5 = Z3 ) )
= ( ^ [A5: A,B4: A] :
( ( ord_less_eq @ A @ A5 @ B4 )
& ( ord_less_eq @ A @ B4 @ A5 ) ) ) ) ) ).
% Orderings.order_eq_iff
thf(fact_381_le__fun__def,axiom,
! [B: $tType,A: $tType] :
( ( ord @ B )
=> ( ( ord_less_eq @ ( A > B ) )
= ( ^ [F3: A > B,G2: A > B] :
! [X2: A] : ( ord_less_eq @ B @ ( F3 @ X2 ) @ ( G2 @ X2 ) ) ) ) ) ).
% le_fun_def
thf(fact_382_le__funI,axiom,
! [B: $tType,A: $tType] :
( ( ord @ B )
=> ! [F2: A > B,G: A > B] :
( ! [X5: A] : ( ord_less_eq @ B @ ( F2 @ X5 ) @ ( G @ X5 ) )
=> ( ord_less_eq @ ( A > B ) @ F2 @ G ) ) ) ).
% le_funI
thf(fact_383_le__funE,axiom,
! [B: $tType,A: $tType] :
( ( ord @ B )
=> ! [F2: A > B,G: A > B,X: A] :
( ( ord_less_eq @ ( A > B ) @ F2 @ G )
=> ( ord_less_eq @ B @ ( F2 @ X ) @ ( G @ X ) ) ) ) ).
% le_funE
thf(fact_384_le__funD,axiom,
! [B: $tType,A: $tType] :
( ( ord @ B )
=> ! [F2: A > B,G: A > B,X: A] :
( ( ord_less_eq @ ( A > B ) @ F2 @ G )
=> ( ord_less_eq @ B @ ( F2 @ X ) @ ( G @ X ) ) ) ) ).
% le_funD
thf(fact_385_antisym,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ B2 @ A3 )
=> ( A3 = B2 ) ) ) ) ).
% antisym
thf(fact_386_dual__order_Otrans,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( ord_less_eq @ A @ C2 @ B2 )
=> ( ord_less_eq @ A @ C2 @ A3 ) ) ) ) ).
% dual_order.trans
thf(fact_387_dual__order_Oantisym,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( ord_less_eq @ A @ A3 @ B2 )
=> ( A3 = B2 ) ) ) ) ).
% dual_order.antisym
thf(fact_388_dual__order_Oeq__iff,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( ^ [Y5: A,Z3: A] : ( Y5 = Z3 ) )
= ( ^ [A5: A,B4: A] :
( ( ord_less_eq @ A @ B4 @ A5 )
& ( ord_less_eq @ A @ A5 @ B4 ) ) ) ) ) ).
% dual_order.eq_iff
thf(fact_389_linorder__wlog,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [P2: A > A > $o,A3: A,B2: A] :
( ! [A7: A,B5: A] :
( ( ord_less_eq @ A @ A7 @ B5 )
=> ( P2 @ A7 @ B5 ) )
=> ( ! [A7: A,B5: A] :
( ( P2 @ B5 @ A7 )
=> ( P2 @ A7 @ B5 ) )
=> ( P2 @ A3 @ B2 ) ) ) ) ).
% linorder_wlog
thf(fact_390_order__trans,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_less_eq @ A @ Y @ Z )
=> ( ord_less_eq @ A @ X @ Z ) ) ) ) ).
% order_trans
thf(fact_391_order_Otrans,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ B2 @ C2 )
=> ( ord_less_eq @ A @ A3 @ C2 ) ) ) ) ).
% order.trans
thf(fact_392_order__antisym,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_less_eq @ A @ Y @ X )
=> ( X = Y ) ) ) ) ).
% order_antisym
thf(fact_393_ord__le__eq__trans,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( B2 = C2 )
=> ( ord_less_eq @ A @ A3 @ C2 ) ) ) ) ).
% ord_le_eq_trans
thf(fact_394_ord__eq__le__trans,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( A3 = B2 )
=> ( ( ord_less_eq @ A @ B2 @ C2 )
=> ( ord_less_eq @ A @ A3 @ C2 ) ) ) ) ).
% ord_eq_le_trans
thf(fact_395_order__class_Oorder__eq__iff,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( ^ [Y5: A,Z3: A] : ( Y5 = Z3 ) )
= ( ^ [X2: A,Y2: A] :
( ( ord_less_eq @ A @ X2 @ Y2 )
& ( ord_less_eq @ A @ Y2 @ X2 ) ) ) ) ) ).
% order_class.order_eq_iff
thf(fact_396_le__cases3,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ( ord_less_eq @ A @ X @ Y )
=> ~ ( ord_less_eq @ A @ Y @ Z ) )
=> ( ( ( ord_less_eq @ A @ Y @ X )
=> ~ ( ord_less_eq @ A @ X @ Z ) )
=> ( ( ( ord_less_eq @ A @ X @ Z )
=> ~ ( ord_less_eq @ A @ Z @ Y ) )
=> ( ( ( ord_less_eq @ A @ Z @ Y )
=> ~ ( ord_less_eq @ A @ Y @ X ) )
=> ( ( ( ord_less_eq @ A @ Y @ Z )
=> ~ ( ord_less_eq @ A @ Z @ X ) )
=> ~ ( ( ord_less_eq @ A @ Z @ X )
=> ~ ( ord_less_eq @ A @ X @ Y ) ) ) ) ) ) ) ) ).
% le_cases3
thf(fact_397_nle__le,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ~ ( ord_less_eq @ A @ A3 @ B2 ) )
= ( ( ord_less_eq @ A @ B2 @ A3 )
& ( B2 != A3 ) ) ) ) ).
% nle_le
thf(fact_398_order__less__imp__not__less,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ~ ( ord_less @ A @ Y @ X ) ) ) ).
% order_less_imp_not_less
thf(fact_399_order__less__imp__not__eq2,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( Y != X ) ) ) ).
% order_less_imp_not_eq2
thf(fact_400_order__less__imp__not__eq,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( X != Y ) ) ) ).
% order_less_imp_not_eq
thf(fact_401_linorder__less__linear,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
| ( X = Y )
| ( ord_less @ A @ Y @ X ) ) ) ).
% linorder_less_linear
thf(fact_402_order__less__imp__triv,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A,P2: $o] :
( ( ord_less @ A @ X @ Y )
=> ( ( ord_less @ A @ Y @ X )
=> P2 ) ) ) ).
% order_less_imp_triv
thf(fact_403_order__less__not__sym,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ~ ( ord_less @ A @ Y @ X ) ) ) ).
% order_less_not_sym
thf(fact_404_order__less__subst2,axiom,
! [A: $tType,C: $tType] :
( ( ( order @ C )
& ( order @ A ) )
=> ! [A3: A,B2: A,F2: A > C,C2: C] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ C @ ( F2 @ B2 ) @ C2 )
=> ( ! [X5: A,Y4: A] :
( ( ord_less @ A @ X5 @ Y4 )
=> ( ord_less @ C @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less @ C @ ( F2 @ A3 ) @ C2 ) ) ) ) ) ).
% order_less_subst2
thf(fact_405_order__less__subst1,axiom,
! [A: $tType,B: $tType] :
( ( ( order @ B )
& ( order @ A ) )
=> ! [A3: A,F2: B > A,B2: B,C2: B] :
( ( ord_less @ A @ A3 @ ( F2 @ B2 ) )
=> ( ( ord_less @ B @ B2 @ C2 )
=> ( ! [X5: B,Y4: B] :
( ( ord_less @ B @ X5 @ Y4 )
=> ( ord_less @ A @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less @ A @ A3 @ ( F2 @ C2 ) ) ) ) ) ) ).
% order_less_subst1
thf(fact_406_order__less__irrefl,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A] :
~ ( ord_less @ A @ X @ X ) ) ).
% order_less_irrefl
thf(fact_407_ord__less__eq__subst,axiom,
! [A: $tType,B: $tType] :
( ( ( ord @ B )
& ( ord @ A ) )
=> ! [A3: A,B2: A,F2: A > B,C2: B] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ( F2 @ B2 )
= C2 )
=> ( ! [X5: A,Y4: A] :
( ( ord_less @ A @ X5 @ Y4 )
=> ( ord_less @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less @ B @ ( F2 @ A3 ) @ C2 ) ) ) ) ) ).
% ord_less_eq_subst
thf(fact_408_ord__eq__less__subst,axiom,
! [A: $tType,B: $tType] :
( ( ( ord @ B )
& ( ord @ A ) )
=> ! [A3: A,F2: B > A,B2: B,C2: B] :
( ( A3
= ( F2 @ B2 ) )
=> ( ( ord_less @ B @ B2 @ C2 )
=> ( ! [X5: B,Y4: B] :
( ( ord_less @ B @ X5 @ Y4 )
=> ( ord_less @ A @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less @ A @ A3 @ ( F2 @ C2 ) ) ) ) ) ) ).
% ord_eq_less_subst
thf(fact_409_order__less__trans,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less @ A @ X @ Y )
=> ( ( ord_less @ A @ Y @ Z )
=> ( ord_less @ A @ X @ Z ) ) ) ) ).
% order_less_trans
thf(fact_410_order__less__asym_H,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ~ ( ord_less @ A @ B2 @ A3 ) ) ) ).
% order_less_asym'
thf(fact_411_linorder__neq__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( X != Y )
= ( ( ord_less @ A @ X @ Y )
| ( ord_less @ A @ Y @ X ) ) ) ) ).
% linorder_neq_iff
thf(fact_412_order__less__asym,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ~ ( ord_less @ A @ Y @ X ) ) ) ).
% order_less_asym
thf(fact_413_linorder__neqE,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( X != Y )
=> ( ~ ( ord_less @ A @ X @ Y )
=> ( ord_less @ A @ Y @ X ) ) ) ) ).
% linorder_neqE
thf(fact_414_dual__order_Ostrict__implies__not__eq,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( A3 != B2 ) ) ) ).
% dual_order.strict_implies_not_eq
thf(fact_415_order_Ostrict__implies__not__eq,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( A3 != B2 ) ) ) ).
% order.strict_implies_not_eq
thf(fact_416_dual__order_Ostrict__trans,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ( ord_less @ A @ C2 @ B2 )
=> ( ord_less @ A @ C2 @ A3 ) ) ) ) ).
% dual_order.strict_trans
thf(fact_417_not__less__iff__gr__or__eq,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( ~ ( ord_less @ A @ X @ Y ) )
= ( ( ord_less @ A @ Y @ X )
| ( X = Y ) ) ) ) ).
% not_less_iff_gr_or_eq
thf(fact_418_order_Ostrict__trans,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ B2 @ C2 )
=> ( ord_less @ A @ A3 @ C2 ) ) ) ) ).
% order.strict_trans
thf(fact_419_linorder__less__wlog,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [P2: A > A > $o,A3: A,B2: A] :
( ! [A7: A,B5: A] :
( ( ord_less @ A @ A7 @ B5 )
=> ( P2 @ A7 @ B5 ) )
=> ( ! [A7: A] : ( P2 @ A7 @ A7 )
=> ( ! [A7: A,B5: A] :
( ( P2 @ B5 @ A7 )
=> ( P2 @ A7 @ B5 ) )
=> ( P2 @ A3 @ B2 ) ) ) ) ) ).
% linorder_less_wlog
thf(fact_420_exists__least__iff,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ( ( ^ [P3: A > $o] :
? [X6: A] : ( P3 @ X6 ) )
= ( ^ [P: A > $o] :
? [N: A] :
( ( P @ N )
& ! [M2: A] :
( ( ord_less @ A @ M2 @ N )
=> ~ ( P @ M2 ) ) ) ) ) ) ).
% exists_least_iff
thf(fact_421_dual__order_Oirrefl,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A] :
~ ( ord_less @ A @ A3 @ A3 ) ) ).
% dual_order.irrefl
thf(fact_422_dual__order_Oasym,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ~ ( ord_less @ A @ A3 @ B2 ) ) ) ).
% dual_order.asym
thf(fact_423_linorder__cases,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ~ ( ord_less @ A @ X @ Y )
=> ( ( X != Y )
=> ( ord_less @ A @ Y @ X ) ) ) ) ).
% linorder_cases
thf(fact_424_antisym__conv3,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Y: A,X: A] :
( ~ ( ord_less @ A @ Y @ X )
=> ( ( ~ ( ord_less @ A @ X @ Y ) )
= ( X = Y ) ) ) ) ).
% antisym_conv3
thf(fact_425_less__induct,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [P2: A > $o,A3: A] :
( ! [X5: A] :
( ! [Y3: A] :
( ( ord_less @ A @ Y3 @ X5 )
=> ( P2 @ Y3 ) )
=> ( P2 @ X5 ) )
=> ( P2 @ A3 ) ) ) ).
% less_induct
thf(fact_426_ord__less__eq__trans,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( B2 = C2 )
=> ( ord_less @ A @ A3 @ C2 ) ) ) ) ).
% ord_less_eq_trans
thf(fact_427_ord__eq__less__trans,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( A3 = B2 )
=> ( ( ord_less @ A @ B2 @ C2 )
=> ( ord_less @ A @ A3 @ C2 ) ) ) ) ).
% ord_eq_less_trans
thf(fact_428_order_Oasym,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ~ ( ord_less @ A @ B2 @ A3 ) ) ) ).
% order.asym
thf(fact_429_less__imp__neq,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( X != Y ) ) ) ).
% less_imp_neq
thf(fact_430_dense,axiom,
! [A: $tType] :
( ( dense_order @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ? [Z2: A] :
( ( ord_less @ A @ X @ Z2 )
& ( ord_less @ A @ Z2 @ Y ) ) ) ) ).
% dense
thf(fact_431_gt__ex,axiom,
! [A: $tType] :
( ( no_top @ A )
=> ! [X: A] :
? [X_12: A] : ( ord_less @ A @ X @ X_12 ) ) ).
% gt_ex
thf(fact_432_lt__ex,axiom,
! [A: $tType] :
( ( no_bot @ A )
=> ! [X: A] :
? [Y4: A] : ( ord_less @ A @ Y4 @ X ) ) ).
% lt_ex
thf(fact_433_bot__fun__def,axiom,
! [B: $tType,A: $tType] :
( ( bot @ B )
=> ( ( bot_bot @ ( A > B ) )
= ( ^ [X2: A] : ( bot_bot @ B ) ) ) ) ).
% bot_fun_def
thf(fact_434_not__psubset__empty,axiom,
! [A: $tType,A4: set @ A] :
~ ( ord_less @ ( set @ A ) @ A4 @ ( bot_bot @ ( set @ A ) ) ) ).
% not_psubset_empty
thf(fact_435_ex__in__conv,axiom,
! [A: $tType,A4: set @ A] :
( ( ? [X2: A] : ( member2 @ A @ X2 @ A4 ) )
= ( A4
!= ( bot_bot @ ( set @ A ) ) ) ) ).
% ex_in_conv
thf(fact_436_equals0I,axiom,
! [A: $tType,A4: set @ A] :
( ! [Y4: A] :
~ ( member2 @ A @ Y4 @ A4 )
=> ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ).
% equals0I
thf(fact_437_equals0D,axiom,
! [A: $tType,A4: set @ A,A3: A] :
( ( A4
= ( bot_bot @ ( set @ A ) ) )
=> ~ ( member2 @ A @ A3 @ A4 ) ) ).
% equals0D
thf(fact_438_emptyE,axiom,
! [A: $tType,A3: A] :
~ ( member2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ).
% emptyE
thf(fact_439_subset__iff__psubset__eq,axiom,
! [A: $tType] :
( ( ord_less_eq @ ( set @ A ) )
= ( ^ [A6: set @ A,B6: set @ A] :
( ( ord_less @ ( set @ A ) @ A6 @ B6 )
| ( A6 = B6 ) ) ) ) ).
% subset_iff_psubset_eq
thf(fact_440_subset__psubset__trans,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,C5: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( ord_less @ ( set @ A ) @ B3 @ C5 )
=> ( ord_less @ ( set @ A ) @ A4 @ C5 ) ) ) ).
% subset_psubset_trans
thf(fact_441_subset__not__subset__eq,axiom,
! [A: $tType] :
( ( ord_less @ ( set @ A ) )
= ( ^ [A6: set @ A,B6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A6 @ B6 )
& ~ ( ord_less_eq @ ( set @ A ) @ B6 @ A6 ) ) ) ) ).
% subset_not_subset_eq
thf(fact_442_psubset__subset__trans,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,C5: set @ A] :
( ( ord_less @ ( set @ A ) @ A4 @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ C5 )
=> ( ord_less @ ( set @ A ) @ A4 @ C5 ) ) ) ).
% psubset_subset_trans
thf(fact_443_psubset__imp__subset,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ).
% psubset_imp_subset
thf(fact_444_Collect__mono__iff,axiom,
! [A: $tType,P2: A > $o,Q: A > $o] :
( ( ord_less_eq @ ( set @ A ) @ ( collect @ A @ P2 ) @ ( collect @ A @ Q ) )
= ( ! [X2: A] :
( ( P2 @ X2 )
=> ( Q @ X2 ) ) ) ) ).
% Collect_mono_iff
thf(fact_445_set__eq__subset,axiom,
! [A: $tType] :
( ( ^ [Y5: set @ A,Z3: set @ A] : ( Y5 = Z3 ) )
= ( ^ [A6: set @ A,B6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A6 @ B6 )
& ( ord_less_eq @ ( set @ A ) @ B6 @ A6 ) ) ) ) ).
% set_eq_subset
thf(fact_446_subset__trans,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,C5: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ C5 )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ C5 ) ) ) ).
% subset_trans
thf(fact_447_Collect__mono,axiom,
! [A: $tType,P2: A > $o,Q: A > $o] :
( ! [X5: A] :
( ( P2 @ X5 )
=> ( Q @ X5 ) )
=> ( ord_less_eq @ ( set @ A ) @ ( collect @ A @ P2 ) @ ( collect @ A @ Q ) ) ) ).
% Collect_mono
thf(fact_448_subset__refl,axiom,
! [A: $tType,A4: set @ A] : ( ord_less_eq @ ( set @ A ) @ A4 @ A4 ) ).
% subset_refl
thf(fact_449_subset__iff,axiom,
! [A: $tType] :
( ( ord_less_eq @ ( set @ A ) )
= ( ^ [A6: set @ A,B6: set @ A] :
! [T3: A] :
( ( member2 @ A @ T3 @ A6 )
=> ( member2 @ A @ T3 @ B6 ) ) ) ) ).
% subset_iff
thf(fact_450_psubset__eq,axiom,
! [A: $tType] :
( ( ord_less @ ( set @ A ) )
= ( ^ [A6: set @ A,B6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A6 @ B6 )
& ( A6 != B6 ) ) ) ) ).
% psubset_eq
thf(fact_451_equalityD2,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( A4 = B3 )
=> ( ord_less_eq @ ( set @ A ) @ B3 @ A4 ) ) ).
% equalityD2
thf(fact_452_equalityD1,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( A4 = B3 )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ).
% equalityD1
thf(fact_453_subset__eq,axiom,
! [A: $tType] :
( ( ord_less_eq @ ( set @ A ) )
= ( ^ [A6: set @ A,B6: set @ A] :
! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( member2 @ A @ X2 @ B6 ) ) ) ) ).
% subset_eq
thf(fact_454_equalityE,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( A4 = B3 )
=> ~ ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ~ ( ord_less_eq @ ( set @ A ) @ B3 @ A4 ) ) ) ).
% equalityE
thf(fact_455_psubsetE,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less @ ( set @ A ) @ A4 @ B3 )
=> ~ ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ ( set @ A ) @ B3 @ A4 ) ) ) ).
% psubsetE
thf(fact_456_subsetD,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,C2: A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( member2 @ A @ C2 @ A4 )
=> ( member2 @ A @ C2 @ B3 ) ) ) ).
% subsetD
thf(fact_457_in__mono,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,X: A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( member2 @ A @ X @ A4 )
=> ( member2 @ A @ X @ B3 ) ) ) ).
% in_mono
thf(fact_458_VEBT__internal_Omembermima_Osimps_I3_J,axiom,
! [Mi: nat,Ma: nat,Va: list @ vEBT_VEBT,Vb: vEBT_VEBT,X: nat] :
( ( vEBT_VEBT_membermima @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ ( zero_zero @ nat ) @ Va @ Vb ) @ X )
= ( ( X = Mi )
| ( X = Ma ) ) ) ).
% VEBT_internal.membermima.simps(3)
thf(fact_459_order__le__imp__less__or__eq,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_less @ A @ X @ Y )
| ( X = Y ) ) ) ) ).
% order_le_imp_less_or_eq
thf(fact_460_linorder__le__less__linear,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
| ( ord_less @ A @ Y @ X ) ) ) ).
% linorder_le_less_linear
thf(fact_461_order__less__le__subst2,axiom,
! [A: $tType,C: $tType] :
( ( ( order @ C )
& ( order @ A ) )
=> ! [A3: A,B2: A,F2: A > C,C2: C] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ C @ ( F2 @ B2 ) @ C2 )
=> ( ! [X5: A,Y4: A] :
( ( ord_less @ A @ X5 @ Y4 )
=> ( ord_less @ C @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less @ C @ ( F2 @ A3 ) @ C2 ) ) ) ) ) ).
% order_less_le_subst2
thf(fact_462_order__less__le__subst1,axiom,
! [A: $tType,B: $tType] :
( ( ( order @ B )
& ( order @ A ) )
=> ! [A3: A,F2: B > A,B2: B,C2: B] :
( ( ord_less @ A @ A3 @ ( F2 @ B2 ) )
=> ( ( ord_less_eq @ B @ B2 @ C2 )
=> ( ! [X5: B,Y4: B] :
( ( ord_less_eq @ B @ X5 @ Y4 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less @ A @ A3 @ ( F2 @ C2 ) ) ) ) ) ) ).
% order_less_le_subst1
thf(fact_463_order__le__less__subst2,axiom,
! [A: $tType,C: $tType] :
( ( ( order @ C )
& ( order @ A ) )
=> ! [A3: A,B2: A,F2: A > C,C2: C] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less @ C @ ( F2 @ B2 ) @ C2 )
=> ( ! [X5: A,Y4: A] :
( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ord_less_eq @ C @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less @ C @ ( F2 @ A3 ) @ C2 ) ) ) ) ) ).
% order_le_less_subst2
thf(fact_464_order__le__less__subst1,axiom,
! [A: $tType,B: $tType] :
( ( ( order @ B )
& ( order @ A ) )
=> ! [A3: A,F2: B > A,B2: B,C2: B] :
( ( ord_less_eq @ A @ A3 @ ( F2 @ B2 ) )
=> ( ( ord_less @ B @ B2 @ C2 )
=> ( ! [X5: B,Y4: B] :
( ( ord_less @ B @ X5 @ Y4 )
=> ( ord_less @ A @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ord_less @ A @ A3 @ ( F2 @ C2 ) ) ) ) ) ) ).
% order_le_less_subst1
thf(fact_465_order__less__le__trans,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less @ A @ X @ Y )
=> ( ( ord_less_eq @ A @ Y @ Z )
=> ( ord_less @ A @ X @ Z ) ) ) ) ).
% order_less_le_trans
thf(fact_466_order__le__less__trans,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_less @ A @ Y @ Z )
=> ( ord_less @ A @ X @ Z ) ) ) ) ).
% order_le_less_trans
thf(fact_467_order__neq__le__trans,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A3: A,B2: A] :
( ( A3 != B2 )
=> ( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ord_less @ A @ A3 @ B2 ) ) ) ) ).
% order_neq_le_trans
thf(fact_468_order__le__neq__trans,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( A3 != B2 )
=> ( ord_less @ A @ A3 @ B2 ) ) ) ) ).
% order_le_neq_trans
thf(fact_469_order__less__imp__le,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( ord_less_eq @ A @ X @ Y ) ) ) ).
% order_less_imp_le
thf(fact_470_linorder__not__less,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( ~ ( ord_less @ A @ X @ Y ) )
= ( ord_less_eq @ A @ Y @ X ) ) ) ).
% linorder_not_less
thf(fact_471_linorder__not__le,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( ~ ( ord_less_eq @ A @ X @ Y ) )
= ( ord_less @ A @ Y @ X ) ) ) ).
% linorder_not_le
thf(fact_472_order__less__le,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( ord_less @ A )
= ( ^ [X2: A,Y2: A] :
( ( ord_less_eq @ A @ X2 @ Y2 )
& ( X2 != Y2 ) ) ) ) ) ).
% order_less_le
thf(fact_473_order__le__less,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [X2: A,Y2: A] :
( ( ord_less @ A @ X2 @ Y2 )
| ( X2 = Y2 ) ) ) ) ) ).
% order_le_less
thf(fact_474_dual__order_Ostrict__implies__order,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ord_less_eq @ A @ B2 @ A3 ) ) ) ).
% dual_order.strict_implies_order
thf(fact_475_order_Ostrict__implies__order,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ord_less_eq @ A @ A3 @ B2 ) ) ) ).
% order.strict_implies_order
thf(fact_476_dual__order_Ostrict__iff__not,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( ( ord_less @ A )
= ( ^ [B4: A,A5: A] :
( ( ord_less_eq @ A @ B4 @ A5 )
& ~ ( ord_less_eq @ A @ A5 @ B4 ) ) ) ) ) ).
% dual_order.strict_iff_not
thf(fact_477_dual__order_Ostrict__trans2,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ( ord_less_eq @ A @ C2 @ B2 )
=> ( ord_less @ A @ C2 @ A3 ) ) ) ) ).
% dual_order.strict_trans2
thf(fact_478_dual__order_Ostrict__trans1,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( ord_less @ A @ C2 @ B2 )
=> ( ord_less @ A @ C2 @ A3 ) ) ) ) ).
% dual_order.strict_trans1
thf(fact_479_dual__order_Ostrict__iff__order,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( ord_less @ A )
= ( ^ [B4: A,A5: A] :
( ( ord_less_eq @ A @ B4 @ A5 )
& ( A5 != B4 ) ) ) ) ) ).
% dual_order.strict_iff_order
thf(fact_480_dual__order_Oorder__iff__strict,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [B4: A,A5: A] :
( ( ord_less @ A @ B4 @ A5 )
| ( A5 = B4 ) ) ) ) ) ).
% dual_order.order_iff_strict
thf(fact_481_dense__le__bounded,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less @ A @ X @ Y )
=> ( ! [W: A] :
( ( ord_less @ A @ X @ W )
=> ( ( ord_less @ A @ W @ Y )
=> ( ord_less_eq @ A @ W @ Z ) ) )
=> ( ord_less_eq @ A @ Y @ Z ) ) ) ) ).
% dense_le_bounded
thf(fact_482_dense__ge__bounded,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [Z: A,X: A,Y: A] :
( ( ord_less @ A @ Z @ X )
=> ( ! [W: A] :
( ( ord_less @ A @ Z @ W )
=> ( ( ord_less @ A @ W @ X )
=> ( ord_less_eq @ A @ Y @ W ) ) )
=> ( ord_less_eq @ A @ Y @ Z ) ) ) ) ).
% dense_ge_bounded
thf(fact_483_order_Ostrict__iff__not,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( ( ord_less @ A )
= ( ^ [A5: A,B4: A] :
( ( ord_less_eq @ A @ A5 @ B4 )
& ~ ( ord_less_eq @ A @ B4 @ A5 ) ) ) ) ) ).
% order.strict_iff_not
thf(fact_484_order_Ostrict__trans2,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ B2 @ C2 )
=> ( ord_less @ A @ A3 @ C2 ) ) ) ) ).
% order.strict_trans2
thf(fact_485_order_Ostrict__trans1,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ B2 @ C2 )
=> ( ord_less @ A @ A3 @ C2 ) ) ) ) ).
% order.strict_trans1
thf(fact_486_order_Ostrict__iff__order,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( ord_less @ A )
= ( ^ [A5: A,B4: A] :
( ( ord_less_eq @ A @ A5 @ B4 )
& ( A5 != B4 ) ) ) ) ) ).
% order.strict_iff_order
thf(fact_487_order_Oorder__iff__strict,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [A5: A,B4: A] :
( ( ord_less @ A @ A5 @ B4 )
| ( A5 = B4 ) ) ) ) ) ).
% order.order_iff_strict
thf(fact_488_not__le__imp__less,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Y: A,X: A] :
( ~ ( ord_less_eq @ A @ Y @ X )
=> ( ord_less @ A @ X @ Y ) ) ) ).
% not_le_imp_less
thf(fact_489_less__le__not__le,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( ( ord_less @ A )
= ( ^ [X2: A,Y2: A] :
( ( ord_less_eq @ A @ X2 @ Y2 )
& ~ ( ord_less_eq @ A @ Y2 @ X2 ) ) ) ) ) ).
% less_le_not_le
thf(fact_490_dense__le,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [Y: A,Z: A] :
( ! [X5: A] :
( ( ord_less @ A @ X5 @ Y )
=> ( ord_less_eq @ A @ X5 @ Z ) )
=> ( ord_less_eq @ A @ Y @ Z ) ) ) ).
% dense_le
thf(fact_491_dense__ge,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [Z: A,Y: A] :
( ! [X5: A] :
( ( ord_less @ A @ Z @ X5 )
=> ( ord_less_eq @ A @ Y @ X5 ) )
=> ( ord_less_eq @ A @ Y @ Z ) ) ) ).
% dense_ge
thf(fact_492_antisym__conv2,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( ~ ( ord_less @ A @ X @ Y ) )
= ( X = Y ) ) ) ) ).
% antisym_conv2
thf(fact_493_antisym__conv1,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X: A,Y: A] :
( ~ ( ord_less @ A @ X @ Y )
=> ( ( ord_less_eq @ A @ X @ Y )
= ( X = Y ) ) ) ) ).
% antisym_conv1
thf(fact_494_nless__le,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A3: A,B2: A] :
( ( ~ ( ord_less @ A @ A3 @ B2 ) )
= ( ~ ( ord_less_eq @ A @ A3 @ B2 )
| ( A3 = B2 ) ) ) ) ).
% nless_le
thf(fact_495_leI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ~ ( ord_less @ A @ X @ Y )
=> ( ord_less_eq @ A @ Y @ X ) ) ) ).
% leI
thf(fact_496_leD,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ Y @ X )
=> ~ ( ord_less @ A @ X @ Y ) ) ) ).
% leD
thf(fact_497_bot_Oextremum__uniqueI,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ A3 @ ( bot_bot @ A ) )
=> ( A3
= ( bot_bot @ A ) ) ) ) ).
% bot.extremum_uniqueI
thf(fact_498_bot_Oextremum__unique,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ A3 @ ( bot_bot @ A ) )
= ( A3
= ( bot_bot @ A ) ) ) ) ).
% bot.extremum_unique
thf(fact_499_bot_Oextremum,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ! [A3: A] : ( ord_less_eq @ A @ ( bot_bot @ A ) @ A3 ) ) ).
% bot.extremum
thf(fact_500_bot_Onot__eq__extremum,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ! [A3: A] :
( ( A3
!= ( bot_bot @ A ) )
= ( ord_less @ A @ ( bot_bot @ A ) @ A3 ) ) ) ).
% bot.not_eq_extremum
thf(fact_501_bot_Oextremum__strict,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ! [A3: A] :
~ ( ord_less @ A @ A3 @ ( bot_bot @ A ) ) ) ).
% bot.extremum_strict
thf(fact_502_vebt__buildup_Ocases,axiom,
! [X: nat] :
( ( X
!= ( zero_zero @ nat ) )
=> ( ( X
!= ( suc @ ( zero_zero @ nat ) ) )
=> ~ ! [Va2: nat] :
( X
!= ( suc @ ( suc @ Va2 ) ) ) ) ) ).
% vebt_buildup.cases
thf(fact_503_max__absorb2,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_max @ A @ X @ Y )
= Y ) ) ) ).
% max_absorb2
thf(fact_504_max__absorb1,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ Y @ X )
=> ( ( ord_max @ A @ X @ Y )
= X ) ) ) ).
% max_absorb1
thf(fact_505_max__def,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( ord_max @ A )
= ( ^ [A5: A,B4: A] : ( if @ A @ ( ord_less_eq @ A @ A5 @ B4 ) @ B4 @ A5 ) ) ) ) ).
% max_def
thf(fact_506_option_Osize__gen_I2_J,axiom,
! [A: $tType,X: A > nat,X22: A] :
( ( size_option @ A @ X @ ( some @ A @ X22 ) )
= ( plus_plus @ nat @ ( X @ X22 ) @ ( suc @ ( zero_zero @ nat ) ) ) ) ).
% option.size_gen(2)
thf(fact_507_old_Oprod_Oinject,axiom,
! [A: $tType,B: $tType,A3: A,B2: B,A8: A,B7: B] :
( ( ( product_Pair @ A @ B @ A3 @ B2 )
= ( product_Pair @ A @ B @ A8 @ B7 ) )
= ( ( A3 = A8 )
& ( B2 = B7 ) ) ) ).
% old.prod.inject
thf(fact_508_prod_Oinject,axiom,
! [A: $tType,B: $tType,X1: A,X22: B,Y1: A,Y22: B] :
( ( ( product_Pair @ A @ B @ X1 @ X22 )
= ( product_Pair @ A @ B @ Y1 @ Y22 ) )
= ( ( X1 = Y1 )
& ( X22 = Y22 ) ) ) ).
% prod.inject
thf(fact_509_inthall,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o,N2: nat] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X5 ) )
=> ( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( P2 @ ( nth @ A @ Xs @ N2 ) ) ) ) ).
% inthall
thf(fact_510_set__vebt__finite,axiom,
! [T2: vEBT_VEBT,N2: nat] :
( ( vEBT_invar_vebt @ T2 @ N2 )
=> ( finite_finite @ nat @ ( vEBT_VEBT_set_vebt @ T2 ) ) ) ).
% set_vebt_finite
thf(fact_511_option_Osize_I4_J,axiom,
! [A: $tType,X22: A] :
( ( size_size @ ( option @ A ) @ ( some @ A @ X22 ) )
= ( suc @ ( zero_zero @ nat ) ) ) ).
% option.size(4)
thf(fact_512_Euclid__induct,axiom,
! [P2: nat > nat > $o,A3: nat,B2: nat] :
( ! [A7: nat,B5: nat] :
( ( P2 @ A7 @ B5 )
= ( P2 @ B5 @ A7 ) )
=> ( ! [A7: nat] : ( P2 @ A7 @ ( zero_zero @ nat ) )
=> ( ! [A7: nat,B5: nat] :
( ( P2 @ A7 @ B5 )
=> ( P2 @ A7 @ ( plus_plus @ nat @ A7 @ B5 ) ) )
=> ( P2 @ A3 @ B2 ) ) ) ) ).
% Euclid_induct
thf(fact_513_nat__descend__induct,axiom,
! [N2: nat,P2: nat > $o,M: nat] :
( ! [K3: nat] :
( ( ord_less @ nat @ N2 @ K3 )
=> ( P2 @ K3 ) )
=> ( ! [K3: nat] :
( ( ord_less_eq @ nat @ K3 @ N2 )
=> ( ! [I4: nat] :
( ( ord_less @ nat @ K3 @ I4 )
=> ( P2 @ I4 ) )
=> ( P2 @ K3 ) ) )
=> ( P2 @ M ) ) ) ).
% nat_descend_induct
thf(fact_514_subset__emptyI,axiom,
! [A: $tType,A4: set @ A] :
( ! [X5: A] :
~ ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ ( bot_bot @ ( set @ A ) ) ) ) ).
% subset_emptyI
thf(fact_515_exists__least__lemma,axiom,
! [P2: nat > $o] :
( ~ ( P2 @ ( zero_zero @ nat ) )
=> ( ? [X_1: nat] : ( P2 @ X_1 )
=> ? [N3: nat] :
( ~ ( P2 @ N3 )
& ( P2 @ ( suc @ N3 ) ) ) ) ) ).
% exists_least_lemma
thf(fact_516_dependent__nat__choice,axiom,
! [A: $tType,P2: nat > A > $o,Q: nat > A > A > $o] :
( ? [X_1: A] : ( P2 @ ( zero_zero @ nat ) @ X_1 )
=> ( ! [X5: A,N3: nat] :
( ( P2 @ N3 @ X5 )
=> ? [Y3: A] :
( ( P2 @ ( suc @ N3 ) @ Y3 )
& ( Q @ N3 @ X5 @ Y3 ) ) )
=> ? [F4: nat > A] :
! [N5: nat] :
( ( P2 @ N5 @ ( F4 @ N5 ) )
& ( Q @ N5 @ ( F4 @ N5 ) @ ( F4 @ ( suc @ N5 ) ) ) ) ) ) ).
% dependent_nat_choice
thf(fact_517_List_Ofinite__set,axiom,
! [A: $tType,Xs: list @ A] : ( finite_finite @ A @ ( set2 @ A @ Xs ) ) ).
% List.finite_set
thf(fact_518_length__list__update,axiom,
! [A: $tType,Xs: list @ A,I: nat,X: A] :
( ( size_size @ ( list @ A ) @ ( list_update @ A @ Xs @ I @ X ) )
= ( size_size @ ( list @ A ) @ Xs ) ) ).
% length_list_update
thf(fact_519_list__update__beyond,axiom,
! [A: $tType,Xs: list @ A,I: nat,X: A] :
( ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ I )
=> ( ( list_update @ A @ Xs @ I @ X )
= Xs ) ) ).
% list_update_beyond
thf(fact_520_nth__list__update__eq,axiom,
! [A: $tType,I: nat,Xs: list @ A,X: A] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ A @ ( list_update @ A @ Xs @ I @ X ) @ I )
= X ) ) ).
% nth_list_update_eq
thf(fact_521_set__swap,axiom,
! [A: $tType,I: nat,Xs: list @ A,J: nat] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ord_less @ nat @ J @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( set2 @ A @ ( list_update @ A @ ( list_update @ A @ Xs @ I @ ( nth @ A @ Xs @ J ) ) @ J @ ( nth @ A @ Xs @ I ) ) )
= ( set2 @ A @ Xs ) ) ) ) ).
% set_swap
thf(fact_522_neq__if__length__neq,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs )
!= ( size_size @ ( list @ A ) @ Ys ) )
=> ( Xs != Ys ) ) ).
% neq_if_length_neq
thf(fact_523_Ex__list__of__length,axiom,
! [A: $tType,N2: nat] :
? [Xs3: list @ A] :
( ( size_size @ ( list @ A ) @ Xs3 )
= N2 ) ).
% Ex_list_of_length
thf(fact_524_size__neq__size__imp__neq,axiom,
! [A: $tType] :
( ( size @ A )
=> ! [X: A,Y: A] :
( ( ( size_size @ A @ X )
!= ( size_size @ A @ Y ) )
=> ( X != Y ) ) ) ).
% size_neq_size_imp_neq
thf(fact_525_length__induct,axiom,
! [A: $tType,P2: ( list @ A ) > $o,Xs: list @ A] :
( ! [Xs3: list @ A] :
( ! [Ys2: list @ A] :
( ( ord_less @ nat @ ( size_size @ ( list @ A ) @ Ys2 ) @ ( size_size @ ( list @ A ) @ Xs3 ) )
=> ( P2 @ Ys2 ) )
=> ( P2 @ Xs3 ) )
=> ( P2 @ Xs ) ) ).
% length_induct
thf(fact_526_finite__list,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ? [Xs3: list @ A] :
( ( set2 @ A @ Xs3 )
= A4 ) ) ).
% finite_list
thf(fact_527_infinite__growing,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X7: set @ A] :
( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ? [Xa: A] :
( ( member2 @ A @ Xa @ X7 )
& ( ord_less @ A @ X5 @ Xa ) ) )
=> ~ ( finite_finite @ A @ X7 ) ) ) ) ).
% infinite_growing
thf(fact_528_ex__min__if__finite,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [S3: set @ A] :
( ( finite_finite @ A @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ S3 )
& ~ ? [Xa: A] :
( ( member2 @ A @ Xa @ S3 )
& ( ord_less @ A @ Xa @ X5 ) ) ) ) ) ) ).
% ex_min_if_finite
thf(fact_529_nth__equalityI,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ A ) @ Ys ) )
=> ( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ A @ Xs @ I3 )
= ( nth @ A @ Ys @ I3 ) ) )
=> ( Xs = Ys ) ) ) ).
% nth_equalityI
thf(fact_530_Skolem__list__nth,axiom,
! [A: $tType,K: nat,P2: nat > A > $o] :
( ( ! [I5: nat] :
( ( ord_less @ nat @ I5 @ K )
=> ? [X8: A] : ( P2 @ I5 @ X8 ) ) )
= ( ? [Xs2: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs2 )
= K )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ K )
=> ( P2 @ I5 @ ( nth @ A @ Xs2 @ I5 ) ) ) ) ) ) ).
% Skolem_list_nth
thf(fact_531_list__eq__iff__nth__eq,axiom,
! [A: $tType] :
( ( ^ [Y5: list @ A,Z3: list @ A] : ( Y5 = Z3 ) )
= ( ^ [Xs2: list @ A,Ys3: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs2 )
= ( size_size @ ( list @ A ) @ Ys3 ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs2 ) )
=> ( ( nth @ A @ Xs2 @ I5 )
= ( nth @ A @ Ys3 @ I5 ) ) ) ) ) ) ).
% list_eq_iff_nth_eq
thf(fact_532_option_Osize__neq,axiom,
! [A: $tType,X: option @ A] :
( ( size_size @ ( option @ A ) @ X )
!= ( zero_zero @ nat ) ) ).
% option.size_neq
thf(fact_533_length__pos__if__in__set,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ ( size_size @ ( list @ A ) @ Xs ) ) ) ).
% length_pos_if_in_set
thf(fact_534_nth__mem,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( member2 @ A @ ( nth @ A @ Xs @ N2 ) @ ( set2 @ A @ Xs ) ) ) ).
% nth_mem
thf(fact_535_list__ball__nth,axiom,
! [A: $tType,N2: nat,Xs: list @ A,P2: A > $o] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X5 ) )
=> ( P2 @ ( nth @ A @ Xs @ N2 ) ) ) ) ).
% list_ball_nth
thf(fact_536_in__set__conv__nth,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
= ( ? [I5: nat] :
( ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs ) )
& ( ( nth @ A @ Xs @ I5 )
= X ) ) ) ) ).
% in_set_conv_nth
thf(fact_537_all__nth__imp__all__set,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o,X: A] :
( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( P2 @ ( nth @ A @ Xs @ I3 ) ) )
=> ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( P2 @ X ) ) ) ).
% all_nth_imp_all_set
thf(fact_538_all__set__conv__all__nth,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X2 ) ) )
= ( ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( P2 @ ( nth @ A @ Xs @ I5 ) ) ) ) ) ).
% all_set_conv_all_nth
thf(fact_539_set__update__memI,axiom,
! [A: $tType,N2: nat,Xs: list @ A,X: A] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( member2 @ A @ X @ ( set2 @ A @ ( list_update @ A @ Xs @ N2 @ X ) ) ) ) ).
% set_update_memI
thf(fact_540_list__update__same__conv,axiom,
! [A: $tType,I: nat,Xs: list @ A,X: A] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ( list_update @ A @ Xs @ I @ X )
= Xs )
= ( ( nth @ A @ Xs @ I )
= X ) ) ) ).
% list_update_same_conv
thf(fact_541_nth__list__update,axiom,
! [A: $tType,I: nat,Xs: list @ A,J: nat,X: A] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ( I = J )
=> ( ( nth @ A @ ( list_update @ A @ Xs @ I @ X ) @ J )
= X ) )
& ( ( I != J )
=> ( ( nth @ A @ ( list_update @ A @ Xs @ I @ X ) @ J )
= ( nth @ A @ Xs @ J ) ) ) ) ) ).
% nth_list_update
thf(fact_542_old_Oprod_Oexhaust,axiom,
! [A: $tType,B: $tType,Y: product_prod @ A @ B] :
~ ! [A7: A,B5: B] :
( Y
!= ( product_Pair @ A @ B @ A7 @ B5 ) ) ).
% old.prod.exhaust
thf(fact_543_surj__pair,axiom,
! [A: $tType,B: $tType,P4: product_prod @ A @ B] :
? [X5: A,Y4: B] :
( P4
= ( product_Pair @ A @ B @ X5 @ Y4 ) ) ).
% surj_pair
thf(fact_544_prod__cases,axiom,
! [B: $tType,A: $tType,P2: ( product_prod @ A @ B ) > $o,P4: product_prod @ A @ B] :
( ! [A7: A,B5: B] : ( P2 @ ( product_Pair @ A @ B @ A7 @ B5 ) )
=> ( P2 @ P4 ) ) ).
% prod_cases
thf(fact_545_Pair__inject,axiom,
! [A: $tType,B: $tType,A3: A,B2: B,A8: A,B7: B] :
( ( ( product_Pair @ A @ B @ A3 @ B2 )
= ( product_Pair @ A @ B @ A8 @ B7 ) )
=> ~ ( ( A3 = A8 )
=> ( B2 != B7 ) ) ) ).
% Pair_inject
thf(fact_546_prod__cases3,axiom,
! [A: $tType,B: $tType,C: $tType,Y: product_prod @ A @ ( product_prod @ B @ C )] :
~ ! [A7: A,B5: B,C4: C] :
( Y
!= ( product_Pair @ A @ ( product_prod @ B @ C ) @ A7 @ ( product_Pair @ B @ C @ B5 @ C4 ) ) ) ).
% prod_cases3
thf(fact_547_prod__cases4,axiom,
! [A: $tType,B: $tType,C: $tType,D: $tType,Y: product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ D ) )] :
~ ! [A7: A,B5: B,C4: C,D3: D] :
( Y
!= ( product_Pair @ A @ ( product_prod @ B @ ( product_prod @ C @ D ) ) @ A7 @ ( product_Pair @ B @ ( product_prod @ C @ D ) @ B5 @ ( product_Pair @ C @ D @ C4 @ D3 ) ) ) ) ).
% prod_cases4
thf(fact_548_prod__cases5,axiom,
! [A: $tType,B: $tType,C: $tType,D: $tType,E2: $tType,Y: product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ E2 ) ) )] :
~ ! [A7: A,B5: B,C4: C,D3: D,E: E2] :
( Y
!= ( product_Pair @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ E2 ) ) ) @ A7 @ ( product_Pair @ B @ ( product_prod @ C @ ( product_prod @ D @ E2 ) ) @ B5 @ ( product_Pair @ C @ ( product_prod @ D @ E2 ) @ C4 @ ( product_Pair @ D @ E2 @ D3 @ E ) ) ) ) ) ).
% prod_cases5
thf(fact_549_prod__cases6,axiom,
! [A: $tType,B: $tType,C: $tType,D: $tType,E2: $tType,F: $tType,Y: product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ F ) ) ) )] :
~ ! [A7: A,B5: B,C4: C,D3: D,E: E2,F4: F] :
( Y
!= ( product_Pair @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ F ) ) ) ) @ A7 @ ( product_Pair @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ F ) ) ) @ B5 @ ( product_Pair @ C @ ( product_prod @ D @ ( product_prod @ E2 @ F ) ) @ C4 @ ( product_Pair @ D @ ( product_prod @ E2 @ F ) @ D3 @ ( product_Pair @ E2 @ F @ E @ F4 ) ) ) ) ) ) ).
% prod_cases6
thf(fact_550_prod__cases7,axiom,
! [A: $tType,B: $tType,C: $tType,D: $tType,E2: $tType,F: $tType,G3: $tType,Y: product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ ( product_prod @ F @ G3 ) ) ) ) )] :
~ ! [A7: A,B5: B,C4: C,D3: D,E: E2,F4: F,G4: G3] :
( Y
!= ( product_Pair @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ ( product_prod @ F @ G3 ) ) ) ) ) @ A7 @ ( product_Pair @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ ( product_prod @ F @ G3 ) ) ) ) @ B5 @ ( product_Pair @ C @ ( product_prod @ D @ ( product_prod @ E2 @ ( product_prod @ F @ G3 ) ) ) @ C4 @ ( product_Pair @ D @ ( product_prod @ E2 @ ( product_prod @ F @ G3 ) ) @ D3 @ ( product_Pair @ E2 @ ( product_prod @ F @ G3 ) @ E @ ( product_Pair @ F @ G3 @ F4 @ G4 ) ) ) ) ) ) ) ).
% prod_cases7
thf(fact_551_prod__induct3,axiom,
! [C: $tType,B: $tType,A: $tType,P2: ( product_prod @ A @ ( product_prod @ B @ C ) ) > $o,X: product_prod @ A @ ( product_prod @ B @ C )] :
( ! [A7: A,B5: B,C4: C] : ( P2 @ ( product_Pair @ A @ ( product_prod @ B @ C ) @ A7 @ ( product_Pair @ B @ C @ B5 @ C4 ) ) )
=> ( P2 @ X ) ) ).
% prod_induct3
thf(fact_552_prod__induct4,axiom,
! [D: $tType,C: $tType,B: $tType,A: $tType,P2: ( product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ D ) ) ) > $o,X: product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ D ) )] :
( ! [A7: A,B5: B,C4: C,D3: D] : ( P2 @ ( product_Pair @ A @ ( product_prod @ B @ ( product_prod @ C @ D ) ) @ A7 @ ( product_Pair @ B @ ( product_prod @ C @ D ) @ B5 @ ( product_Pair @ C @ D @ C4 @ D3 ) ) ) )
=> ( P2 @ X ) ) ).
% prod_induct4
thf(fact_553_prod__induct5,axiom,
! [E2: $tType,D: $tType,C: $tType,B: $tType,A: $tType,P2: ( product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ E2 ) ) ) ) > $o,X: product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ E2 ) ) )] :
( ! [A7: A,B5: B,C4: C,D3: D,E: E2] : ( P2 @ ( product_Pair @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ E2 ) ) ) @ A7 @ ( product_Pair @ B @ ( product_prod @ C @ ( product_prod @ D @ E2 ) ) @ B5 @ ( product_Pair @ C @ ( product_prod @ D @ E2 ) @ C4 @ ( product_Pair @ D @ E2 @ D3 @ E ) ) ) ) )
=> ( P2 @ X ) ) ).
% prod_induct5
thf(fact_554_prod__induct6,axiom,
! [F: $tType,E2: $tType,D: $tType,C: $tType,B: $tType,A: $tType,P2: ( product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ F ) ) ) ) ) > $o,X: product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ F ) ) ) )] :
( ! [A7: A,B5: B,C4: C,D3: D,E: E2,F4: F] : ( P2 @ ( product_Pair @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ F ) ) ) ) @ A7 @ ( product_Pair @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ F ) ) ) @ B5 @ ( product_Pair @ C @ ( product_prod @ D @ ( product_prod @ E2 @ F ) ) @ C4 @ ( product_Pair @ D @ ( product_prod @ E2 @ F ) @ D3 @ ( product_Pair @ E2 @ F @ E @ F4 ) ) ) ) ) )
=> ( P2 @ X ) ) ).
% prod_induct6
thf(fact_555_prod__induct7,axiom,
! [G3: $tType,F: $tType,E2: $tType,D: $tType,C: $tType,B: $tType,A: $tType,P2: ( product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ ( product_prod @ F @ G3 ) ) ) ) ) ) > $o,X: product_prod @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ ( product_prod @ F @ G3 ) ) ) ) )] :
( ! [A7: A,B5: B,C4: C,D3: D,E: E2,F4: F,G4: G3] : ( P2 @ ( product_Pair @ A @ ( product_prod @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ ( product_prod @ F @ G3 ) ) ) ) ) @ A7 @ ( product_Pair @ B @ ( product_prod @ C @ ( product_prod @ D @ ( product_prod @ E2 @ ( product_prod @ F @ G3 ) ) ) ) @ B5 @ ( product_Pair @ C @ ( product_prod @ D @ ( product_prod @ E2 @ ( product_prod @ F @ G3 ) ) ) @ C4 @ ( product_Pair @ D @ ( product_prod @ E2 @ ( product_prod @ F @ G3 ) ) @ D3 @ ( product_Pair @ E2 @ ( product_prod @ F @ G3 ) @ E @ ( product_Pair @ F @ G3 @ F4 @ G4 ) ) ) ) ) ) )
=> ( P2 @ X ) ) ).
% prod_induct7
thf(fact_556_ssubst__Pair__rhs,axiom,
! [B: $tType,A: $tType,R2: A,S: B,R: set @ ( product_prod @ A @ B ),S4: B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ R2 @ S ) @ R )
=> ( ( S4 = S )
=> ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ R2 @ S4 ) @ R ) ) ) ).
% ssubst_Pair_rhs
thf(fact_557_old_Oprod_Orec,axiom,
! [A: $tType,T: $tType,B: $tType,F1: A > B > T,A3: A,B2: B] :
( ( product_rec_prod @ A @ B @ T @ F1 @ ( product_Pair @ A @ B @ A3 @ B2 ) )
= ( F1 @ A3 @ B2 ) ) ).
% old.prod.rec
thf(fact_558_finite__has__minimal,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ A4 )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ A4 )
=> ( ( ord_less_eq @ A @ Xa @ X5 )
=> ( X5 = Xa ) ) ) ) ) ) ) ).
% finite_has_minimal
thf(fact_559_finite__has__maximal,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ A4 )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ A4 )
=> ( ( ord_less_eq @ A @ X5 @ Xa )
=> ( X5 = Xa ) ) ) ) ) ) ) ).
% finite_has_maximal
thf(fact_560_bot__empty__eq,axiom,
! [A: $tType] :
( ( bot_bot @ ( A > $o ) )
= ( ^ [X2: A] : ( member2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% bot_empty_eq
thf(fact_561_Collect__empty__eq__bot,axiom,
! [A: $tType,P2: A > $o] :
( ( ( collect @ A @ P2 )
= ( bot_bot @ ( set @ A ) ) )
= ( P2
= ( bot_bot @ ( A > $o ) ) ) ) ).
% Collect_empty_eq_bot
thf(fact_562_nth__enumerate__eq,axiom,
! [A: $tType,M: nat,Xs: list @ A,N2: nat] :
( ( ord_less @ nat @ M @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ ( product_prod @ nat @ A ) @ ( enumerate @ A @ N2 @ Xs ) @ M )
= ( product_Pair @ nat @ A @ ( plus_plus @ nat @ N2 @ M ) @ ( nth @ A @ Xs @ M ) ) ) ) ).
% nth_enumerate_eq
thf(fact_563_infinite__nat__iff__unbounded__le,axiom,
! [S3: set @ nat] :
( ( ~ ( finite_finite @ nat @ S3 ) )
= ( ! [M2: nat] :
? [N: nat] :
( ( ord_less_eq @ nat @ M2 @ N )
& ( member2 @ nat @ N @ S3 ) ) ) ) ).
% infinite_nat_iff_unbounded_le
thf(fact_564_finite__nat__set__iff__bounded__le,axiom,
( ( finite_finite @ nat )
= ( ^ [N6: set @ nat] :
? [M2: nat] :
! [X2: nat] :
( ( member2 @ nat @ X2 @ N6 )
=> ( ord_less_eq @ nat @ X2 @ M2 ) ) ) ) ).
% finite_nat_set_iff_bounded_le
thf(fact_565_unbounded__k__infinite,axiom,
! [K: nat,S3: set @ nat] :
( ! [M3: nat] :
( ( ord_less @ nat @ K @ M3 )
=> ? [N5: nat] :
( ( ord_less @ nat @ M3 @ N5 )
& ( member2 @ nat @ N5 @ S3 ) ) )
=> ~ ( finite_finite @ nat @ S3 ) ) ).
% unbounded_k_infinite
thf(fact_566_bounded__nat__set__is__finite,axiom,
! [N7: set @ nat,N2: nat] :
( ! [X5: nat] :
( ( member2 @ nat @ X5 @ N7 )
=> ( ord_less @ nat @ X5 @ N2 ) )
=> ( finite_finite @ nat @ N7 ) ) ).
% bounded_nat_set_is_finite
thf(fact_567_length__enumerate,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( size_size @ ( list @ ( product_prod @ nat @ A ) ) @ ( enumerate @ A @ N2 @ Xs ) )
= ( size_size @ ( list @ A ) @ Xs ) ) ).
% length_enumerate
thf(fact_568_finite__maxlen,axiom,
! [A: $tType,M7: set @ ( list @ A )] :
( ( finite_finite @ ( list @ A ) @ M7 )
=> ? [N3: nat] :
! [X3: list @ A] :
( ( member2 @ ( list @ A ) @ X3 @ M7 )
=> ( ord_less @ nat @ ( size_size @ ( list @ A ) @ X3 ) @ N3 ) ) ) ).
% finite_maxlen
thf(fact_569_subrelI,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ B ),S: set @ ( product_prod @ A @ B )] :
( ! [X5: A,Y4: B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X5 @ Y4 ) @ R2 )
=> ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X5 @ Y4 ) @ S ) )
=> ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) ) @ R2 @ S ) ) ).
% subrelI
thf(fact_570_bounded__Max__nat,axiom,
! [P2: nat > $o,X: nat,M7: nat] :
( ( P2 @ X )
=> ( ! [X5: nat] :
( ( P2 @ X5 )
=> ( ord_less_eq @ nat @ X5 @ M7 ) )
=> ~ ! [M3: nat] :
( ( P2 @ M3 )
=> ~ ! [X3: nat] :
( ( P2 @ X3 )
=> ( ord_less_eq @ nat @ X3 @ M3 ) ) ) ) ) ).
% bounded_Max_nat
thf(fact_571_fold__atLeastAtMost__nat_Ocases,axiom,
! [A: $tType,X: product_prod @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) )] :
~ ! [F4: nat > A > A,A7: nat,B5: nat,Acc: A] :
( X
!= ( product_Pair @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) @ F4 @ ( product_Pair @ nat @ ( product_prod @ nat @ A ) @ A7 @ ( product_Pair @ nat @ A @ B5 @ Acc ) ) ) ) ).
% fold_atLeastAtMost_nat.cases
thf(fact_572_finite__has__minimal2,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A4: set @ A,A3: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ A4 )
& ( ord_less_eq @ A @ X5 @ A3 )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ A4 )
=> ( ( ord_less_eq @ A @ Xa @ X5 )
=> ( X5 = Xa ) ) ) ) ) ) ) ).
% finite_has_minimal2
thf(fact_573_finite__has__maximal2,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A4: set @ A,A3: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ A4 )
& ( ord_less_eq @ A @ A3 @ X5 )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ A4 )
=> ( ( ord_less_eq @ A @ X5 @ Xa )
=> ( X5 = Xa ) ) ) ) ) ) ) ).
% finite_has_maximal2
thf(fact_574_finite__transitivity__chain,axiom,
! [A: $tType,A4: set @ A,R: A > A > $o] :
( ( finite_finite @ A @ A4 )
=> ( ! [X5: A] :
~ ( R @ X5 @ X5 )
=> ( ! [X5: A,Y4: A,Z2: A] :
( ( R @ X5 @ Y4 )
=> ( ( R @ Y4 @ Z2 )
=> ( R @ X5 @ Z2 ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ? [Y3: A] :
( ( member2 @ A @ Y3 @ A4 )
& ( R @ X5 @ Y3 ) ) )
=> ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% finite_transitivity_chain
thf(fact_575_infinite__imp__nonempty,axiom,
! [A: $tType,S3: set @ A] :
( ~ ( finite_finite @ A @ S3 )
=> ( S3
!= ( bot_bot @ ( set @ A ) ) ) ) ).
% infinite_imp_nonempty
thf(fact_576_finite_OemptyI,axiom,
! [A: $tType] : ( finite_finite @ A @ ( bot_bot @ ( set @ A ) ) ) ).
% finite.emptyI
thf(fact_577_rev__finite__subset,axiom,
! [A: $tType,B3: set @ A,A4: set @ A] :
( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( finite_finite @ A @ A4 ) ) ) ).
% rev_finite_subset
thf(fact_578_infinite__super,axiom,
! [A: $tType,S3: set @ A,T4: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ S3 @ T4 )
=> ( ~ ( finite_finite @ A @ S3 )
=> ~ ( finite_finite @ A @ T4 ) ) ) ).
% infinite_super
thf(fact_579_finite__subset,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( finite_finite @ A @ B3 )
=> ( finite_finite @ A @ A4 ) ) ) ).
% finite_subset
thf(fact_580_finite__nat__set__iff__bounded,axiom,
( ( finite_finite @ nat )
= ( ^ [N6: set @ nat] :
? [M2: nat] :
! [X2: nat] :
( ( member2 @ nat @ X2 @ N6 )
=> ( ord_less @ nat @ X2 @ M2 ) ) ) ) ).
% finite_nat_set_iff_bounded
thf(fact_581_infinite__nat__iff__unbounded,axiom,
! [S3: set @ nat] :
( ( ~ ( finite_finite @ nat @ S3 ) )
= ( ! [M2: nat] :
? [N: nat] :
( ( ord_less @ nat @ M2 @ N )
& ( member2 @ nat @ N @ S3 ) ) ) ) ).
% infinite_nat_iff_unbounded
thf(fact_582_arg__min__if__finite_I2_J,axiom,
! [B: $tType,A: $tType] :
( ( order @ B )
=> ! [S3: set @ A,F2: A > B] :
( ( finite_finite @ A @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ~ ? [X3: A] :
( ( member2 @ A @ X3 @ S3 )
& ( ord_less @ B @ ( F2 @ X3 ) @ ( F2 @ ( lattic7623131987881927897min_on @ A @ B @ F2 @ S3 ) ) ) ) ) ) ) ).
% arg_min_if_finite(2)
thf(fact_583_arg__min__least,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ! [S3: set @ A,Y: A,F2: A > B] :
( ( finite_finite @ A @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( member2 @ A @ Y @ S3 )
=> ( ord_less_eq @ B @ ( F2 @ ( lattic7623131987881927897min_on @ A @ B @ F2 @ S3 ) ) @ ( F2 @ Y ) ) ) ) ) ) ).
% arg_min_least
thf(fact_584_list__decode_Ocases,axiom,
! [X: nat] :
( ( X
!= ( zero_zero @ nat ) )
=> ~ ! [N3: nat] :
( X
!= ( suc @ N3 ) ) ) ).
% list_decode.cases
thf(fact_585_verit__sum__simplify,axiom,
! [A: $tType] :
( ( cancel1802427076303600483id_add @ A )
=> ! [A3: A] :
( ( plus_plus @ A @ A3 @ ( zero_zero @ A ) )
= A3 ) ) ).
% verit_sum_simplify
thf(fact_586_add__0__iff,axiom,
! [A: $tType] :
( ( semiri1453513574482234551roduct @ A )
=> ! [B2: A,A3: A] :
( ( B2
= ( plus_plus @ A @ B2 @ A3 ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% add_0_iff
thf(fact_587_field__lbound__gt__zero,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [D1: A,D22: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ D1 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ D22 )
=> ? [E: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ E )
& ( ord_less @ A @ E @ D1 )
& ( ord_less @ A @ E @ D22 ) ) ) ) ) ).
% field_lbound_gt_zero
thf(fact_588_less__numeral__extra_I3_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ~ ( ord_less @ A @ ( zero_zero @ A ) @ ( zero_zero @ A ) ) ) ).
% less_numeral_extra(3)
thf(fact_589_complete__interval,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [A3: A,B2: A,P2: A > $o] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( P2 @ A3 )
=> ( ~ ( P2 @ B2 )
=> ? [C4: A] :
( ( ord_less_eq @ A @ A3 @ C4 )
& ( ord_less_eq @ A @ C4 @ B2 )
& ! [X3: A] :
( ( ( ord_less_eq @ A @ A3 @ X3 )
& ( ord_less @ A @ X3 @ C4 ) )
=> ( P2 @ X3 ) )
& ! [D4: A] :
( ! [X5: A] :
( ( ( ord_less_eq @ A @ A3 @ X5 )
& ( ord_less @ A @ X5 @ D4 ) )
=> ( P2 @ X5 ) )
=> ( ord_less_eq @ A @ D4 @ C4 ) ) ) ) ) ) ) ).
% complete_interval
thf(fact_590_verit__comp__simplify1_I3_J,axiom,
! [B: $tType] :
( ( linorder @ B )
=> ! [B7: B,A8: B] :
( ( ~ ( ord_less_eq @ B @ B7 @ A8 ) )
= ( ord_less @ B @ A8 @ B7 ) ) ) ).
% verit_comp_simplify1(3)
thf(fact_591_pinf_I6_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ Z2 @ X3 )
=> ~ ( ord_less_eq @ A @ X3 @ T2 ) ) ) ).
% pinf(6)
thf(fact_592_less__by__empty,axiom,
! [A: $tType,A4: set @ ( product_prod @ A @ A ),B3: set @ ( product_prod @ A @ A )] :
( ( A4
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
=> ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ A4 @ B3 ) ) ).
% less_by_empty
thf(fact_593_verit__comp__simplify1_I2_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A3: A] : ( ord_less_eq @ A @ A3 @ A3 ) ) ).
% verit_comp_simplify1(2)
thf(fact_594_verit__la__disequality,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( A3 = B2 )
| ~ ( ord_less_eq @ A @ A3 @ B2 )
| ~ ( ord_less_eq @ A @ B2 @ A3 ) ) ) ).
% verit_la_disequality
thf(fact_595_minf_I11_J,axiom,
! [C: $tType,D: $tType] :
( ( ord @ C )
=> ! [F5: D] :
? [Z2: C] :
! [X3: C] :
( ( ord_less @ C @ X3 @ Z2 )
=> ( F5 = F5 ) ) ) ).
% minf(11)
thf(fact_596_minf_I7_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ X3 @ Z2 )
=> ~ ( ord_less @ A @ T2 @ X3 ) ) ) ).
% minf(7)
thf(fact_597_minf_I5_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ X3 @ Z2 )
=> ( ord_less @ A @ X3 @ T2 ) ) ) ).
% minf(5)
thf(fact_598_minf_I4_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ X3 @ Z2 )
=> ( X3 != T2 ) ) ) ).
% minf(4)
thf(fact_599_minf_I3_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ X3 @ Z2 )
=> ( X3 != T2 ) ) ) ).
% minf(3)
thf(fact_600_minf_I2_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [P2: A > $o,P5: A > $o,Q: A > $o,Q4: A > $o] :
( ? [Z4: A] :
! [X5: A] :
( ( ord_less @ A @ X5 @ Z4 )
=> ( ( P2 @ X5 )
= ( P5 @ X5 ) ) )
=> ( ? [Z4: A] :
! [X5: A] :
( ( ord_less @ A @ X5 @ Z4 )
=> ( ( Q @ X5 )
= ( Q4 @ X5 ) ) )
=> ? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ X3 @ Z2 )
=> ( ( ( P2 @ X3 )
| ( Q @ X3 ) )
= ( ( P5 @ X3 )
| ( Q4 @ X3 ) ) ) ) ) ) ) ).
% minf(2)
thf(fact_601_minf_I1_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [P2: A > $o,P5: A > $o,Q: A > $o,Q4: A > $o] :
( ? [Z4: A] :
! [X5: A] :
( ( ord_less @ A @ X5 @ Z4 )
=> ( ( P2 @ X5 )
= ( P5 @ X5 ) ) )
=> ( ? [Z4: A] :
! [X5: A] :
( ( ord_less @ A @ X5 @ Z4 )
=> ( ( Q @ X5 )
= ( Q4 @ X5 ) ) )
=> ? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ X3 @ Z2 )
=> ( ( ( P2 @ X3 )
& ( Q @ X3 ) )
= ( ( P5 @ X3 )
& ( Q4 @ X3 ) ) ) ) ) ) ) ).
% minf(1)
thf(fact_602_pinf_I11_J,axiom,
! [C: $tType,D: $tType] :
( ( ord @ C )
=> ! [F5: D] :
? [Z2: C] :
! [X3: C] :
( ( ord_less @ C @ Z2 @ X3 )
=> ( F5 = F5 ) ) ) ).
% pinf(11)
thf(fact_603_pinf_I7_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ Z2 @ X3 )
=> ( ord_less @ A @ T2 @ X3 ) ) ) ).
% pinf(7)
thf(fact_604_pinf_I5_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ Z2 @ X3 )
=> ~ ( ord_less @ A @ X3 @ T2 ) ) ) ).
% pinf(5)
thf(fact_605_pinf_I4_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ Z2 @ X3 )
=> ( X3 != T2 ) ) ) ).
% pinf(4)
thf(fact_606_pinf_I3_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ Z2 @ X3 )
=> ( X3 != T2 ) ) ) ).
% pinf(3)
thf(fact_607_pinf_I2_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [P2: A > $o,P5: A > $o,Q: A > $o,Q4: A > $o] :
( ? [Z4: A] :
! [X5: A] :
( ( ord_less @ A @ Z4 @ X5 )
=> ( ( P2 @ X5 )
= ( P5 @ X5 ) ) )
=> ( ? [Z4: A] :
! [X5: A] :
( ( ord_less @ A @ Z4 @ X5 )
=> ( ( Q @ X5 )
= ( Q4 @ X5 ) ) )
=> ? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ Z2 @ X3 )
=> ( ( ( P2 @ X3 )
| ( Q @ X3 ) )
= ( ( P5 @ X3 )
| ( Q4 @ X3 ) ) ) ) ) ) ) ).
% pinf(2)
thf(fact_608_pinf_I1_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [P2: A > $o,P5: A > $o,Q: A > $o,Q4: A > $o] :
( ? [Z4: A] :
! [X5: A] :
( ( ord_less @ A @ Z4 @ X5 )
=> ( ( P2 @ X5 )
= ( P5 @ X5 ) ) )
=> ( ? [Z4: A] :
! [X5: A] :
( ( ord_less @ A @ Z4 @ X5 )
=> ( ( Q @ X5 )
= ( Q4 @ X5 ) ) )
=> ? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ Z2 @ X3 )
=> ( ( ( P2 @ X3 )
& ( Q @ X3 ) )
= ( ( P5 @ X3 )
& ( Q4 @ X3 ) ) ) ) ) ) ) ).
% pinf(1)
thf(fact_609_verit__comp__simplify1_I1_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A3: A] :
~ ( ord_less @ A @ A3 @ A3 ) ) ).
% verit_comp_simplify1(1)
thf(fact_610_ex__gt__or__lt,axiom,
! [A: $tType] :
( ( condit5016429287641298734tinuum @ A )
=> ! [A3: A] :
? [B5: A] :
( ( ord_less @ A @ A3 @ B5 )
| ( ord_less @ A @ B5 @ A3 ) ) ) ).
% ex_gt_or_lt
thf(fact_611_is__num__normalize_I1_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( plus_plus @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) ) ) ) ).
% is_num_normalize(1)
thf(fact_612_prod__decode__aux_Ocases,axiom,
! [X: product_prod @ nat @ nat] :
~ ! [K3: nat,M3: nat] :
( X
!= ( product_Pair @ nat @ nat @ K3 @ M3 ) ) ).
% prod_decode_aux.cases
thf(fact_613_arg__min__if__finite_I1_J,axiom,
! [B: $tType,A: $tType] :
( ( order @ B )
=> ! [S3: set @ A,F2: A > B] :
( ( finite_finite @ A @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ A @ ( lattic7623131987881927897min_on @ A @ B @ F2 @ S3 ) @ S3 ) ) ) ) ).
% arg_min_if_finite(1)
thf(fact_614_le__numeral__extra_I3_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( zero_zero @ A ) ) ) ).
% le_numeral_extra(3)
thf(fact_615_minf_I8_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ X3 @ Z2 )
=> ~ ( ord_less_eq @ A @ T2 @ X3 ) ) ) ).
% minf(8)
thf(fact_616_minf_I6_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ X3 @ Z2 )
=> ( ord_less_eq @ A @ X3 @ T2 ) ) ) ).
% minf(6)
thf(fact_617_pinf_I8_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [T2: A] :
? [Z2: A] :
! [X3: A] :
( ( ord_less @ A @ Z2 @ X3 )
=> ( ord_less_eq @ A @ T2 @ X3 ) ) ) ).
% pinf(8)
thf(fact_618_triangle__Suc,axiom,
! [N2: nat] :
( ( nat_triangle @ ( suc @ N2 ) )
= ( plus_plus @ nat @ ( nat_triangle @ N2 ) @ ( suc @ N2 ) ) ) ).
% triangle_Suc
thf(fact_619_find__Some__iff2,axiom,
! [A: $tType,X: A,P2: A > $o,Xs: list @ A] :
( ( ( some @ A @ X )
= ( find @ A @ P2 @ Xs ) )
= ( ? [I5: nat] :
( ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs ) )
& ( P2 @ ( nth @ A @ Xs @ I5 ) )
& ( X
= ( nth @ A @ Xs @ I5 ) )
& ! [J3: nat] :
( ( ord_less @ nat @ J3 @ I5 )
=> ~ ( P2 @ ( nth @ A @ Xs @ J3 ) ) ) ) ) ) ).
% find_Some_iff2
thf(fact_620_find__Some__iff,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A,X: A] :
( ( ( find @ A @ P2 @ Xs )
= ( some @ A @ X ) )
= ( ? [I5: nat] :
( ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs ) )
& ( P2 @ ( nth @ A @ Xs @ I5 ) )
& ( X
= ( nth @ A @ Xs @ I5 ) )
& ! [J3: nat] :
( ( ord_less @ nat @ J3 @ I5 )
=> ~ ( P2 @ ( nth @ A @ Xs @ J3 ) ) ) ) ) ) ).
% find_Some_iff
thf(fact_621_nth__zip,axiom,
! [A: $tType,B: $tType,I: nat,Xs: list @ A,Ys: list @ B] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ord_less @ nat @ I @ ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( nth @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) @ I )
= ( product_Pair @ A @ B @ ( nth @ A @ Xs @ I ) @ ( nth @ B @ Ys @ I ) ) ) ) ) ).
% nth_zip
thf(fact_622__C7_C,axiom,
( ( mi != ma )
=> ! [I4: nat] :
( ( ord_less @ nat @ I4 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ m ) )
=> ( ( ( ( vEBT_VEBT_high @ ma @ na )
= I4 )
=> ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ treeList @ I4 ) @ ( vEBT_VEBT_low @ ma @ na ) ) )
& ! [Y3: nat] :
( ( ( ( vEBT_VEBT_high @ Y3 @ na )
= I4 )
& ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ treeList @ I4 ) @ ( vEBT_VEBT_low @ Y3 @ na ) ) )
=> ( ( ord_less @ nat @ mi @ Y3 )
& ( ord_less_eq @ nat @ Y3 @ ma ) ) ) ) ) ) ).
% "7"
thf(fact_623_count__notin,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( count_list @ A @ Xs @ X )
= ( zero_zero @ nat ) ) ) ).
% count_notin
thf(fact_624_listrel1__iff__update,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel1 @ A @ R2 ) )
= ( ? [Y2: A,N: nat] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ ( nth @ A @ Xs @ N ) @ Y2 ) @ R2 )
& ( ord_less @ nat @ N @ ( size_size @ ( list @ A ) @ Xs ) )
& ( Ys
= ( list_update @ A @ Xs @ N @ Y2 ) ) ) ) ) ).
% listrel1_iff_update
thf(fact_625_pair__lessI2,axiom,
! [A3: nat,B2: nat,S: nat,T2: nat] :
( ( ord_less_eq @ nat @ A3 @ B2 )
=> ( ( ord_less @ nat @ S @ T2 )
=> ( member2 @ ( product_prod @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) ) @ ( product_Pair @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ A3 @ S ) @ ( product_Pair @ nat @ nat @ B2 @ T2 ) ) @ fun_pair_less ) ) ) ).
% pair_lessI2
thf(fact_626_intind,axiom,
! [A: $tType,I: nat,N2: nat,P2: A > $o,X: A] :
( ( ord_less @ nat @ I @ N2 )
=> ( ( P2 @ X )
=> ( P2 @ ( nth @ A @ ( replicate @ A @ N2 @ X ) @ I ) ) ) ) ).
% intind
thf(fact_627_pair__less__iff1,axiom,
! [X: nat,Y: nat,Z: nat] :
( ( member2 @ ( product_prod @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) ) @ ( product_Pair @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ X @ Y ) @ ( product_Pair @ nat @ nat @ X @ Z ) ) @ fun_pair_less )
= ( ord_less @ nat @ Y @ Z ) ) ).
% pair_less_iff1
thf(fact_628__C2_C,axiom,
( ( size_size @ ( list @ vEBT_VEBT ) @ treeList )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ m ) ) ).
% "2"
thf(fact_629__C5_Oprems_C,axiom,
ord_less @ nat @ xa @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ deg ) ).
% "5.prems"
thf(fact_630__C5_Ohyps_C_I8_J,axiom,
ord_less @ nat @ ma @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ deg ) ).
% "5.hyps"(8)
thf(fact_631__092_060open_062i_A_060_A2_A_094_Am_092_060close_062,axiom,
ord_less @ nat @ i @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ m ) ).
% \<open>i < 2 ^ m\<close>
thf(fact_632__C5_OIH_C_I1_J,axiom,
! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ treeList ) )
=> ( ( vEBT_invar_vebt @ X3 @ na )
& ! [Xa: nat] :
( ( ord_less @ nat @ Xa @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ na ) )
=> ( vEBT_invar_vebt @ ( vEBT_vebt_insert @ X3 @ Xa ) @ na ) ) ) ) ).
% "5.IH"(1)
thf(fact_633__C4_C,axiom,
! [I4: nat] :
( ( ord_less @ nat @ I4 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ m ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ treeList @ I4 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ summary @ I4 ) ) ) ).
% "4"
thf(fact_634_high__bound__aux,axiom,
! [Ma: nat,N2: nat,M: nat] :
( ( ord_less @ nat @ Ma @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( plus_plus @ nat @ N2 @ M ) ) )
=> ( ord_less @ nat @ ( vEBT_VEBT_high @ Ma @ N2 ) @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) ) ) ).
% high_bound_aux
thf(fact_635_member__bound,axiom,
! [Tree: vEBT_VEBT,X: nat,N2: nat] :
( ( vEBT_vebt_member @ Tree @ X )
=> ( ( vEBT_invar_vebt @ Tree @ N2 )
=> ( ord_less @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ).
% member_bound
thf(fact_636_numeral__le__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [M: num,N2: num] :
( ( ord_less_eq @ A @ ( numeral_numeral @ A @ M ) @ ( numeral_numeral @ A @ N2 ) )
= ( ord_less_eq @ num @ M @ N2 ) ) ) ).
% numeral_le_iff
thf(fact_637_numeral__less__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [M: num,N2: num] :
( ( ord_less @ A @ ( numeral_numeral @ A @ M ) @ ( numeral_numeral @ A @ N2 ) )
= ( ord_less @ num @ M @ N2 ) ) ) ).
% numeral_less_iff
thf(fact_638_add__numeral__left,axiom,
! [A: $tType] :
( ( numeral @ A )
=> ! [V2: num,W2: num,Z: A] :
( ( plus_plus @ A @ ( numeral_numeral @ A @ V2 ) @ ( plus_plus @ A @ ( numeral_numeral @ A @ W2 ) @ Z ) )
= ( plus_plus @ A @ ( numeral_numeral @ A @ ( plus_plus @ num @ V2 @ W2 ) ) @ Z ) ) ) ).
% add_numeral_left
thf(fact_639_numeral__plus__numeral,axiom,
! [A: $tType] :
( ( numeral @ A )
=> ! [M: num,N2: num] :
( ( plus_plus @ A @ ( numeral_numeral @ A @ M ) @ ( numeral_numeral @ A @ N2 ) )
= ( numeral_numeral @ A @ ( plus_plus @ num @ M @ N2 ) ) ) ) ).
% numeral_plus_numeral
thf(fact_640_insert__simp__mima,axiom,
! [X: nat,Mi: nat,Ma: nat,Deg: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT] :
( ( ( X = Mi )
| ( X = Ma ) )
=> ( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg )
=> ( ( vEBT_vebt_insert @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ Deg @ TreeList2 @ Summary ) @ X )
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ Deg @ TreeList2 @ Summary ) ) ) ) ).
% insert_simp_mima
thf(fact_641_valid__insert__both__member__options__pres,axiom,
! [T2: vEBT_VEBT,N2: nat,X: nat,Y: nat] :
( ( vEBT_invar_vebt @ T2 @ N2 )
=> ( ( ord_less @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) )
=> ( ( ord_less @ nat @ Y @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) )
=> ( ( vEBT_V8194947554948674370ptions @ T2 @ X )
=> ( vEBT_V8194947554948674370ptions @ ( vEBT_vebt_insert @ T2 @ Y ) @ X ) ) ) ) ) ).
% valid_insert_both_member_options_pres
thf(fact_642_valid__insert__both__member__options__add,axiom,
! [T2: vEBT_VEBT,N2: nat,X: nat] :
( ( vEBT_invar_vebt @ T2 @ N2 )
=> ( ( ord_less @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) )
=> ( vEBT_V8194947554948674370ptions @ ( vEBT_vebt_insert @ T2 @ X ) @ X ) ) ) ).
% valid_insert_both_member_options_add
thf(fact_643_post__member__pre__member,axiom,
! [T2: vEBT_VEBT,N2: nat,X: nat,Y: nat] :
( ( vEBT_invar_vebt @ T2 @ N2 )
=> ( ( ord_less @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) )
=> ( ( ord_less @ nat @ Y @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) )
=> ( ( vEBT_vebt_member @ ( vEBT_vebt_insert @ T2 @ X ) @ Y )
=> ( ( vEBT_vebt_member @ T2 @ Y )
| ( X = Y ) ) ) ) ) ) ).
% post_member_pre_member
thf(fact_644_replicate__eq__replicate,axiom,
! [A: $tType,M: nat,X: A,N2: nat,Y: A] :
( ( ( replicate @ A @ M @ X )
= ( replicate @ A @ N2 @ Y ) )
= ( ( M = N2 )
& ( ( M
!= ( zero_zero @ nat ) )
=> ( X = Y ) ) ) ) ).
% replicate_eq_replicate
thf(fact_645_length__replicate,axiom,
! [A: $tType,N2: nat,X: A] :
( ( size_size @ ( list @ A ) @ ( replicate @ A @ N2 @ X ) )
= N2 ) ).
% length_replicate
thf(fact_646_triangle__0,axiom,
( ( nat_triangle @ ( zero_zero @ nat ) )
= ( zero_zero @ nat ) ) ).
% triangle_0
thf(fact_647_mi__ma__2__deg,axiom,
! [Mi: nat,Ma: nat,Deg: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,N2: nat] :
( ( vEBT_invar_vebt @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ Deg @ TreeList2 @ Summary ) @ N2 )
=> ( ( ord_less_eq @ nat @ Mi @ Ma )
& ( ord_less @ nat @ Ma @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg ) ) ) ) ).
% mi_ma_2_deg
thf(fact_648__C5_OIH_C_I2_J,axiom,
! [X: nat] :
( ( ord_less @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ m ) )
=> ( vEBT_invar_vebt @ ( vEBT_vebt_insert @ summary @ X ) @ m ) ) ).
% "5.IH"(2)
thf(fact_649_Suc__numeral,axiom,
! [N2: num] :
( ( suc @ ( numeral_numeral @ nat @ N2 ) )
= ( numeral_numeral @ nat @ ( plus_plus @ num @ N2 @ one2 ) ) ) ).
% Suc_numeral
thf(fact_650_max__number__of_I1_J,axiom,
! [A: $tType] :
( ( ( numeral @ A )
& ( ord @ A ) )
=> ! [U: num,V2: num] :
( ( ( ord_less_eq @ A @ ( numeral_numeral @ A @ U ) @ ( numeral_numeral @ A @ V2 ) )
=> ( ( ord_max @ A @ ( numeral_numeral @ A @ U ) @ ( numeral_numeral @ A @ V2 ) )
= ( numeral_numeral @ A @ V2 ) ) )
& ( ~ ( ord_less_eq @ A @ ( numeral_numeral @ A @ U ) @ ( numeral_numeral @ A @ V2 ) )
=> ( ( ord_max @ A @ ( numeral_numeral @ A @ U ) @ ( numeral_numeral @ A @ V2 ) )
= ( numeral_numeral @ A @ U ) ) ) ) ) ).
% max_number_of(1)
thf(fact_651_max__0__1_I3_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [X: num] :
( ( ord_max @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ A @ X ) )
= ( numeral_numeral @ A @ X ) ) ) ).
% max_0_1(3)
thf(fact_652_max__0__1_I4_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [X: num] :
( ( ord_max @ A @ ( numeral_numeral @ A @ X ) @ ( zero_zero @ A ) )
= ( numeral_numeral @ A @ X ) ) ) ).
% max_0_1(4)
thf(fact_653_myIHs,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ( member2 @ vEBT_VEBT @ X @ ( set2 @ vEBT_VEBT @ treeList ) )
=> ( ( vEBT_invar_vebt @ X @ na )
=> ( ( ord_less @ nat @ Xa2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ na ) )
=> ( vEBT_invar_vebt @ ( vEBT_vebt_insert @ X @ Xa2 ) @ na ) ) ) ) ).
% myIHs
thf(fact_654__C6_C,axiom,
( ( ord_less_eq @ nat @ mi @ ma )
& ( ord_less @ nat @ ma @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ deg ) ) ) ).
% "6"
thf(fact_655_Ball__set__replicate,axiom,
! [A: $tType,N2: nat,A3: A,P2: A > $o] :
( ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ ( replicate @ A @ N2 @ A3 ) ) )
=> ( P2 @ X2 ) ) )
= ( ( P2 @ A3 )
| ( N2
= ( zero_zero @ nat ) ) ) ) ).
% Ball_set_replicate
thf(fact_656_Bex__set__replicate,axiom,
! [A: $tType,N2: nat,A3: A,P2: A > $o] :
( ( ? [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ ( replicate @ A @ N2 @ A3 ) ) )
& ( P2 @ X2 ) ) )
= ( ( P2 @ A3 )
& ( N2
!= ( zero_zero @ nat ) ) ) ) ).
% Bex_set_replicate
thf(fact_657_in__set__replicate,axiom,
! [A: $tType,X: A,N2: nat,Y: A] :
( ( member2 @ A @ X @ ( set2 @ A @ ( replicate @ A @ N2 @ Y ) ) )
= ( ( X = Y )
& ( N2
!= ( zero_zero @ nat ) ) ) ) ).
% in_set_replicate
thf(fact_658_nth__replicate,axiom,
! [A: $tType,I: nat,N2: nat,X: A] :
( ( ord_less @ nat @ I @ N2 )
=> ( ( nth @ A @ ( replicate @ A @ N2 @ X ) @ I )
= X ) ) ).
% nth_replicate
thf(fact_659_highlowprop,axiom,
( ( ord_less @ nat @ ( vEBT_VEBT_high @ xa @ na ) @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ m ) )
& ( ord_less @ nat @ ( vEBT_VEBT_low @ xa @ na ) @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ na ) ) ) ).
% highlowprop
thf(fact_660_add__2__eq__Suc,axiom,
! [N2: nat] :
( ( plus_plus @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
= ( suc @ ( suc @ N2 ) ) ) ).
% add_2_eq_Suc
thf(fact_661_add__2__eq__Suc_H,axiom,
! [N2: nat] :
( ( plus_plus @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( suc @ ( suc @ N2 ) ) ) ).
% add_2_eq_Suc'
thf(fact_662_numeral__Bit0,axiom,
! [A: $tType] :
( ( numeral @ A )
=> ! [N2: num] :
( ( numeral_numeral @ A @ ( bit0 @ N2 ) )
= ( plus_plus @ A @ ( numeral_numeral @ A @ N2 ) @ ( numeral_numeral @ A @ N2 ) ) ) ) ).
% numeral_Bit0
thf(fact_663_numeral__2__eq__2,axiom,
( ( numeral_numeral @ nat @ ( bit0 @ one2 ) )
= ( suc @ ( suc @ ( zero_zero @ nat ) ) ) ) ).
% numeral_2_eq_2
thf(fact_664_VEBT__internal_Oexp__split__high__low_I1_J,axiom,
! [X: nat,N2: nat,M: nat] :
( ( ord_less @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( plus_plus @ nat @ N2 @ M ) ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ N2 ) @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) ) ) ) ) ).
% VEBT_internal.exp_split_high_low(1)
thf(fact_665_VEBT__internal_Oexp__split__high__low_I2_J,axiom,
! [X: nat,N2: nat,M: nat] :
( ( ord_less @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( plus_plus @ nat @ N2 @ M ) ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ord_less @ nat @ ( vEBT_VEBT_low @ X @ N2 ) @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ) ).
% VEBT_internal.exp_split_high_low(2)
thf(fact_666_less__2__cases,axiom,
! [N2: nat] :
( ( ord_less @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
=> ( ( N2
= ( zero_zero @ nat ) )
| ( N2
= ( suc @ ( zero_zero @ nat ) ) ) ) ) ).
% less_2_cases
thf(fact_667_less__2__cases__iff,axiom,
! [N2: nat] :
( ( ord_less @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( ( N2
= ( zero_zero @ nat ) )
| ( N2
= ( suc @ ( zero_zero @ nat ) ) ) ) ) ).
% less_2_cases_iff
thf(fact_668_numeral__1__eq__Suc__0,axiom,
( ( numeral_numeral @ nat @ one2 )
= ( suc @ ( zero_zero @ nat ) ) ) ).
% numeral_1_eq_Suc_0
thf(fact_669_Suc__nat__number__of__add,axiom,
! [V2: num,N2: nat] :
( ( suc @ ( plus_plus @ nat @ ( numeral_numeral @ nat @ V2 ) @ N2 ) )
= ( plus_plus @ nat @ ( numeral_numeral @ nat @ ( plus_plus @ num @ V2 @ one2 ) ) @ N2 ) ) ).
% Suc_nat_number_of_add
thf(fact_670_zero__neq__numeral,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ! [N2: num] :
( ( zero_zero @ A )
!= ( numeral_numeral @ A @ N2 ) ) ) ).
% zero_neq_numeral
thf(fact_671_num_Osize_I4_J,axiom,
( ( size_size @ num @ one2 )
= ( zero_zero @ nat ) ) ).
% num.size(4)
thf(fact_672_listrel1__eq__len,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel1 @ A @ R2 ) )
=> ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ A ) @ Ys ) ) ) ).
% listrel1_eq_len
thf(fact_673_listrel1__mono,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),S: set @ ( product_prod @ A @ A )] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R2 @ S )
=> ( ord_less_eq @ ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) @ ( listrel1 @ A @ R2 ) @ ( listrel1 @ A @ S ) ) ) ).
% listrel1_mono
thf(fact_674_find__cong,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,P2: A > $o,Q: A > $o] :
( ( Xs = Ys )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Ys ) )
=> ( ( P2 @ X5 )
= ( Q @ X5 ) ) )
=> ( ( find @ A @ P2 @ Xs )
= ( find @ A @ Q @ Ys ) ) ) ) ).
% find_cong
thf(fact_675_set__zip__rightD,axiom,
! [A: $tType,B: $tType,X: A,Y: B,Xs: list @ A,Ys: list @ B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y ) @ ( set2 @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) ) )
=> ( member2 @ B @ Y @ ( set2 @ B @ Ys ) ) ) ).
% set_zip_rightD
thf(fact_676_set__zip__leftD,axiom,
! [B: $tType,A: $tType,X: A,Y: B,Xs: list @ A,Ys: list @ B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y ) @ ( set2 @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) ) )
=> ( member2 @ A @ X @ ( set2 @ A @ Xs ) ) ) ).
% set_zip_leftD
thf(fact_677_in__set__zipE,axiom,
! [A: $tType,B: $tType,X: A,Y: B,Xs: list @ A,Ys: list @ B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y ) @ ( set2 @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) ) )
=> ~ ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ~ ( member2 @ B @ Y @ ( set2 @ B @ Ys ) ) ) ) ).
% in_set_zipE
thf(fact_678_zip__same,axiom,
! [A: $tType,A3: A,B2: A,Xs: list @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( set2 @ ( product_prod @ A @ A ) @ ( zip @ A @ A @ Xs @ Xs ) ) )
= ( ( member2 @ A @ A3 @ ( set2 @ A @ Xs ) )
& ( A3 = B2 ) ) ) ).
% zip_same
thf(fact_679_zip__update,axiom,
! [A: $tType,B: $tType,Xs: list @ A,I: nat,X: A,Ys: list @ B,Y: B] :
( ( zip @ A @ B @ ( list_update @ A @ Xs @ I @ X ) @ ( list_update @ B @ Ys @ I @ Y ) )
= ( list_update @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) @ I @ ( product_Pair @ A @ B @ X @ Y ) ) ) ).
% zip_update
thf(fact_680_not__numeral__le__zero,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [N2: num] :
~ ( ord_less_eq @ A @ ( numeral_numeral @ A @ N2 ) @ ( zero_zero @ A ) ) ) ).
% not_numeral_le_zero
thf(fact_681_zero__le__numeral,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [N2: num] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ A @ N2 ) ) ) ).
% zero_le_numeral
thf(fact_682_not__numeral__less__zero,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [N2: num] :
~ ( ord_less @ A @ ( numeral_numeral @ A @ N2 ) @ ( zero_zero @ A ) ) ) ).
% not_numeral_less_zero
thf(fact_683_zero__less__numeral,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [N2: num] : ( ord_less @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ A @ N2 ) ) ) ).
% zero_less_numeral
thf(fact_684_replicate__length__same,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( X5 = X ) )
=> ( ( replicate @ A @ ( size_size @ ( list @ A ) @ Xs ) @ X )
= Xs ) ) ).
% replicate_length_same
thf(fact_685_replicate__eqI,axiom,
! [A: $tType,Xs: list @ A,N2: nat,X: A] :
( ( ( size_size @ ( list @ A ) @ Xs )
= N2 )
=> ( ! [Y4: A] :
( ( member2 @ A @ Y4 @ ( set2 @ A @ Xs ) )
=> ( Y4 = X ) )
=> ( Xs
= ( replicate @ A @ N2 @ X ) ) ) ) ).
% replicate_eqI
thf(fact_686_in__set__impl__in__set__zip1,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,X: A] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ~ ! [Y4: B] :
~ ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y4 ) @ ( set2 @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) ) ) ) ) ).
% in_set_impl_in_set_zip1
thf(fact_687_in__set__impl__in__set__zip2,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,Y: B] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( member2 @ B @ Y @ ( set2 @ B @ Ys ) )
=> ~ ! [X5: A] :
~ ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X5 @ Y ) @ ( set2 @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) ) ) ) ) ).
% in_set_impl_in_set_zip2
thf(fact_688_invar__vebt_Ointros_I4_J,axiom,
! [TreeList2: list @ vEBT_VEBT,N2: nat,Summary: vEBT_VEBT,M: nat,Deg: nat,Mi: nat,Ma: nat] :
( ! [X5: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X5 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ( vEBT_invar_vebt @ X5 @ N2 ) )
=> ( ( vEBT_invar_vebt @ Summary @ M )
=> ( ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) )
=> ( ( M = N2 )
=> ( ( Deg
= ( plus_plus @ nat @ N2 @ M ) )
=> ( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList2 @ I3 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary @ I3 ) ) )
=> ( ( ( Mi = Ma )
=> ! [X5: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X5 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ~ ? [X_12: nat] : ( vEBT_V8194947554948674370ptions @ X5 @ X_12 ) ) )
=> ( ( ord_less_eq @ nat @ Mi @ Ma )
=> ( ( ord_less @ nat @ Ma @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg ) )
=> ( ( ( Mi != Ma )
=> ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) )
=> ( ( ( ( vEBT_VEBT_high @ Ma @ N2 )
= I3 )
=> ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList2 @ I3 ) @ ( vEBT_VEBT_low @ Ma @ N2 ) ) )
& ! [X5: nat] :
( ( ( ( vEBT_VEBT_high @ X5 @ N2 )
= I3 )
& ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList2 @ I3 ) @ ( vEBT_VEBT_low @ X5 @ N2 ) ) )
=> ( ( ord_less @ nat @ Mi @ X5 )
& ( ord_less_eq @ nat @ X5 @ Ma ) ) ) ) ) )
=> ( vEBT_invar_vebt @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ Deg @ TreeList2 @ Summary ) @ Deg ) ) ) ) ) ) ) ) ) ) ) ).
% invar_vebt.intros(4)
thf(fact_689_num_Osize_I5_J,axiom,
! [X22: num] :
( ( size_size @ num @ ( bit0 @ X22 ) )
= ( plus_plus @ nat @ ( size_size @ num @ X22 ) @ ( suc @ ( zero_zero @ nat ) ) ) ) ).
% num.size(5)
thf(fact_690_invar__vebt_Ointros_I5_J,axiom,
! [TreeList2: list @ vEBT_VEBT,N2: nat,Summary: vEBT_VEBT,M: nat,Deg: nat,Mi: nat,Ma: nat] :
( ! [X5: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X5 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ( vEBT_invar_vebt @ X5 @ N2 ) )
=> ( ( vEBT_invar_vebt @ Summary @ M )
=> ( ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) )
=> ( ( M
= ( suc @ N2 ) )
=> ( ( Deg
= ( plus_plus @ nat @ N2 @ M ) )
=> ( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList2 @ I3 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary @ I3 ) ) )
=> ( ( ( Mi = Ma )
=> ! [X5: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X5 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ~ ? [X_12: nat] : ( vEBT_V8194947554948674370ptions @ X5 @ X_12 ) ) )
=> ( ( ord_less_eq @ nat @ Mi @ Ma )
=> ( ( ord_less @ nat @ Ma @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg ) )
=> ( ( ( Mi != Ma )
=> ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) )
=> ( ( ( ( vEBT_VEBT_high @ Ma @ N2 )
= I3 )
=> ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList2 @ I3 ) @ ( vEBT_VEBT_low @ Ma @ N2 ) ) )
& ! [X5: nat] :
( ( ( ( vEBT_VEBT_high @ X5 @ N2 )
= I3 )
& ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList2 @ I3 ) @ ( vEBT_VEBT_low @ X5 @ N2 ) ) )
=> ( ( ord_less @ nat @ Mi @ X5 )
& ( ord_less_eq @ nat @ X5 @ Ma ) ) ) ) ) )
=> ( vEBT_invar_vebt @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ Deg @ TreeList2 @ Summary ) @ Deg ) ) ) ) ) ) ) ) ) ) ) ).
% invar_vebt.intros(5)
thf(fact_691_pair__lessI1,axiom,
! [A3: nat,B2: nat,S: nat,T2: nat] :
( ( ord_less @ nat @ A3 @ B2 )
=> ( member2 @ ( product_prod @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) ) @ ( product_Pair @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ A3 @ S ) @ ( product_Pair @ nat @ nat @ B2 @ T2 ) ) @ fun_pair_less ) ) ).
% pair_lessI1
thf(fact_692_count__le__length,axiom,
! [A: $tType,Xs: list @ A,X: A] : ( ord_less_eq @ nat @ ( count_list @ A @ Xs @ X ) @ ( size_size @ ( list @ A ) @ Xs ) ) ).
% count_le_length
thf(fact_693_sum__power2__eq__zero__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] :
( ( ( plus_plus @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
= ( zero_zero @ A ) )
= ( ( X
= ( zero_zero @ A ) )
& ( Y
= ( zero_zero @ A ) ) ) ) ) ).
% sum_power2_eq_zero_iff
thf(fact_694_zero__less__power2,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
= ( A3
!= ( zero_zero @ A ) ) ) ) ).
% zero_less_power2
thf(fact_695_power2__less__eq__zero__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( power_power @ A @ A3 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% power2_less_eq_zero_iff
thf(fact_696_power2__eq__iff__nonneg,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( ( ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
= ( X = Y ) ) ) ) ) ).
% power2_eq_iff_nonneg
thf(fact_697_zero__eq__power2,axiom,
! [A: $tType] :
( ( semiri2026040879449505780visors @ A )
=> ! [A3: A] :
( ( ( power_power @ A @ A3 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% zero_eq_power2
thf(fact_698_power__mono__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,B2: A,N2: nat] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ A @ ( power_power @ A @ A3 @ N2 ) @ ( power_power @ A @ B2 @ N2 ) )
= ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ) ) ).
% power_mono_iff
thf(fact_699_insert__simp__excp,axiom,
! [Mi: nat,Deg: nat,TreeList2: list @ vEBT_VEBT,X: nat,Ma: nat,Summary: vEBT_VEBT] :
( ( ord_less @ nat @ ( vEBT_VEBT_high @ Mi @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) )
=> ( ( ord_less @ nat @ X @ Mi )
=> ( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg )
=> ( ( X != Ma )
=> ( ( vEBT_vebt_insert @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ Deg @ TreeList2 @ Summary ) @ X )
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ X @ ( ord_max @ nat @ Mi @ Ma ) ) ) @ Deg @ ( list_update @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ Mi @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ Mi @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Mi @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) @ ( if @ vEBT_VEBT @ ( vEBT_VEBT_minNull @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ Mi @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) @ ( vEBT_vebt_insert @ Summary @ ( vEBT_VEBT_high @ Mi @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ Summary ) ) ) ) ) ) ) ).
% insert_simp_excp
thf(fact_700_insert__simp__norm,axiom,
! [X: nat,Deg: nat,TreeList2: list @ vEBT_VEBT,Mi: nat,Ma: nat,Summary: vEBT_VEBT] :
( ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) )
=> ( ( ord_less @ nat @ Mi @ X )
=> ( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg )
=> ( ( X != Ma )
=> ( ( vEBT_vebt_insert @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ Deg @ TreeList2 @ Summary ) @ X )
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ ( ord_max @ nat @ X @ Ma ) ) ) @ Deg @ ( list_update @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) @ ( if @ vEBT_VEBT @ ( vEBT_VEBT_minNull @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) @ ( vEBT_vebt_insert @ Summary @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ Summary ) ) ) ) ) ) ) ).
% insert_simp_norm
thf(fact_701_power__eq__0__iff,axiom,
! [A: $tType] :
( ( semiri2026040879449505780visors @ A )
=> ! [A3: A,N2: nat] :
( ( ( power_power @ A @ A3 @ N2 )
= ( zero_zero @ A ) )
= ( ( A3
= ( zero_zero @ A ) )
& ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% power_eq_0_iff
thf(fact_702_member__inv,axiom,
! [Mi: nat,Ma: nat,Deg: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,X: nat] :
( ( vEBT_vebt_member @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ Deg @ TreeList2 @ Summary ) @ X )
=> ( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg )
& ( ( X = Mi )
| ( X = Ma )
| ( ( ord_less @ nat @ X @ Ma )
& ( ord_less @ nat @ Mi @ X )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) )
& ( vEBT_vebt_member @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ).
% member_inv
thf(fact_703_pow__sum,axiom,
! [A3: nat,B2: nat] :
( ( divide_divide @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( plus_plus @ nat @ A3 @ B2 ) ) @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ A3 ) )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ B2 ) ) ).
% pow_sum
thf(fact_704_high__def,axiom,
( vEBT_VEBT_high
= ( ^ [X2: nat,N: nat] : ( divide_divide @ nat @ X2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) ) ) ) ).
% high_def
thf(fact_705__C9_C,axiom,
( ( divide_divide @ nat @ deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= na ) ).
% "9"
thf(fact_706_div__0,axiom,
! [A: $tType] :
( ( semidom_divide @ A )
=> ! [A3: A] :
( ( divide_divide @ A @ ( zero_zero @ A ) @ A3 )
= ( zero_zero @ A ) ) ) ).
% div_0
thf(fact_707_divide__eq__0__iff,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A] :
( ( ( divide_divide @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
= ( ( A3
= ( zero_zero @ A ) )
| ( B2
= ( zero_zero @ A ) ) ) ) ) ).
% divide_eq_0_iff
thf(fact_708_div__by__0,axiom,
! [A: $tType] :
( ( semidom_divide @ A )
=> ! [A3: A] :
( ( divide_divide @ A @ A3 @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% div_by_0
thf(fact_709_divide__cancel__left,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ( divide_divide @ A @ C2 @ A3 )
= ( divide_divide @ A @ C2 @ B2 ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( A3 = B2 ) ) ) ) ).
% divide_cancel_left
thf(fact_710_divide__cancel__right,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ( divide_divide @ A @ A3 @ C2 )
= ( divide_divide @ A @ B2 @ C2 ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( A3 = B2 ) ) ) ) ).
% divide_cancel_right
thf(fact_711_division__ring__divide__zero,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( divide_divide @ A @ A3 @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% division_ring_divide_zero
thf(fact_712_power__0__Suc,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [N2: nat] :
( ( power_power @ A @ ( zero_zero @ A ) @ ( suc @ N2 ) )
= ( zero_zero @ A ) ) ) ).
% power_0_Suc
thf(fact_713_power__zero__numeral,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [K: num] :
( ( power_power @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ nat @ K ) )
= ( zero_zero @ A ) ) ) ).
% power_zero_numeral
thf(fact_714_power__Suc0__right,axiom,
! [A: $tType] :
( ( monoid_mult @ A )
=> ! [A3: A] :
( ( power_power @ A @ A3 @ ( suc @ ( zero_zero @ nat ) ) )
= A3 ) ) ).
% power_Suc0_right
thf(fact_715_power__Suc__0,axiom,
! [N2: nat] :
( ( power_power @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
= ( suc @ ( zero_zero @ nat ) ) ) ).
% power_Suc_0
thf(fact_716_nat__power__eq__Suc__0__iff,axiom,
! [X: nat,M: nat] :
( ( ( power_power @ nat @ X @ M )
= ( suc @ ( zero_zero @ nat ) ) )
= ( ( M
= ( zero_zero @ nat ) )
| ( X
= ( suc @ ( zero_zero @ nat ) ) ) ) ) ).
% nat_power_eq_Suc_0_iff
thf(fact_717_nat__zero__less__power__iff,axiom,
! [X: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( power_power @ nat @ X @ N2 ) )
= ( ( ord_less @ nat @ ( zero_zero @ nat ) @ X )
| ( N2
= ( zero_zero @ nat ) ) ) ) ).
% nat_zero_less_power_iff
thf(fact_718_both__member__options__ding,axiom,
! [Info: option @ ( product_prod @ nat @ nat ),Deg: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,N2: nat,X: nat] :
( ( vEBT_invar_vebt @ ( vEBT_Node @ Info @ Deg @ TreeList2 @ Summary ) @ N2 )
=> ( ( ord_less @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg ) )
=> ( ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
=> ( vEBT_V8194947554948674370ptions @ ( vEBT_Node @ Info @ Deg @ TreeList2 @ Summary ) @ X ) ) ) ) ).
% both_member_options_ding
thf(fact_719_add__divide__distrib,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( divide_divide @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) ) ) ) ).
% add_divide_distrib
thf(fact_720_divide__le__0__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( divide_divide @ A @ A3 @ B2 ) @ ( zero_zero @ A ) )
= ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) ) )
| ( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 ) ) ) ) ) ).
% divide_le_0_iff
thf(fact_721_divide__right__mono,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) ) ) ) ) ).
% divide_right_mono
thf(fact_722_zero__le__divide__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ A3 @ B2 ) )
= ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 ) )
| ( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) ) ) ) ) ) ).
% zero_le_divide_iff
thf(fact_723_divide__nonneg__nonneg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ X @ Y ) ) ) ) ) ).
% divide_nonneg_nonneg
thf(fact_724_divide__nonneg__nonpos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less_eq @ A @ Y @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( divide_divide @ A @ X @ Y ) @ ( zero_zero @ A ) ) ) ) ) ).
% divide_nonneg_nonpos
thf(fact_725_divide__nonpos__nonneg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( ord_less_eq @ A @ ( divide_divide @ A @ X @ Y ) @ ( zero_zero @ A ) ) ) ) ) ).
% divide_nonpos_nonneg
thf(fact_726_divide__nonpos__nonpos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ Y @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ X @ Y ) ) ) ) ) ).
% divide_nonpos_nonpos
thf(fact_727_divide__right__mono__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( divide_divide @ A @ B2 @ C2 ) @ ( divide_divide @ A @ A3 @ C2 ) ) ) ) ) ).
% divide_right_mono_neg
thf(fact_728_divide__neg__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ Y @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ X @ Y ) ) ) ) ) ).
% divide_neg_neg
thf(fact_729_divide__neg__pos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ Y )
=> ( ord_less @ A @ ( divide_divide @ A @ X @ Y ) @ ( zero_zero @ A ) ) ) ) ) ).
% divide_neg_pos
thf(fact_730_divide__pos__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less @ A @ Y @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( divide_divide @ A @ X @ Y ) @ ( zero_zero @ A ) ) ) ) ) ).
% divide_pos_neg
thf(fact_731_divide__pos__pos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ Y )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ X @ Y ) ) ) ) ) ).
% divide_pos_pos
thf(fact_732_divide__less__0__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( divide_divide @ A @ A3 @ B2 ) @ ( zero_zero @ A ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less @ A @ B2 @ ( zero_zero @ A ) ) )
| ( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less @ A @ ( zero_zero @ A ) @ B2 ) ) ) ) ) ).
% divide_less_0_iff
thf(fact_733_divide__less__cancel,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ A3 @ B2 ) )
& ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ B2 @ A3 ) )
& ( C2
!= ( zero_zero @ A ) ) ) ) ) ).
% divide_less_cancel
thf(fact_734_zero__less__divide__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ A3 @ B2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less @ A @ ( zero_zero @ A ) @ B2 ) )
| ( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less @ A @ B2 @ ( zero_zero @ A ) ) ) ) ) ) ).
% zero_less_divide_iff
thf(fact_735_divide__strict__right__mono,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) ) ) ) ) ).
% divide_strict_right_mono
thf(fact_736_divide__strict__right__mono__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) ) ) ) ) ).
% divide_strict_right_mono_neg
thf(fact_737_frac__le,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [Y: A,X: A,W2: A,Z: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ W2 )
=> ( ( ord_less_eq @ A @ W2 @ Z )
=> ( ord_less_eq @ A @ ( divide_divide @ A @ X @ Z ) @ ( divide_divide @ A @ Y @ W2 ) ) ) ) ) ) ) ).
% frac_le
thf(fact_738_frac__less,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A,W2: A,Z: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less @ A @ X @ Y )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ W2 )
=> ( ( ord_less_eq @ A @ W2 @ Z )
=> ( ord_less @ A @ ( divide_divide @ A @ X @ Z ) @ ( divide_divide @ A @ Y @ W2 ) ) ) ) ) ) ) ).
% frac_less
thf(fact_739_frac__less2,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A,W2: A,Z: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ W2 )
=> ( ( ord_less @ A @ W2 @ Z )
=> ( ord_less @ A @ ( divide_divide @ A @ X @ Z ) @ ( divide_divide @ A @ Y @ W2 ) ) ) ) ) ) ) ).
% frac_less2
thf(fact_740_divide__le__cancel,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less_eq @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ A3 @ B2 ) )
& ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ) ).
% divide_le_cancel
thf(fact_741_divide__nonneg__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less @ A @ Y @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( divide_divide @ A @ X @ Y ) @ ( zero_zero @ A ) ) ) ) ) ).
% divide_nonneg_neg
thf(fact_742_divide__nonneg__pos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ Y )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ X @ Y ) ) ) ) ) ).
% divide_nonneg_pos
thf(fact_743_divide__nonpos__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ Y @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ X @ Y ) ) ) ) ) ).
% divide_nonpos_neg
thf(fact_744_divide__nonpos__pos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ Y )
=> ( ord_less_eq @ A @ ( divide_divide @ A @ X @ Y ) @ ( zero_zero @ A ) ) ) ) ) ).
% divide_nonpos_pos
thf(fact_745_field__sum__of__halves,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A] :
( ( plus_plus @ A @ ( divide_divide @ A @ X @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ A @ X @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) )
= X ) ) ).
% field_sum_of_halves
thf(fact_746_half__gt__zero__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% half_gt_zero_iff
thf(fact_747_half__gt__zero,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% half_gt_zero
thf(fact_748_field__less__half__sum,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( ord_less @ A @ X @ ( divide_divide @ A @ ( plus_plus @ A @ X @ Y ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% field_less_half_sum
thf(fact_749_power__not__zero,axiom,
! [A: $tType] :
( ( semiri2026040879449505780visors @ A )
=> ! [A3: A,N2: nat] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( power_power @ A @ A3 @ N2 )
!= ( zero_zero @ A ) ) ) ) ).
% power_not_zero
thf(fact_750_power__mono,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,B2: A,N2: nat] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less_eq @ A @ ( power_power @ A @ A3 @ N2 ) @ ( power_power @ A @ B2 @ N2 ) ) ) ) ) ).
% power_mono
thf(fact_751_zero__le__power,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ N2 ) ) ) ) ).
% zero_le_power
thf(fact_752_zero__less__power,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ N2 ) ) ) ) ).
% zero_less_power
thf(fact_753_nat__power__less__imp__less,axiom,
! [I: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ I )
=> ( ( ord_less @ nat @ ( power_power @ nat @ I @ M ) @ ( power_power @ nat @ I @ N2 ) )
=> ( ord_less @ nat @ M @ N2 ) ) ) ).
% nat_power_less_imp_less
thf(fact_754_power__less__imp__less__base,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat,B2: A] :
( ( ord_less @ A @ ( power_power @ A @ A3 @ N2 ) @ ( power_power @ A @ B2 @ N2 ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less @ A @ A3 @ B2 ) ) ) ) ).
% power_less_imp_less_base
thf(fact_755_power__inject__base,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat,B2: A] :
( ( ( power_power @ A @ A3 @ ( suc @ N2 ) )
= ( power_power @ A @ B2 @ ( suc @ N2 ) ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( A3 = B2 ) ) ) ) ) ).
% power_inject_base
thf(fact_756_power__le__imp__le__base,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat,B2: A] :
( ( ord_less_eq @ A @ ( power_power @ A @ A3 @ ( suc @ N2 ) ) @ ( power_power @ A @ B2 @ ( suc @ N2 ) ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ).
% power_le_imp_le_base
thf(fact_757_zero__power,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( power_power @ A @ ( zero_zero @ A ) @ N2 )
= ( zero_zero @ A ) ) ) ) ).
% zero_power
thf(fact_758_power__gt__expt,axiom,
! [N2: nat,K: nat] :
( ( ord_less @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
=> ( ord_less @ nat @ K @ ( power_power @ nat @ N2 @ K ) ) ) ).
% power_gt_expt
thf(fact_759_nat__one__le__power,axiom,
! [I: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( suc @ ( zero_zero @ nat ) ) @ I )
=> ( ord_less_eq @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( power_power @ nat @ I @ N2 ) ) ) ).
% nat_one_le_power
thf(fact_760_power__eq__iff__eq__base,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat,A3: A,B2: A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ( power_power @ A @ A3 @ N2 )
= ( power_power @ A @ B2 @ N2 ) )
= ( A3 = B2 ) ) ) ) ) ) ).
% power_eq_iff_eq_base
thf(fact_761_power__eq__imp__eq__base,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat,B2: A] :
( ( ( power_power @ A @ A3 @ N2 )
= ( power_power @ A @ B2 @ N2 ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( A3 = B2 ) ) ) ) ) ) ).
% power_eq_imp_eq_base
thf(fact_762_zero__power2,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( power_power @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( zero_zero @ A ) ) ) ).
% zero_power2
thf(fact_763_less__exp,axiom,
! [N2: nat] : ( ord_less @ nat @ N2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ).
% less_exp
thf(fact_764_power2__nat__le__imp__le,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( power_power @ nat @ M @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ N2 )
=> ( ord_less_eq @ nat @ M @ N2 ) ) ).
% power2_nat_le_imp_le
thf(fact_765_power2__nat__le__eq__le,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( power_power @ nat @ M @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ).
% power2_nat_le_eq_le
thf(fact_766_self__le__ge2__pow,axiom,
! [K: nat,M: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ K )
=> ( ord_less_eq @ nat @ M @ ( power_power @ nat @ K @ M ) ) ) ).
% self_le_ge2_pow
thf(fact_767_power2__le__imp__le,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( ord_less_eq @ A @ X @ Y ) ) ) ) ).
% power2_le_imp_le
thf(fact_768_power2__eq__imp__eq,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [X: A,Y: A] :
( ( ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( X = Y ) ) ) ) ) ).
% power2_eq_imp_eq
thf(fact_769_zero__le__power2,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ).
% zero_le_power2
thf(fact_770_power__strict__mono,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,B2: A,N2: nat] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less @ A @ ( power_power @ A @ A3 @ N2 ) @ ( power_power @ A @ B2 @ N2 ) ) ) ) ) ) ).
% power_strict_mono
thf(fact_771_power2__less__0,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
~ ( ord_less @ A @ ( power_power @ A @ A3 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( zero_zero @ A ) ) ) ).
% power2_less_0
thf(fact_772_power2__less__imp__less,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( ord_less @ A @ X @ Y ) ) ) ) ).
% power2_less_imp_less
thf(fact_773_sum__power2__ge__zero,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ).
% sum_power2_ge_zero
thf(fact_774_sum__power2__le__zero__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( zero_zero @ A ) )
= ( ( X
= ( zero_zero @ A ) )
& ( Y
= ( zero_zero @ A ) ) ) ) ) ).
% sum_power2_le_zero_iff
thf(fact_775_not__sum__power2__lt__zero,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] :
~ ( ord_less @ A @ ( plus_plus @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( zero_zero @ A ) ) ) ).
% not_sum_power2_lt_zero
thf(fact_776_sum__power2__gt__zero__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
= ( ( X
!= ( zero_zero @ A ) )
| ( Y
!= ( zero_zero @ A ) ) ) ) ) ).
% sum_power2_gt_zero_iff
thf(fact_777_both__member__options__from__chilf__to__complete__tree,axiom,
! [X: nat,Deg: nat,TreeList2: list @ vEBT_VEBT,Mi: nat,Ma: nat,Summary: vEBT_VEBT] :
( ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) )
=> ( ( ord_less_eq @ nat @ ( one_one @ nat ) @ Deg )
=> ( ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
=> ( vEBT_V8194947554948674370ptions @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ Deg @ TreeList2 @ Summary ) @ X ) ) ) ) ).
% both_member_options_from_chilf_to_complete_tree
thf(fact_778_add__self__div__2,axiom,
! [M: nat] :
( ( divide_divide @ nat @ ( plus_plus @ nat @ M @ M ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= M ) ).
% add_self_div_2
thf(fact_779_div2__Suc__Suc,axiom,
! [M: nat] :
( ( divide_divide @ nat @ ( suc @ ( suc @ M ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( suc @ ( divide_divide @ nat @ M @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ).
% div2_Suc_Suc
thf(fact_780_both__member__options__from__complete__tree__to__child,axiom,
! [Deg: nat,Mi: nat,Ma: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,X: nat] :
( ( ord_less_eq @ nat @ ( one_one @ nat ) @ Deg )
=> ( ( vEBT_V8194947554948674370ptions @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ Deg @ TreeList2 @ Summary ) @ X )
=> ( ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ X @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
| ( X = Mi )
| ( X = Ma ) ) ) ) ).
% both_member_options_from_complete_tree_to_child
thf(fact_781_div__less,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ( ( divide_divide @ nat @ M @ N2 )
= ( zero_zero @ nat ) ) ) ).
% div_less
thf(fact_782_div__by__Suc__0,axiom,
! [M: nat] :
( ( divide_divide @ nat @ M @ ( suc @ ( zero_zero @ nat ) ) )
= M ) ).
% div_by_Suc_0
thf(fact_783_set__n__deg__not__0,axiom,
! [TreeList2: list @ vEBT_VEBT,N2: nat,M: nat] :
( ! [X5: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X5 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ( vEBT_invar_vebt @ X5 @ N2 ) )
=> ( ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) )
=> ( ord_less_eq @ nat @ ( one_one @ nat ) @ N2 ) ) ) ).
% set_n_deg_not_0
thf(fact_784_Suc__n__div__2__gt__zero,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ ( divide_divide @ nat @ ( suc @ N2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ).
% Suc_n_div_2_gt_zero
thf(fact_785_div__2__gt__zero,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ ( divide_divide @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ).
% div_2_gt_zero
thf(fact_786_div__exp__eq,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,M: nat,N2: nat] :
( ( divide_divide @ A @ ( divide_divide @ A @ A3 @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( divide_divide @ A @ A3 @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( plus_plus @ nat @ M @ N2 ) ) ) ) ) ).
% div_exp_eq
thf(fact_787_bits__div__by__0,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A] :
( ( divide_divide @ A @ A3 @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% bits_div_by_0
thf(fact_788_bits__div__0,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A] :
( ( divide_divide @ A @ ( zero_zero @ A ) @ A3 )
= ( zero_zero @ A ) ) ) ).
% bits_div_0
thf(fact_789_div__by__1,axiom,
! [A: $tType] :
( ( semidom_divide @ A )
=> ! [A3: A] :
( ( divide_divide @ A @ A3 @ ( one_one @ A ) )
= A3 ) ) ).
% div_by_1
thf(fact_790_zero__eq__1__divide__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ( zero_zero @ A )
= ( divide_divide @ A @ ( one_one @ A ) @ A3 ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% zero_eq_1_divide_iff
thf(fact_791_one__divide__eq__0__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ( divide_divide @ A @ ( one_one @ A ) @ A3 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% one_divide_eq_0_iff
thf(fact_792_eq__divide__eq__1,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,A3: A] :
( ( ( one_one @ A )
= ( divide_divide @ A @ B2 @ A3 ) )
= ( ( A3
!= ( zero_zero @ A ) )
& ( A3 = B2 ) ) ) ) ).
% eq_divide_eq_1
thf(fact_793_divide__eq__eq__1,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,A3: A] :
( ( ( divide_divide @ A @ B2 @ A3 )
= ( one_one @ A ) )
= ( ( A3
!= ( zero_zero @ A ) )
& ( A3 = B2 ) ) ) ) ).
% divide_eq_eq_1
thf(fact_794_divide__self__if,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( ( A3
= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ A3 @ A3 )
= ( zero_zero @ A ) ) )
& ( ( A3
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ A3 @ A3 )
= ( one_one @ A ) ) ) ) ) ).
% divide_self_if
thf(fact_795_divide__self,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ A3 @ A3 )
= ( one_one @ A ) ) ) ) ).
% divide_self
thf(fact_796_one__eq__divide__iff,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A] :
( ( ( one_one @ A )
= ( divide_divide @ A @ A3 @ B2 ) )
= ( ( B2
!= ( zero_zero @ A ) )
& ( A3 = B2 ) ) ) ) ).
% one_eq_divide_iff
thf(fact_797_div__self,axiom,
! [A: $tType] :
( ( semidom_divide @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ A3 @ A3 )
= ( one_one @ A ) ) ) ) ).
% div_self
thf(fact_798_divide__eq__1__iff,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A] :
( ( ( divide_divide @ A @ A3 @ B2 )
= ( one_one @ A ) )
= ( ( B2
!= ( zero_zero @ A ) )
& ( A3 = B2 ) ) ) ) ).
% divide_eq_1_iff
thf(fact_799_power__inject__exp,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,M: nat,N2: nat] :
( ( ord_less @ A @ ( one_one @ A ) @ A3 )
=> ( ( ( power_power @ A @ A3 @ M )
= ( power_power @ A @ A3 @ N2 ) )
= ( M = N2 ) ) ) ) ).
% power_inject_exp
thf(fact_800_max__0__1_I1_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ( ( ord_max @ A @ ( zero_zero @ A ) @ ( one_one @ A ) )
= ( one_one @ A ) ) ) ).
% max_0_1(1)
thf(fact_801_max__0__1_I2_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ( ( ord_max @ A @ ( one_one @ A ) @ ( zero_zero @ A ) )
= ( one_one @ A ) ) ) ).
% max_0_1(2)
thf(fact_802_max__0__1_I5_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [X: num] :
( ( ord_max @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ X ) )
= ( numeral_numeral @ A @ X ) ) ) ).
% max_0_1(5)
thf(fact_803_max__0__1_I6_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [X: num] :
( ( ord_max @ A @ ( numeral_numeral @ A @ X ) @ ( one_one @ A ) )
= ( numeral_numeral @ A @ X ) ) ) ).
% max_0_1(6)
thf(fact_804_less__one,axiom,
! [N2: nat] :
( ( ord_less @ nat @ N2 @ ( one_one @ nat ) )
= ( N2
= ( zero_zero @ nat ) ) ) ).
% less_one
thf(fact_805_zero__le__divide__1__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ ( one_one @ A ) @ A3 ) )
= ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% zero_le_divide_1_iff
thf(fact_806_divide__le__0__1__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( divide_divide @ A @ ( one_one @ A ) @ A3 ) @ ( zero_zero @ A ) )
= ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% divide_le_0_1_iff
thf(fact_807_zero__less__divide__1__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ ( one_one @ A ) @ A3 ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% zero_less_divide_1_iff
thf(fact_808_less__divide__eq__1__pos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ ( one_one @ A ) @ ( divide_divide @ A @ B2 @ A3 ) )
= ( ord_less @ A @ A3 @ B2 ) ) ) ) ).
% less_divide_eq_1_pos
thf(fact_809_less__divide__eq__1__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( one_one @ A ) @ ( divide_divide @ A @ B2 @ A3 ) )
= ( ord_less @ A @ B2 @ A3 ) ) ) ) ).
% less_divide_eq_1_neg
thf(fact_810_divide__less__eq__1__pos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ ( divide_divide @ A @ B2 @ A3 ) @ ( one_one @ A ) )
= ( ord_less @ A @ B2 @ A3 ) ) ) ) ).
% divide_less_eq_1_pos
thf(fact_811_divide__less__eq__1__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( divide_divide @ A @ B2 @ A3 ) @ ( one_one @ A ) )
= ( ord_less @ A @ A3 @ B2 ) ) ) ) ).
% divide_less_eq_1_neg
thf(fact_812_divide__less__0__1__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( divide_divide @ A @ ( one_one @ A ) @ A3 ) @ ( zero_zero @ A ) )
= ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% divide_less_0_1_iff
thf(fact_813_power__strict__increasing__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [B2: A,X: nat,Y: nat] :
( ( ord_less @ A @ ( one_one @ A ) @ B2 )
=> ( ( ord_less @ A @ ( power_power @ A @ B2 @ X ) @ ( power_power @ A @ B2 @ Y ) )
= ( ord_less @ nat @ X @ Y ) ) ) ) ).
% power_strict_increasing_iff
thf(fact_814_le__divide__eq__1__pos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( one_one @ A ) @ ( divide_divide @ A @ B2 @ A3 ) )
= ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ).
% le_divide_eq_1_pos
thf(fact_815_le__divide__eq__1__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ ( one_one @ A ) @ ( divide_divide @ A @ B2 @ A3 ) )
= ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ).
% le_divide_eq_1_neg
thf(fact_816_divide__le__eq__1__pos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( divide_divide @ A @ B2 @ A3 ) @ ( one_one @ A ) )
= ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ).
% divide_le_eq_1_pos
thf(fact_817_divide__le__eq__1__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ ( divide_divide @ A @ B2 @ A3 ) @ ( one_one @ A ) )
= ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ).
% divide_le_eq_1_neg
thf(fact_818_one__add__one,axiom,
! [A: $tType] :
( ( numeral @ A )
=> ( ( plus_plus @ A @ ( one_one @ A ) @ ( one_one @ A ) )
= ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ).
% one_add_one
thf(fact_819_power__strict__decreasing__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [B2: A,M: nat,N2: nat] :
( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less @ A @ B2 @ ( one_one @ A ) )
=> ( ( ord_less @ A @ ( power_power @ A @ B2 @ M ) @ ( power_power @ A @ B2 @ N2 ) )
= ( ord_less @ nat @ N2 @ M ) ) ) ) ) ).
% power_strict_decreasing_iff
thf(fact_820_power__increasing__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [B2: A,X: nat,Y: nat] :
( ( ord_less @ A @ ( one_one @ A ) @ B2 )
=> ( ( ord_less_eq @ A @ ( power_power @ A @ B2 @ X ) @ ( power_power @ A @ B2 @ Y ) )
= ( ord_less_eq @ nat @ X @ Y ) ) ) ) ).
% power_increasing_iff
thf(fact_821_Suc__1,axiom,
( ( suc @ ( one_one @ nat ) )
= ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ).
% Suc_1
thf(fact_822_numeral__plus__one,axiom,
! [A: $tType] :
( ( numeral @ A )
=> ! [N2: num] :
( ( plus_plus @ A @ ( numeral_numeral @ A @ N2 ) @ ( one_one @ A ) )
= ( numeral_numeral @ A @ ( plus_plus @ num @ N2 @ one2 ) ) ) ) ).
% numeral_plus_one
thf(fact_823_one__plus__numeral,axiom,
! [A: $tType] :
( ( numeral @ A )
=> ! [N2: num] :
( ( plus_plus @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ N2 ) )
= ( numeral_numeral @ A @ ( plus_plus @ num @ one2 @ N2 ) ) ) ) ).
% one_plus_numeral
thf(fact_824_numeral__le__one__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [N2: num] :
( ( ord_less_eq @ A @ ( numeral_numeral @ A @ N2 ) @ ( one_one @ A ) )
= ( ord_less_eq @ num @ N2 @ one2 ) ) ) ).
% numeral_le_one_iff
thf(fact_825_one__less__numeral__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [N2: num] :
( ( ord_less @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ N2 ) )
= ( ord_less @ num @ one2 @ N2 ) ) ) ).
% one_less_numeral_iff
thf(fact_826_one__div__two__eq__zero,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ( ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( zero_zero @ A ) ) ) ).
% one_div_two_eq_zero
thf(fact_827_bits__1__div__2,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ( ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( zero_zero @ A ) ) ) ).
% bits_1_div_2
thf(fact_828_power__decreasing__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [B2: A,M: nat,N2: nat] :
( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less @ A @ B2 @ ( one_one @ A ) )
=> ( ( ord_less_eq @ A @ ( power_power @ A @ B2 @ M ) @ ( power_power @ A @ B2 @ N2 ) )
= ( ord_less_eq @ nat @ N2 @ M ) ) ) ) ) ).
% power_decreasing_iff
thf(fact_829_one__reorient,axiom,
! [A: $tType] :
( ( one @ A )
=> ! [X: A] :
( ( ( one_one @ A )
= X )
= ( X
= ( one_one @ A ) ) ) ) ).
% one_reorient
thf(fact_830_le__numeral__extra_I4_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ( ord_less_eq @ A @ ( one_one @ A ) @ ( one_one @ A ) ) ) ).
% le_numeral_extra(4)
thf(fact_831_zero__neq__one,axiom,
! [A: $tType] :
( ( zero_neq_one @ A )
=> ( ( zero_zero @ A )
!= ( one_one @ A ) ) ) ).
% zero_neq_one
thf(fact_832_less__numeral__extra_I4_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ~ ( ord_less @ A @ ( one_one @ A ) @ ( one_one @ A ) ) ) ).
% less_numeral_extra(4)
thf(fact_833_div__add__self1,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ B2 @ A3 ) @ B2 )
= ( plus_plus @ A @ ( divide_divide @ A @ A3 @ B2 ) @ ( one_one @ A ) ) ) ) ) ).
% div_add_self1
thf(fact_834_div__add__self2,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ A3 @ B2 ) @ B2 )
= ( plus_plus @ A @ ( divide_divide @ A @ A3 @ B2 ) @ ( one_one @ A ) ) ) ) ) ).
% div_add_self2
thf(fact_835_not__one__le__zero,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ~ ( ord_less_eq @ A @ ( one_one @ A ) @ ( zero_zero @ A ) ) ) ).
% not_one_le_zero
thf(fact_836_linordered__nonzero__semiring__class_Ozero__le__one,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( one_one @ A ) ) ) ).
% linordered_nonzero_semiring_class.zero_le_one
thf(fact_837_zero__less__one__class_Ozero__le__one,axiom,
! [A: $tType] :
( ( zero_less_one @ A )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( one_one @ A ) ) ) ).
% zero_less_one_class.zero_le_one
thf(fact_838_not__one__less__zero,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ~ ( ord_less @ A @ ( one_one @ A ) @ ( zero_zero @ A ) ) ) ).
% not_one_less_zero
thf(fact_839_zero__less__one,axiom,
! [A: $tType] :
( ( zero_less_one @ A )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( one_one @ A ) ) ) ).
% zero_less_one
thf(fact_840_less__numeral__extra_I1_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( one_one @ A ) ) ) ).
% less_numeral_extra(1)
thf(fact_841_one__le__numeral,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [N2: num] : ( ord_less_eq @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ N2 ) ) ) ).
% one_le_numeral
thf(fact_842_not__numeral__less__one,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [N2: num] :
~ ( ord_less @ A @ ( numeral_numeral @ A @ N2 ) @ ( one_one @ A ) ) ) ).
% not_numeral_less_one
thf(fact_843_less__add__one,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A] : ( ord_less @ A @ A3 @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) ) ) ).
% less_add_one
thf(fact_844_add__mono1,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ord_less @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ ( plus_plus @ A @ B2 @ ( one_one @ A ) ) ) ) ) ).
% add_mono1
thf(fact_845_right__inverse__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( ( divide_divide @ A @ A3 @ B2 )
= ( one_one @ A ) )
= ( A3 = B2 ) ) ) ) ).
% right_inverse_eq
thf(fact_846_one__plus__numeral__commute,axiom,
! [A: $tType] :
( ( numeral @ A )
=> ! [X: num] :
( ( plus_plus @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ X ) )
= ( plus_plus @ A @ ( numeral_numeral @ A @ X ) @ ( one_one @ A ) ) ) ) ).
% one_plus_numeral_commute
thf(fact_847_one__le__power,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less_eq @ A @ ( one_one @ A ) @ A3 )
=> ( ord_less_eq @ A @ ( one_one @ A ) @ ( power_power @ A @ A3 @ N2 ) ) ) ) ).
% one_le_power
thf(fact_848_div__eq__dividend__iff,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ( ( divide_divide @ nat @ M @ N2 )
= M )
= ( N2
= ( one_one @ nat ) ) ) ) ).
% div_eq_dividend_iff
thf(fact_849_div__less__dividend,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( one_one @ nat ) @ N2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ord_less @ nat @ ( divide_divide @ nat @ M @ N2 ) @ M ) ) ) ).
% div_less_dividend
thf(fact_850_power__0,axiom,
! [A: $tType] :
( ( power @ A )
=> ! [A3: A] :
( ( power_power @ A @ A3 @ ( zero_zero @ nat ) )
= ( one_one @ A ) ) ) ).
% power_0
thf(fact_851_One__nat__def,axiom,
( ( one_one @ nat )
= ( suc @ ( zero_zero @ nat ) ) ) ).
% One_nat_def
thf(fact_852_Suc__eq__plus1__left,axiom,
( suc
= ( plus_plus @ nat @ ( one_one @ nat ) ) ) ).
% Suc_eq_plus1_left
thf(fact_853_plus__1__eq__Suc,axiom,
( ( plus_plus @ nat @ ( one_one @ nat ) )
= suc ) ).
% plus_1_eq_Suc
thf(fact_854_Suc__eq__plus1,axiom,
( suc
= ( ^ [N: nat] : ( plus_plus @ nat @ N @ ( one_one @ nat ) ) ) ) ).
% Suc_eq_plus1
thf(fact_855_zero__less__two,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ ( one_one @ A ) @ ( one_one @ A ) ) ) ) ).
% zero_less_two
thf(fact_856_less__divide__eq__1,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ ( one_one @ A ) @ ( divide_divide @ A @ B2 @ A3 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less @ A @ A3 @ B2 ) )
| ( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less @ A @ B2 @ A3 ) ) ) ) ) ).
% less_divide_eq_1
thf(fact_857_divide__less__eq__1,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ ( divide_divide @ A @ B2 @ A3 ) @ ( one_one @ A ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less @ A @ B2 @ A3 ) )
| ( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less @ A @ A3 @ B2 ) )
| ( A3
= ( zero_zero @ A ) ) ) ) ) ).
% divide_less_eq_1
thf(fact_858_power__le__one,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ A3 @ ( one_one @ A ) )
=> ( ord_less_eq @ A @ ( power_power @ A @ A3 @ N2 ) @ ( one_one @ A ) ) ) ) ) ).
% power_le_one
thf(fact_859_gt__half__sum,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ord_less @ A @ ( divide_divide @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( plus_plus @ A @ ( one_one @ A ) @ ( one_one @ A ) ) ) @ B2 ) ) ) ).
% gt_half_sum
thf(fact_860_less__half__sum,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ord_less @ A @ A3 @ ( divide_divide @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( plus_plus @ A @ ( one_one @ A ) @ ( one_one @ A ) ) ) ) ) ) ).
% less_half_sum
thf(fact_861_power__0__left,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [N2: nat] :
( ( ( N2
= ( zero_zero @ nat ) )
=> ( ( power_power @ A @ ( zero_zero @ A ) @ N2 )
= ( one_one @ A ) ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( power_power @ A @ ( zero_zero @ A ) @ N2 )
= ( zero_zero @ A ) ) ) ) ) ).
% power_0_left
thf(fact_862_power__gt1,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less @ A @ ( one_one @ A ) @ A3 )
=> ( ord_less @ A @ ( one_one @ A ) @ ( power_power @ A @ A3 @ ( suc @ N2 ) ) ) ) ) ).
% power_gt1
thf(fact_863_power__strict__increasing,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat,N7: nat,A3: A] :
( ( ord_less @ nat @ N2 @ N7 )
=> ( ( ord_less @ A @ ( one_one @ A ) @ A3 )
=> ( ord_less @ A @ ( power_power @ A @ A3 @ N2 ) @ ( power_power @ A @ A3 @ N7 ) ) ) ) ) ).
% power_strict_increasing
thf(fact_864_power__less__imp__less__exp,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,M: nat,N2: nat] :
( ( ord_less @ A @ ( one_one @ A ) @ A3 )
=> ( ( ord_less @ A @ ( power_power @ A @ A3 @ M ) @ ( power_power @ A @ A3 @ N2 ) )
=> ( ord_less @ nat @ M @ N2 ) ) ) ) ).
% power_less_imp_less_exp
thf(fact_865_power__increasing,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat,N7: nat,A3: A] :
( ( ord_less_eq @ nat @ N2 @ N7 )
=> ( ( ord_less_eq @ A @ ( one_one @ A ) @ A3 )
=> ( ord_less_eq @ A @ ( power_power @ A @ A3 @ N2 ) @ ( power_power @ A @ A3 @ N7 ) ) ) ) ) ).
% power_increasing
thf(fact_866_nat__induct__non__zero,axiom,
! [N2: nat,P2: nat > $o] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( P2 @ ( one_one @ nat ) )
=> ( ! [N3: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 )
=> ( ( P2 @ N3 )
=> ( P2 @ ( suc @ N3 ) ) ) )
=> ( P2 @ N2 ) ) ) ) ).
% nat_induct_non_zero
thf(fact_867_le__divide__eq__1,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ ( one_one @ A ) @ ( divide_divide @ A @ B2 @ A3 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less_eq @ A @ A3 @ B2 ) )
| ( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ) ).
% le_divide_eq_1
thf(fact_868_divide__le__eq__1,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ ( divide_divide @ A @ B2 @ A3 ) @ ( one_one @ A ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less_eq @ A @ B2 @ A3 ) )
| ( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less_eq @ A @ A3 @ B2 ) )
| ( A3
= ( zero_zero @ A ) ) ) ) ) ).
% divide_le_eq_1
thf(fact_869_power__Suc__le__self,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ A3 @ ( one_one @ A ) )
=> ( ord_less_eq @ A @ ( power_power @ A @ A3 @ ( suc @ N2 ) ) @ A3 ) ) ) ) ).
% power_Suc_le_self
thf(fact_870_power__Suc__less__one,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ A3 @ ( one_one @ A ) )
=> ( ord_less @ A @ ( power_power @ A @ A3 @ ( suc @ N2 ) ) @ ( one_one @ A ) ) ) ) ) ).
% power_Suc_less_one
thf(fact_871_power__strict__decreasing,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat,N7: nat,A3: A] :
( ( ord_less @ nat @ N2 @ N7 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ A3 @ ( one_one @ A ) )
=> ( ord_less @ A @ ( power_power @ A @ A3 @ N7 ) @ ( power_power @ A @ A3 @ N2 ) ) ) ) ) ) ).
% power_strict_decreasing
thf(fact_872_power__decreasing,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat,N7: nat,A3: A] :
( ( ord_less_eq @ nat @ N2 @ N7 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ A3 @ ( one_one @ A ) )
=> ( ord_less_eq @ A @ ( power_power @ A @ A3 @ N7 ) @ ( power_power @ A @ A3 @ N2 ) ) ) ) ) ) ).
% power_decreasing
thf(fact_873_power__le__imp__le__exp,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,M: nat,N2: nat] :
( ( ord_less @ A @ ( one_one @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( power_power @ A @ A3 @ M ) @ ( power_power @ A @ A3 @ N2 ) )
=> ( ord_less_eq @ nat @ M @ N2 ) ) ) ) ).
% power_le_imp_le_exp
thf(fact_874_self__le__power,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less_eq @ A @ ( one_one @ A ) @ A3 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less_eq @ A @ A3 @ ( power_power @ A @ A3 @ N2 ) ) ) ) ) ).
% self_le_power
thf(fact_875_one__less__power,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less @ A @ ( one_one @ A ) @ A3 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less @ A @ ( one_one @ A ) @ ( power_power @ A @ A3 @ N2 ) ) ) ) ) ).
% one_less_power
thf(fact_876_nat__1__add__1,axiom,
( ( plus_plus @ nat @ ( one_one @ nat ) @ ( one_one @ nat ) )
= ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ).
% nat_1_add_1
thf(fact_877_div__le__dividend,axiom,
! [M: nat,N2: nat] : ( ord_less_eq @ nat @ ( divide_divide @ nat @ M @ N2 ) @ M ) ).
% div_le_dividend
thf(fact_878_div__le__mono,axiom,
! [M: nat,N2: nat,K: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ord_less_eq @ nat @ ( divide_divide @ nat @ M @ K ) @ ( divide_divide @ nat @ N2 @ K ) ) ) ).
% div_le_mono
thf(fact_879_ex__power__ivl1,axiom,
! [B2: nat,K: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ B2 )
=> ( ( ord_less_eq @ nat @ ( one_one @ nat ) @ K )
=> ? [N3: nat] :
( ( ord_less_eq @ nat @ ( power_power @ nat @ B2 @ N3 ) @ K )
& ( ord_less @ nat @ K @ ( power_power @ nat @ B2 @ ( plus_plus @ nat @ N3 @ ( one_one @ nat ) ) ) ) ) ) ) ).
% ex_power_ivl1
thf(fact_880_ex__power__ivl2,axiom,
! [B2: nat,K: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ B2 )
=> ( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ K )
=> ? [N3: nat] :
( ( ord_less @ nat @ ( power_power @ nat @ B2 @ N3 ) @ K )
& ( ord_less_eq @ nat @ K @ ( power_power @ nat @ B2 @ ( plus_plus @ nat @ N3 @ ( one_one @ nat ) ) ) ) ) ) ) ).
% ex_power_ivl2
thf(fact_881_Euclidean__Division_Odiv__eq__0__iff,axiom,
! [M: nat,N2: nat] :
( ( ( divide_divide @ nat @ M @ N2 )
= ( zero_zero @ nat ) )
= ( ( ord_less @ nat @ M @ N2 )
| ( N2
= ( zero_zero @ nat ) ) ) ) ).
% Euclidean_Division.div_eq_0_iff
thf(fact_882_Suc__div__le__mono,axiom,
! [M: nat,N2: nat] : ( ord_less_eq @ nat @ ( divide_divide @ nat @ M @ N2 ) @ ( divide_divide @ nat @ ( suc @ M ) @ N2 ) ) ).
% Suc_div_le_mono
thf(fact_883_div__greater__zero__iff,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( divide_divide @ nat @ M @ N2 ) )
= ( ( ord_less_eq @ nat @ N2 @ M )
& ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ).
% div_greater_zero_iff
thf(fact_884_div__le__mono2,axiom,
! [M: nat,N2: nat,K: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ( ord_less_eq @ nat @ M @ N2 )
=> ( ord_less_eq @ nat @ ( divide_divide @ nat @ K @ N2 ) @ ( divide_divide @ nat @ K @ M ) ) ) ) ).
% div_le_mono2
thf(fact_885_exp__add__not__zero__imp__left,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [M: nat,N2: nat] :
( ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( plus_plus @ nat @ M @ N2 ) )
!= ( zero_zero @ A ) )
=> ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M )
!= ( zero_zero @ A ) ) ) ) ).
% exp_add_not_zero_imp_left
thf(fact_886_exp__add__not__zero__imp__right,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [M: nat,N2: nat] :
( ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( plus_plus @ nat @ M @ N2 ) )
!= ( zero_zero @ A ) )
=> ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 )
!= ( zero_zero @ A ) ) ) ) ).
% exp_add_not_zero_imp_right
thf(fact_887_nat__induct2,axiom,
! [P2: nat > $o,N2: nat] :
( ( P2 @ ( zero_zero @ nat ) )
=> ( ( P2 @ ( one_one @ nat ) )
=> ( ! [N3: nat] :
( ( P2 @ N3 )
=> ( P2 @ ( plus_plus @ nat @ N3 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
=> ( P2 @ N2 ) ) ) ) ).
% nat_induct2
thf(fact_888_bit__concat__def,axiom,
( vEBT_VEBT_bit_concat
= ( ^ [H: nat,L2: nat,D5: nat] : ( plus_plus @ nat @ ( times_times @ nat @ H @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ D5 ) ) @ L2 ) ) ) ).
% bit_concat_def
thf(fact_889_low__inv,axiom,
! [X: nat,N2: nat,Y: nat] :
( ( ord_less @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) )
=> ( ( vEBT_VEBT_low @ ( plus_plus @ nat @ ( times_times @ nat @ Y @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) @ X ) @ N2 )
= X ) ) ).
% low_inv
thf(fact_890_high__inv,axiom,
! [X: nat,N2: nat,Y: nat] :
( ( ord_less @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) )
=> ( ( vEBT_VEBT_high @ ( plus_plus @ nat @ ( times_times @ nat @ Y @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) @ X ) @ N2 )
= Y ) ) ).
% high_inv
thf(fact_891_enat__ord__number_I1_J,axiom,
! [M: num,N2: num] :
( ( ord_less_eq @ extended_enat @ ( numeral_numeral @ extended_enat @ M ) @ ( numeral_numeral @ extended_enat @ N2 ) )
= ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ M ) @ ( numeral_numeral @ nat @ N2 ) ) ) ).
% enat_ord_number(1)
thf(fact_892_enat__ord__number_I2_J,axiom,
! [M: num,N2: num] :
( ( ord_less @ extended_enat @ ( numeral_numeral @ extended_enat @ M ) @ ( numeral_numeral @ extended_enat @ N2 ) )
= ( ord_less @ nat @ ( numeral_numeral @ nat @ M ) @ ( numeral_numeral @ nat @ N2 ) ) ) ).
% enat_ord_number(2)
thf(fact_893_pos2,axiom,
ord_less @ nat @ ( zero_zero @ nat ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ).
% pos2
thf(fact_894_discrete,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ( ( ord_less @ A )
= ( ^ [A5: A] : ( ord_less_eq @ A @ ( plus_plus @ A @ A5 @ ( one_one @ A ) ) ) ) ) ) ).
% discrete
thf(fact_895_div__positive,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ).
% div_positive
thf(fact_896_unique__euclidean__semiring__numeral__class_Odiv__less,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ A3 @ B2 )
=> ( ( divide_divide @ A @ A3 @ B2 )
= ( zero_zero @ A ) ) ) ) ) ).
% unique_euclidean_semiring_numeral_class.div_less
thf(fact_897_mult__zero__left,axiom,
! [A: $tType] :
( ( mult_zero @ A )
=> ! [A3: A] :
( ( times_times @ A @ ( zero_zero @ A ) @ A3 )
= ( zero_zero @ A ) ) ) ).
% mult_zero_left
thf(fact_898_mult__zero__right,axiom,
! [A: $tType] :
( ( mult_zero @ A )
=> ! [A3: A] :
( ( times_times @ A @ A3 @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% mult_zero_right
thf(fact_899_mult__eq__0__iff,axiom,
! [A: $tType] :
( ( semiri3467727345109120633visors @ A )
=> ! [A3: A,B2: A] :
( ( ( times_times @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
= ( ( A3
= ( zero_zero @ A ) )
| ( B2
= ( zero_zero @ A ) ) ) ) ) ).
% mult_eq_0_iff
thf(fact_900_mult__cancel__left,axiom,
! [A: $tType] :
( ( semiri6575147826004484403cancel @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ( times_times @ A @ C2 @ A3 )
= ( times_times @ A @ C2 @ B2 ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( A3 = B2 ) ) ) ) ).
% mult_cancel_left
thf(fact_901_mult__cancel__right,axiom,
! [A: $tType] :
( ( semiri6575147826004484403cancel @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ( times_times @ A @ A3 @ C2 )
= ( times_times @ A @ B2 @ C2 ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( A3 = B2 ) ) ) ) ).
% mult_cancel_right
thf(fact_902_mult__1,axiom,
! [A: $tType] :
( ( monoid_mult @ A )
=> ! [A3: A] :
( ( times_times @ A @ ( one_one @ A ) @ A3 )
= A3 ) ) ).
% mult_1
thf(fact_903_mult_Oright__neutral,axiom,
! [A: $tType] :
( ( monoid_mult @ A )
=> ! [A3: A] :
( ( times_times @ A @ A3 @ ( one_one @ A ) )
= A3 ) ) ).
% mult.right_neutral
thf(fact_904_times__divide__eq__right,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( times_times @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( divide_divide @ A @ ( times_times @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% times_divide_eq_right
thf(fact_905_divide__divide__eq__right,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( divide_divide @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( divide_divide @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 ) ) ) ).
% divide_divide_eq_right
thf(fact_906_divide__divide__eq__left,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( divide_divide @ A @ ( divide_divide @ A @ A3 @ B2 ) @ C2 )
= ( divide_divide @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) ) ) ) ).
% divide_divide_eq_left
thf(fact_907_times__divide__eq__left,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( times_times @ A @ ( divide_divide @ A @ B2 @ C2 ) @ A3 )
= ( divide_divide @ A @ ( times_times @ A @ B2 @ A3 ) @ C2 ) ) ) ).
% times_divide_eq_left
thf(fact_908_mult__is__0,axiom,
! [M: nat,N2: nat] :
( ( ( times_times @ nat @ M @ N2 )
= ( zero_zero @ nat ) )
= ( ( M
= ( zero_zero @ nat ) )
| ( N2
= ( zero_zero @ nat ) ) ) ) ).
% mult_is_0
thf(fact_909_mult__0__right,axiom,
! [M: nat] :
( ( times_times @ nat @ M @ ( zero_zero @ nat ) )
= ( zero_zero @ nat ) ) ).
% mult_0_right
thf(fact_910_mult__cancel1,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ( times_times @ nat @ K @ M )
= ( times_times @ nat @ K @ N2 ) )
= ( ( M = N2 )
| ( K
= ( zero_zero @ nat ) ) ) ) ).
% mult_cancel1
thf(fact_911_mult__cancel2,axiom,
! [M: nat,K: nat,N2: nat] :
( ( ( times_times @ nat @ M @ K )
= ( times_times @ nat @ N2 @ K ) )
= ( ( M = N2 )
| ( K
= ( zero_zero @ nat ) ) ) ) ).
% mult_cancel2
thf(fact_912_nat__mult__eq__1__iff,axiom,
! [M: nat,N2: nat] :
( ( ( times_times @ nat @ M @ N2 )
= ( one_one @ nat ) )
= ( ( M
= ( one_one @ nat ) )
& ( N2
= ( one_one @ nat ) ) ) ) ).
% nat_mult_eq_1_iff
thf(fact_913_nat__1__eq__mult__iff,axiom,
! [M: nat,N2: nat] :
( ( ( one_one @ nat )
= ( times_times @ nat @ M @ N2 ) )
= ( ( M
= ( one_one @ nat ) )
& ( N2
= ( one_one @ nat ) ) ) ) ).
% nat_1_eq_mult_iff
thf(fact_914_mult__cancel__left1,axiom,
! [A: $tType] :
( ( ring_15535105094025558882visors @ A )
=> ! [C2: A,B2: A] :
( ( C2
= ( times_times @ A @ C2 @ B2 ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( B2
= ( one_one @ A ) ) ) ) ) ).
% mult_cancel_left1
thf(fact_915_mult__cancel__left2,axiom,
! [A: $tType] :
( ( ring_15535105094025558882visors @ A )
=> ! [C2: A,A3: A] :
( ( ( times_times @ A @ C2 @ A3 )
= C2 )
= ( ( C2
= ( zero_zero @ A ) )
| ( A3
= ( one_one @ A ) ) ) ) ) ).
% mult_cancel_left2
thf(fact_916_mult__cancel__right1,axiom,
! [A: $tType] :
( ( ring_15535105094025558882visors @ A )
=> ! [C2: A,B2: A] :
( ( C2
= ( times_times @ A @ B2 @ C2 ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( B2
= ( one_one @ A ) ) ) ) ) ).
% mult_cancel_right1
thf(fact_917_mult__cancel__right2,axiom,
! [A: $tType] :
( ( ring_15535105094025558882visors @ A )
=> ! [A3: A,C2: A] :
( ( ( times_times @ A @ A3 @ C2 )
= C2 )
= ( ( C2
= ( zero_zero @ A ) )
| ( A3
= ( one_one @ A ) ) ) ) ) ).
% mult_cancel_right2
thf(fact_918_sum__squares__eq__zero__iff,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [X: A,Y: A] :
( ( ( plus_plus @ A @ ( times_times @ A @ X @ X ) @ ( times_times @ A @ Y @ Y ) )
= ( zero_zero @ A ) )
= ( ( X
= ( zero_zero @ A ) )
& ( Y
= ( zero_zero @ A ) ) ) ) ) ).
% sum_squares_eq_zero_iff
thf(fact_919_mult__divide__mult__cancel__left__if,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ( C2
= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( zero_zero @ A ) ) )
& ( ( C2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ).
% mult_divide_mult_cancel_left_if
thf(fact_920_nonzero__mult__divide__mult__cancel__left,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ).
% nonzero_mult_divide_mult_cancel_left
thf(fact_921_nonzero__mult__div__cancel__left,axiom,
! [A: $tType] :
( ( semidom_divide @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ A3 @ B2 ) @ A3 )
= B2 ) ) ) ).
% nonzero_mult_div_cancel_left
thf(fact_922_nonzero__mult__divide__mult__cancel__left2,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ B2 @ C2 ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ).
% nonzero_mult_divide_mult_cancel_left2
thf(fact_923_nonzero__mult__divide__mult__cancel__right,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ).
% nonzero_mult_divide_mult_cancel_right
thf(fact_924_nonzero__mult__div__cancel__right,axiom,
! [A: $tType] :
( ( semidom_divide @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ A3 @ B2 ) @ B2 )
= A3 ) ) ) ).
% nonzero_mult_div_cancel_right
thf(fact_925_nonzero__mult__divide__mult__cancel__right2,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ).
% nonzero_mult_divide_mult_cancel_right2
thf(fact_926_div__mult__mult1,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ).
% div_mult_mult1
thf(fact_927_div__mult__mult2,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ).
% div_mult_mult2
thf(fact_928_div__mult__mult1__if,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ( C2
= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( zero_zero @ A ) ) )
& ( ( C2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ).
% div_mult_mult1_if
thf(fact_929_distrib__left__numeral,axiom,
! [A: $tType] :
( ( ( numeral @ A )
& ( semiring @ A ) )
=> ! [V2: num,B2: A,C2: A] :
( ( times_times @ A @ ( numeral_numeral @ A @ V2 ) @ ( plus_plus @ A @ B2 @ C2 ) )
= ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ V2 ) @ B2 ) @ ( times_times @ A @ ( numeral_numeral @ A @ V2 ) @ C2 ) ) ) ) ).
% distrib_left_numeral
thf(fact_930_distrib__right__numeral,axiom,
! [A: $tType] :
( ( ( numeral @ A )
& ( semiring @ A ) )
=> ! [A3: A,B2: A,V2: num] :
( ( times_times @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( numeral_numeral @ A @ V2 ) )
= ( plus_plus @ A @ ( times_times @ A @ A3 @ ( numeral_numeral @ A @ V2 ) ) @ ( times_times @ A @ B2 @ ( numeral_numeral @ A @ V2 ) ) ) ) ) ).
% distrib_right_numeral
thf(fact_931_one__eq__mult__iff,axiom,
! [M: nat,N2: nat] :
( ( ( suc @ ( zero_zero @ nat ) )
= ( times_times @ nat @ M @ N2 ) )
= ( ( M
= ( suc @ ( zero_zero @ nat ) ) )
& ( N2
= ( suc @ ( zero_zero @ nat ) ) ) ) ) ).
% one_eq_mult_iff
thf(fact_932_mult__eq__1__iff,axiom,
! [M: nat,N2: nat] :
( ( ( times_times @ nat @ M @ N2 )
= ( suc @ ( zero_zero @ nat ) ) )
= ( ( M
= ( suc @ ( zero_zero @ nat ) ) )
& ( N2
= ( suc @ ( zero_zero @ nat ) ) ) ) ) ).
% mult_eq_1_iff
thf(fact_933_mult__less__cancel2,axiom,
! [M: nat,K: nat,N2: nat] :
( ( ord_less @ nat @ ( times_times @ nat @ M @ K ) @ ( times_times @ nat @ N2 @ K ) )
= ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
& ( ord_less @ nat @ M @ N2 ) ) ) ).
% mult_less_cancel2
thf(fact_934_nat__0__less__mult__iff,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( times_times @ nat @ M @ N2 ) )
= ( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
& ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ).
% nat_0_less_mult_iff
thf(fact_935_mult__Suc__right,axiom,
! [M: nat,N2: nat] :
( ( times_times @ nat @ M @ ( suc @ N2 ) )
= ( plus_plus @ nat @ M @ ( times_times @ nat @ M @ N2 ) ) ) ).
% mult_Suc_right
thf(fact_936_le__divide__eq__numeral1_I1_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,W2: num] :
( ( ord_less_eq @ A @ A3 @ ( divide_divide @ A @ B2 @ ( numeral_numeral @ A @ W2 ) ) )
= ( ord_less_eq @ A @ ( times_times @ A @ A3 @ ( numeral_numeral @ A @ W2 ) ) @ B2 ) ) ) ).
% le_divide_eq_numeral1(1)
thf(fact_937_divide__le__eq__numeral1_I1_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,W2: num,A3: A] :
( ( ord_less_eq @ A @ ( divide_divide @ A @ B2 @ ( numeral_numeral @ A @ W2 ) ) @ A3 )
= ( ord_less_eq @ A @ B2 @ ( times_times @ A @ A3 @ ( numeral_numeral @ A @ W2 ) ) ) ) ) ).
% divide_le_eq_numeral1(1)
thf(fact_938_eq__divide__eq__numeral1_I1_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A,W2: num] :
( ( A3
= ( divide_divide @ A @ B2 @ ( numeral_numeral @ A @ W2 ) ) )
= ( ( ( ( numeral_numeral @ A @ W2 )
!= ( zero_zero @ A ) )
=> ( ( times_times @ A @ A3 @ ( numeral_numeral @ A @ W2 ) )
= B2 ) )
& ( ( ( numeral_numeral @ A @ W2 )
= ( zero_zero @ A ) )
=> ( A3
= ( zero_zero @ A ) ) ) ) ) ) ).
% eq_divide_eq_numeral1(1)
thf(fact_939_divide__eq__eq__numeral1_I1_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [B2: A,W2: num,A3: A] :
( ( ( divide_divide @ A @ B2 @ ( numeral_numeral @ A @ W2 ) )
= A3 )
= ( ( ( ( numeral_numeral @ A @ W2 )
!= ( zero_zero @ A ) )
=> ( B2
= ( times_times @ A @ A3 @ ( numeral_numeral @ A @ W2 ) ) ) )
& ( ( ( numeral_numeral @ A @ W2 )
= ( zero_zero @ A ) )
=> ( A3
= ( zero_zero @ A ) ) ) ) ) ) ).
% divide_eq_eq_numeral1(1)
thf(fact_940_divide__less__eq__numeral1_I1_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,W2: num,A3: A] :
( ( ord_less @ A @ ( divide_divide @ A @ B2 @ ( numeral_numeral @ A @ W2 ) ) @ A3 )
= ( ord_less @ A @ B2 @ ( times_times @ A @ A3 @ ( numeral_numeral @ A @ W2 ) ) ) ) ) ).
% divide_less_eq_numeral1(1)
thf(fact_941_less__divide__eq__numeral1_I1_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,W2: num] :
( ( ord_less @ A @ A3 @ ( divide_divide @ A @ B2 @ ( numeral_numeral @ A @ W2 ) ) )
= ( ord_less @ A @ ( times_times @ A @ A3 @ ( numeral_numeral @ A @ W2 ) ) @ B2 ) ) ) ).
% less_divide_eq_numeral1(1)
thf(fact_942_nonzero__divide__mult__cancel__right,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ B2 @ ( times_times @ A @ A3 @ B2 ) )
= ( divide_divide @ A @ ( one_one @ A ) @ A3 ) ) ) ) ).
% nonzero_divide_mult_cancel_right
thf(fact_943_nonzero__divide__mult__cancel__left,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ A3 @ ( times_times @ A @ A3 @ B2 ) )
= ( divide_divide @ A @ ( one_one @ A ) @ B2 ) ) ) ) ).
% nonzero_divide_mult_cancel_left
thf(fact_944_div__mult__self4,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ ( times_times @ A @ B2 @ C2 ) @ A3 ) @ B2 )
= ( plus_plus @ A @ C2 @ ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ).
% div_mult_self4
thf(fact_945_div__mult__self3,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ ( times_times @ A @ C2 @ B2 ) @ A3 ) @ B2 )
= ( plus_plus @ A @ C2 @ ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ).
% div_mult_self3
thf(fact_946_div__mult__self2,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) ) @ B2 )
= ( plus_plus @ A @ C2 @ ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ).
% div_mult_self2
thf(fact_947_div__mult__self1,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ A3 @ ( times_times @ A @ C2 @ B2 ) ) @ B2 )
= ( plus_plus @ A @ C2 @ ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ).
% div_mult_self1
thf(fact_948_one__le__mult__iff,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( times_times @ nat @ M @ N2 ) )
= ( ( ord_less_eq @ nat @ ( suc @ ( zero_zero @ nat ) ) @ M )
& ( ord_less_eq @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 ) ) ) ).
% one_le_mult_iff
thf(fact_949_mult__le__cancel2,axiom,
! [M: nat,K: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( times_times @ nat @ M @ K ) @ ( times_times @ nat @ N2 @ K ) )
= ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ord_less_eq @ nat @ M @ N2 ) ) ) ).
% mult_le_cancel2
thf(fact_950_div__mult__self__is__m,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( divide_divide @ nat @ ( times_times @ nat @ M @ N2 ) @ N2 )
= M ) ) ).
% div_mult_self_is_m
thf(fact_951_div__mult__self1__is__m,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( divide_divide @ nat @ ( times_times @ nat @ N2 @ M ) @ N2 )
= M ) ) ).
% div_mult_self1_is_m
thf(fact_952_mult_Oleft__commute,axiom,
! [A: $tType] :
( ( ab_semigroup_mult @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( times_times @ A @ B2 @ ( times_times @ A @ A3 @ C2 ) )
= ( times_times @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) ) ) ) ).
% mult.left_commute
thf(fact_953_mult_Ocommute,axiom,
! [A: $tType] :
( ( ab_semigroup_mult @ A )
=> ( ( times_times @ A )
= ( ^ [A5: A,B4: A] : ( times_times @ A @ B4 @ A5 ) ) ) ) ).
% mult.commute
thf(fact_954_mult_Oassoc,axiom,
! [A: $tType] :
( ( semigroup_mult @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( times_times @ A @ ( times_times @ A @ A3 @ B2 ) @ C2 )
= ( times_times @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) ) ) ) ).
% mult.assoc
thf(fact_955_ab__semigroup__mult__class_Omult__ac_I1_J,axiom,
! [A: $tType] :
( ( ab_semigroup_mult @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( times_times @ A @ ( times_times @ A @ A3 @ B2 ) @ C2 )
= ( times_times @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) ) ) ) ).
% ab_semigroup_mult_class.mult_ac(1)
thf(fact_956_mult__not__zero,axiom,
! [A: $tType] :
( ( mult_zero @ A )
=> ! [A3: A,B2: A] :
( ( ( times_times @ A @ A3 @ B2 )
!= ( zero_zero @ A ) )
=> ( ( A3
!= ( zero_zero @ A ) )
& ( B2
!= ( zero_zero @ A ) ) ) ) ) ).
% mult_not_zero
thf(fact_957_divisors__zero,axiom,
! [A: $tType] :
( ( semiri3467727345109120633visors @ A )
=> ! [A3: A,B2: A] :
( ( ( times_times @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
=> ( ( A3
= ( zero_zero @ A ) )
| ( B2
= ( zero_zero @ A ) ) ) ) ) ).
% divisors_zero
thf(fact_958_no__zero__divisors,axiom,
! [A: $tType] :
( ( semiri3467727345109120633visors @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ( times_times @ A @ A3 @ B2 )
!= ( zero_zero @ A ) ) ) ) ) ).
% no_zero_divisors
thf(fact_959_mult__left__cancel,axiom,
! [A: $tType] :
( ( semiri6575147826004484403cancel @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( ( times_times @ A @ C2 @ A3 )
= ( times_times @ A @ C2 @ B2 ) )
= ( A3 = B2 ) ) ) ) ).
% mult_left_cancel
thf(fact_960_mult__right__cancel,axiom,
! [A: $tType] :
( ( semiri6575147826004484403cancel @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( ( times_times @ A @ A3 @ C2 )
= ( times_times @ A @ B2 @ C2 ) )
= ( A3 = B2 ) ) ) ) ).
% mult_right_cancel
thf(fact_961_mult_Ocomm__neutral,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A] :
( ( times_times @ A @ A3 @ ( one_one @ A ) )
= A3 ) ) ).
% mult.comm_neutral
thf(fact_962_comm__monoid__mult__class_Omult__1,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A] :
( ( times_times @ A @ ( one_one @ A ) @ A3 )
= A3 ) ) ).
% comm_monoid_mult_class.mult_1
thf(fact_963_crossproduct__eq,axiom,
! [A: $tType] :
( ( semiri1453513574482234551roduct @ A )
=> ! [W2: A,Y: A,X: A,Z: A] :
( ( ( plus_plus @ A @ ( times_times @ A @ W2 @ Y ) @ ( times_times @ A @ X @ Z ) )
= ( plus_plus @ A @ ( times_times @ A @ W2 @ Z ) @ ( times_times @ A @ X @ Y ) ) )
= ( ( W2 = X )
| ( Y = Z ) ) ) ) ).
% crossproduct_eq
thf(fact_964_crossproduct__noteq,axiom,
! [A: $tType] :
( ( semiri1453513574482234551roduct @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ( A3 != B2 )
& ( C2 != D2 ) )
= ( ( plus_plus @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ D2 ) )
!= ( plus_plus @ A @ ( times_times @ A @ A3 @ D2 ) @ ( times_times @ A @ B2 @ C2 ) ) ) ) ) ).
% crossproduct_noteq
thf(fact_965_ring__class_Oring__distribs_I2_J,axiom,
! [A: $tType] :
( ( ring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( times_times @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) ) ) ) ).
% ring_class.ring_distribs(2)
thf(fact_966_ring__class_Oring__distribs_I1_J,axiom,
! [A: $tType] :
( ( ring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( times_times @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) )
= ( plus_plus @ A @ ( times_times @ A @ A3 @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) ) ) ).
% ring_class.ring_distribs(1)
thf(fact_967_comm__semiring__class_Odistrib,axiom,
! [A: $tType] :
( ( comm_semiring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( times_times @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) ) ) ) ).
% comm_semiring_class.distrib
thf(fact_968_distrib__left,axiom,
! [A: $tType] :
( ( semiring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( times_times @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) )
= ( plus_plus @ A @ ( times_times @ A @ A3 @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) ) ) ).
% distrib_left
thf(fact_969_distrib__right,axiom,
! [A: $tType] :
( ( semiring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( times_times @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) ) ) ) ).
% distrib_right
thf(fact_970_combine__common__factor,axiom,
! [A: $tType] :
( ( semiring @ A )
=> ! [A3: A,E3: A,B2: A,C2: A] :
( ( plus_plus @ A @ ( times_times @ A @ A3 @ E3 ) @ ( plus_plus @ A @ ( times_times @ A @ B2 @ E3 ) @ C2 ) )
= ( plus_plus @ A @ ( times_times @ A @ ( plus_plus @ A @ A3 @ B2 ) @ E3 ) @ C2 ) ) ) ).
% combine_common_factor
thf(fact_971_divide__divide__eq__left_H,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( divide_divide @ A @ ( divide_divide @ A @ A3 @ B2 ) @ C2 )
= ( divide_divide @ A @ A3 @ ( times_times @ A @ C2 @ B2 ) ) ) ) ).
% divide_divide_eq_left'
thf(fact_972_divide__divide__times__eq,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [X: A,Y: A,Z: A,W2: A] :
( ( divide_divide @ A @ ( divide_divide @ A @ X @ Y ) @ ( divide_divide @ A @ Z @ W2 ) )
= ( divide_divide @ A @ ( times_times @ A @ X @ W2 ) @ ( times_times @ A @ Y @ Z ) ) ) ) ).
% divide_divide_times_eq
thf(fact_973_times__divide__times__eq,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [X: A,Y: A,Z: A,W2: A] :
( ( times_times @ A @ ( divide_divide @ A @ X @ Y ) @ ( divide_divide @ A @ Z @ W2 ) )
= ( divide_divide @ A @ ( times_times @ A @ X @ Z ) @ ( times_times @ A @ Y @ W2 ) ) ) ) ).
% times_divide_times_eq
thf(fact_974_Suc__mult__cancel1,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ( times_times @ nat @ ( suc @ K ) @ M )
= ( times_times @ nat @ ( suc @ K ) @ N2 ) )
= ( M = N2 ) ) ).
% Suc_mult_cancel1
thf(fact_975_mult__0,axiom,
! [N2: nat] :
( ( times_times @ nat @ ( zero_zero @ nat ) @ N2 )
= ( zero_zero @ nat ) ) ).
% mult_0
thf(fact_976_le__cube,axiom,
! [M: nat] : ( ord_less_eq @ nat @ M @ ( times_times @ nat @ M @ ( times_times @ nat @ M @ M ) ) ) ).
% le_cube
thf(fact_977_le__square,axiom,
! [M: nat] : ( ord_less_eq @ nat @ M @ ( times_times @ nat @ M @ M ) ) ).
% le_square
thf(fact_978_mult__le__mono,axiom,
! [I: nat,J: nat,K: nat,L: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( ord_less_eq @ nat @ K @ L )
=> ( ord_less_eq @ nat @ ( times_times @ nat @ I @ K ) @ ( times_times @ nat @ J @ L ) ) ) ) ).
% mult_le_mono
thf(fact_979_mult__le__mono1,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ord_less_eq @ nat @ ( times_times @ nat @ I @ K ) @ ( times_times @ nat @ J @ K ) ) ) ).
% mult_le_mono1
thf(fact_980_mult__le__mono2,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ord_less_eq @ nat @ ( times_times @ nat @ K @ I ) @ ( times_times @ nat @ K @ J ) ) ) ).
% mult_le_mono2
thf(fact_981_add__mult__distrib,axiom,
! [M: nat,N2: nat,K: nat] :
( ( times_times @ nat @ ( plus_plus @ nat @ M @ N2 ) @ K )
= ( plus_plus @ nat @ ( times_times @ nat @ M @ K ) @ ( times_times @ nat @ N2 @ K ) ) ) ).
% add_mult_distrib
thf(fact_982_add__mult__distrib2,axiom,
! [K: nat,M: nat,N2: nat] :
( ( times_times @ nat @ K @ ( plus_plus @ nat @ M @ N2 ) )
= ( plus_plus @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) ) ) ).
% add_mult_distrib2
thf(fact_983_nat__mult__1__right,axiom,
! [N2: nat] :
( ( times_times @ nat @ N2 @ ( one_one @ nat ) )
= N2 ) ).
% nat_mult_1_right
thf(fact_984_nat__mult__1,axiom,
! [N2: nat] :
( ( times_times @ nat @ ( one_one @ nat ) @ N2 )
= N2 ) ).
% nat_mult_1
thf(fact_985_nat__mult__max__left,axiom,
! [M: nat,N2: nat,Q2: nat] :
( ( times_times @ nat @ ( ord_max @ nat @ M @ N2 ) @ Q2 )
= ( ord_max @ nat @ ( times_times @ nat @ M @ Q2 ) @ ( times_times @ nat @ N2 @ Q2 ) ) ) ).
% nat_mult_max_left
thf(fact_986_nat__mult__max__right,axiom,
! [M: nat,N2: nat,Q2: nat] :
( ( times_times @ nat @ M @ ( ord_max @ nat @ N2 @ Q2 ) )
= ( ord_max @ nat @ ( times_times @ nat @ M @ N2 ) @ ( times_times @ nat @ M @ Q2 ) ) ) ).
% nat_mult_max_right
thf(fact_987_unique__euclidean__semiring__numeral__class_Odiv__mult2__eq,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( divide_divide @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) )
= ( divide_divide @ A @ ( divide_divide @ A @ A3 @ B2 ) @ C2 ) ) ) ) ).
% unique_euclidean_semiring_numeral_class.div_mult2_eq
thf(fact_988_mult__mono,axiom,
! [A: $tType] :
( ( ordered_semiring @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ D2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ D2 ) ) ) ) ) ) ) ).
% mult_mono
thf(fact_989_mult__mono_H,axiom,
! [A: $tType] :
( ( ordered_semiring @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ D2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ D2 ) ) ) ) ) ) ) ).
% mult_mono'
thf(fact_990_zero__le__square,axiom,
! [A: $tType] :
( ( linordered_ring @ A )
=> ! [A3: A] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ A3 ) ) ) ).
% zero_le_square
thf(fact_991_split__mult__pos__le,axiom,
! [A: $tType] :
( ( ordered_ring @ A )
=> ! [A3: A,B2: A] :
( ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 ) )
| ( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) ) ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) ) ) ) ).
% split_mult_pos_le
thf(fact_992_mult__left__mono__neg,axiom,
! [A: $tType] :
( ( ordered_ring @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) ) ) ) ) ).
% mult_left_mono_neg
thf(fact_993_mult__nonpos__nonpos,axiom,
! [A: $tType] :
( ( ordered_ring @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) ) ) ) ) ).
% mult_nonpos_nonpos
thf(fact_994_mult__left__mono,axiom,
! [A: $tType] :
( ( ordered_semiring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) ) ) ) ) ).
% mult_left_mono
thf(fact_995_mult__right__mono__neg,axiom,
! [A: $tType] :
( ( ordered_ring @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) ) ) ) ) ).
% mult_right_mono_neg
thf(fact_996_mult__right__mono,axiom,
! [A: $tType] :
( ( ordered_semiring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) ) ) ) ) ).
% mult_right_mono
thf(fact_997_mult__le__0__iff,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( times_times @ A @ A3 @ B2 ) @ ( zero_zero @ A ) )
= ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) ) )
| ( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 ) ) ) ) ) ).
% mult_le_0_iff
thf(fact_998_split__mult__neg__le,axiom,
! [A: $tType] :
( ( ordered_semiring_0 @ A )
=> ! [A3: A,B2: A] :
( ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) ) )
| ( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 ) ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ B2 ) @ ( zero_zero @ A ) ) ) ) ).
% split_mult_neg_le
thf(fact_999_mult__nonneg__nonneg,axiom,
! [A: $tType] :
( ( ordered_semiring_0 @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) ) ) ) ) ).
% mult_nonneg_nonneg
thf(fact_1000_mult__nonneg__nonpos,axiom,
! [A: $tType] :
( ( ordered_semiring_0 @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ B2 ) @ ( zero_zero @ A ) ) ) ) ) ).
% mult_nonneg_nonpos
thf(fact_1001_mult__nonpos__nonneg,axiom,
! [A: $tType] :
( ( ordered_semiring_0 @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ B2 ) @ ( zero_zero @ A ) ) ) ) ) ).
% mult_nonpos_nonneg
thf(fact_1002_mult__nonneg__nonpos2,axiom,
! [A: $tType] :
( ( ordered_semiring_0 @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ B2 @ A3 ) @ ( zero_zero @ A ) ) ) ) ) ).
% mult_nonneg_nonpos2
thf(fact_1003_zero__le__mult__iff,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) )
= ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 ) )
| ( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) ) ) ) ) ) ).
% zero_le_mult_iff
thf(fact_1004_ordered__comm__semiring__class_Ocomm__mult__left__mono,axiom,
! [A: $tType] :
( ( ordere2520102378445227354miring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) ) ) ) ) ).
% ordered_comm_semiring_class.comm_mult_left_mono
thf(fact_1005_mult__neg__neg,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) ) ) ) ) ).
% mult_neg_neg
thf(fact_1006_not__square__less__zero,axiom,
! [A: $tType] :
( ( linordered_ring @ A )
=> ! [A3: A] :
~ ( ord_less @ A @ ( times_times @ A @ A3 @ A3 ) @ ( zero_zero @ A ) ) ) ).
% not_square_less_zero
thf(fact_1007_mult__less__0__iff,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( times_times @ A @ A3 @ B2 ) @ ( zero_zero @ A ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less @ A @ B2 @ ( zero_zero @ A ) ) )
| ( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less @ A @ ( zero_zero @ A ) @ B2 ) ) ) ) ) ).
% mult_less_0_iff
thf(fact_1008_mult__neg__pos,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ B2 ) @ ( zero_zero @ A ) ) ) ) ) ).
% mult_neg_pos
thf(fact_1009_mult__pos__neg,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ B2 ) @ ( zero_zero @ A ) ) ) ) ) ).
% mult_pos_neg
thf(fact_1010_mult__pos__pos,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) ) ) ) ) ).
% mult_pos_pos
thf(fact_1011_mult__pos__neg2,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( times_times @ A @ B2 @ A3 ) @ ( zero_zero @ A ) ) ) ) ) ).
% mult_pos_neg2
thf(fact_1012_zero__less__mult__iff,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less @ A @ ( zero_zero @ A ) @ B2 ) )
| ( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
& ( ord_less @ A @ B2 @ ( zero_zero @ A ) ) ) ) ) ) ).
% zero_less_mult_iff
thf(fact_1013_zero__less__mult__pos,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ B2 ) ) ) ) ).
% zero_less_mult_pos
thf(fact_1014_zero__less__mult__pos2,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( times_times @ A @ B2 @ A3 ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ B2 ) ) ) ) ).
% zero_less_mult_pos2
thf(fact_1015_mult__less__cancel__left__neg,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( ord_less @ A @ B2 @ A3 ) ) ) ) ).
% mult_less_cancel_left_neg
thf(fact_1016_mult__less__cancel__left__pos,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( ord_less @ A @ A3 @ B2 ) ) ) ) ).
% mult_less_cancel_left_pos
thf(fact_1017_mult__strict__left__mono__neg,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) ) ) ) ) ).
% mult_strict_left_mono_neg
thf(fact_1018_mult__strict__left__mono,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) ) ) ) ) ).
% mult_strict_left_mono
thf(fact_1019_mult__less__cancel__left__disj,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
& ( ord_less @ A @ A3 @ B2 ) )
| ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
& ( ord_less @ A @ B2 @ A3 ) ) ) ) ) ).
% mult_less_cancel_left_disj
thf(fact_1020_mult__strict__right__mono__neg,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) ) ) ) ) ).
% mult_strict_right_mono_neg
thf(fact_1021_mult__strict__right__mono,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) ) ) ) ) ).
% mult_strict_right_mono
thf(fact_1022_mult__less__cancel__right__disj,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
& ( ord_less @ A @ A3 @ B2 ) )
| ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
& ( ord_less @ A @ B2 @ A3 ) ) ) ) ) ).
% mult_less_cancel_right_disj
thf(fact_1023_linordered__comm__semiring__strict__class_Ocomm__mult__strict__left__mono,axiom,
! [A: $tType] :
( ( linord2810124833399127020strict @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) ) ) ) ) ).
% linordered_comm_semiring_strict_class.comm_mult_strict_left_mono
thf(fact_1024_add__scale__eq__noteq,axiom,
! [A: $tType] :
( ( semiri1453513574482234551roduct @ A )
=> ! [R2: A,A3: A,B2: A,C2: A,D2: A] :
( ( R2
!= ( zero_zero @ A ) )
=> ( ( ( A3 = B2 )
& ( C2 != D2 ) )
=> ( ( plus_plus @ A @ A3 @ ( times_times @ A @ R2 @ C2 ) )
!= ( plus_plus @ A @ B2 @ ( times_times @ A @ R2 @ D2 ) ) ) ) ) ) ).
% add_scale_eq_noteq
thf(fact_1025_less__1__mult,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [M: A,N2: A] :
( ( ord_less @ A @ ( one_one @ A ) @ M )
=> ( ( ord_less @ A @ ( one_one @ A ) @ N2 )
=> ( ord_less @ A @ ( one_one @ A ) @ ( times_times @ A @ M @ N2 ) ) ) ) ) ).
% less_1_mult
thf(fact_1026_nonzero__eq__divide__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( A3
= ( divide_divide @ A @ B2 @ C2 ) )
= ( ( times_times @ A @ A3 @ C2 )
= B2 ) ) ) ) ).
% nonzero_eq_divide_eq
thf(fact_1027_nonzero__divide__eq__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( ( divide_divide @ A @ B2 @ C2 )
= A3 )
= ( B2
= ( times_times @ A @ A3 @ C2 ) ) ) ) ) ).
% nonzero_divide_eq_eq
thf(fact_1028_eq__divide__imp,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( ( times_times @ A @ A3 @ C2 )
= B2 )
=> ( A3
= ( divide_divide @ A @ B2 @ C2 ) ) ) ) ) ).
% eq_divide_imp
thf(fact_1029_divide__eq__imp,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( B2
= ( times_times @ A @ A3 @ C2 ) )
=> ( ( divide_divide @ A @ B2 @ C2 )
= A3 ) ) ) ) ).
% divide_eq_imp
thf(fact_1030_eq__divide__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( A3
= ( divide_divide @ A @ B2 @ C2 ) )
= ( ( ( C2
!= ( zero_zero @ A ) )
=> ( ( times_times @ A @ A3 @ C2 )
= B2 ) )
& ( ( C2
= ( zero_zero @ A ) )
=> ( A3
= ( zero_zero @ A ) ) ) ) ) ) ).
% eq_divide_eq
thf(fact_1031_divide__eq__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ( divide_divide @ A @ B2 @ C2 )
= A3 )
= ( ( ( C2
!= ( zero_zero @ A ) )
=> ( B2
= ( times_times @ A @ A3 @ C2 ) ) )
& ( ( C2
= ( zero_zero @ A ) )
=> ( A3
= ( zero_zero @ A ) ) ) ) ) ) ).
% divide_eq_eq
thf(fact_1032_frac__eq__eq,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [Y: A,Z: A,X: A,W2: A] :
( ( Y
!= ( zero_zero @ A ) )
=> ( ( Z
!= ( zero_zero @ A ) )
=> ( ( ( divide_divide @ A @ X @ Y )
= ( divide_divide @ A @ W2 @ Z ) )
= ( ( times_times @ A @ X @ Z )
= ( times_times @ A @ W2 @ Y ) ) ) ) ) ) ).
% frac_eq_eq
thf(fact_1033_power__Suc2,axiom,
! [A: $tType] :
( ( monoid_mult @ A )
=> ! [A3: A,N2: nat] :
( ( power_power @ A @ A3 @ ( suc @ N2 ) )
= ( times_times @ A @ ( power_power @ A @ A3 @ N2 ) @ A3 ) ) ) ).
% power_Suc2
thf(fact_1034_power__Suc,axiom,
! [A: $tType] :
( ( power @ A )
=> ! [A3: A,N2: nat] :
( ( power_power @ A @ A3 @ ( suc @ N2 ) )
= ( times_times @ A @ A3 @ ( power_power @ A @ A3 @ N2 ) ) ) ) ).
% power_Suc
thf(fact_1035_Suc__mult__less__cancel1,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ ( times_times @ nat @ ( suc @ K ) @ M ) @ ( times_times @ nat @ ( suc @ K ) @ N2 ) )
= ( ord_less @ nat @ M @ N2 ) ) ).
% Suc_mult_less_cancel1
thf(fact_1036_power__add,axiom,
! [A: $tType] :
( ( monoid_mult @ A )
=> ! [A3: A,M: nat,N2: nat] :
( ( power_power @ A @ A3 @ ( plus_plus @ nat @ M @ N2 ) )
= ( times_times @ A @ ( power_power @ A @ A3 @ M ) @ ( power_power @ A @ A3 @ N2 ) ) ) ) ).
% power_add
thf(fact_1037_mult__less__mono1,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less @ nat @ I @ J )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ord_less @ nat @ ( times_times @ nat @ I @ K ) @ ( times_times @ nat @ J @ K ) ) ) ) ).
% mult_less_mono1
thf(fact_1038_mult__less__mono2,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less @ nat @ I @ J )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ord_less @ nat @ ( times_times @ nat @ K @ I ) @ ( times_times @ nat @ K @ J ) ) ) ) ).
% mult_less_mono2
thf(fact_1039_Suc__mult__le__cancel1,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( times_times @ nat @ ( suc @ K ) @ M ) @ ( times_times @ nat @ ( suc @ K ) @ N2 ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ).
% Suc_mult_le_cancel1
thf(fact_1040_mult__Suc,axiom,
! [M: nat,N2: nat] :
( ( times_times @ nat @ ( suc @ M ) @ N2 )
= ( plus_plus @ nat @ N2 @ ( times_times @ nat @ M @ N2 ) ) ) ).
% mult_Suc
thf(fact_1041_mult__eq__self__implies__10,axiom,
! [M: nat,N2: nat] :
( ( M
= ( times_times @ nat @ M @ N2 ) )
=> ( ( N2
= ( one_one @ nat ) )
| ( M
= ( zero_zero @ nat ) ) ) ) ).
% mult_eq_self_implies_10
thf(fact_1042_less__mult__imp__div__less,axiom,
! [M: nat,I: nat,N2: nat] :
( ( ord_less @ nat @ M @ ( times_times @ nat @ I @ N2 ) )
=> ( ord_less @ nat @ ( divide_divide @ nat @ M @ N2 ) @ I ) ) ).
% less_mult_imp_div_less
thf(fact_1043_times__div__less__eq__dividend,axiom,
! [N2: nat,M: nat] : ( ord_less_eq @ nat @ ( times_times @ nat @ N2 @ ( divide_divide @ nat @ M @ N2 ) ) @ M ) ).
% times_div_less_eq_dividend
thf(fact_1044_div__times__less__eq__dividend,axiom,
! [M: nat,N2: nat] : ( ord_less_eq @ nat @ ( times_times @ nat @ ( divide_divide @ nat @ M @ N2 ) @ N2 ) @ M ) ).
% div_times_less_eq_dividend
thf(fact_1045_power__odd__eq,axiom,
! [A: $tType] :
( ( monoid_mult @ A )
=> ! [A3: A,N2: nat] :
( ( power_power @ A @ A3 @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) )
= ( times_times @ A @ A3 @ ( power_power @ A @ ( power_power @ A @ A3 @ N2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ).
% power_odd_eq
thf(fact_1046_double__not__eq__Suc__double,axiom,
! [M: nat,N2: nat] :
( ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M )
!= ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) ).
% double_not_eq_Suc_double
thf(fact_1047_Suc__double__not__eq__double,axiom,
! [M: nat,N2: nat] :
( ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) )
!= ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ).
% Suc_double_not_eq_double
thf(fact_1048_mult__le__cancel__left,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ A3 @ B2 ) )
& ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ) ).
% mult_le_cancel_left
thf(fact_1049_mult__le__cancel__right,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ A3 @ B2 ) )
& ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ) ).
% mult_le_cancel_right
thf(fact_1050_mult__left__less__imp__less,axiom,
! [A: $tType] :
( ( linordered_semiring @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ A3 @ B2 ) ) ) ) ).
% mult_left_less_imp_less
thf(fact_1051_mult__strict__mono,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ C2 @ D2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ D2 ) ) ) ) ) ) ) ).
% mult_strict_mono
thf(fact_1052_mult__less__cancel__left,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ A3 @ B2 ) )
& ( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ B2 @ A3 ) ) ) ) ) ).
% mult_less_cancel_left
thf(fact_1053_mult__right__less__imp__less,axiom,
! [A: $tType] :
( ( linordered_semiring @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ A3 @ B2 ) ) ) ) ).
% mult_right_less_imp_less
thf(fact_1054_mult__strict__mono_H,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ C2 @ D2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ D2 ) ) ) ) ) ) ) ).
% mult_strict_mono'
thf(fact_1055_mult__less__cancel__right,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) )
= ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ A3 @ B2 ) )
& ( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ B2 @ A3 ) ) ) ) ) ).
% mult_less_cancel_right
thf(fact_1056_mult__le__cancel__left__neg,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ).
% mult_le_cancel_left_neg
thf(fact_1057_mult__le__cancel__left__pos,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less_eq @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ).
% mult_le_cancel_left_pos
thf(fact_1058_mult__left__le__imp__le,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ).
% mult_left_le_imp_le
thf(fact_1059_mult__right__le__imp__le,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ).
% mult_right_le_imp_le
thf(fact_1060_mult__le__less__imp__less,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ C2 @ D2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ D2 ) ) ) ) ) ) ) ).
% mult_le_less_imp_less
thf(fact_1061_mult__less__le__imp__less,axiom,
! [A: $tType] :
( ( linord8928482502909563296strict @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ D2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ D2 ) ) ) ) ) ) ) ).
% mult_less_le_imp_less
thf(fact_1062_mult__left__le__one__le,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( ( ord_less_eq @ A @ Y @ ( one_one @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ Y @ X ) @ X ) ) ) ) ) ).
% mult_left_le_one_le
thf(fact_1063_mult__right__le__one__le,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( ( ord_less_eq @ A @ Y @ ( one_one @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ X @ Y ) @ X ) ) ) ) ) ).
% mult_right_le_one_le
thf(fact_1064_mult__le__one,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ ( one_one @ A ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less_eq @ A @ B2 @ ( one_one @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ B2 ) @ ( one_one @ A ) ) ) ) ) ) ).
% mult_le_one
thf(fact_1065_mult__left__le,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [C2: A,A3: A] :
( ( ord_less_eq @ A @ C2 @ ( one_one @ A ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ A3 ) ) ) ) ).
% mult_left_le
thf(fact_1066_sum__squares__le__zero__iff,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ ( times_times @ A @ X @ X ) @ ( times_times @ A @ Y @ Y ) ) @ ( zero_zero @ A ) )
= ( ( X
= ( zero_zero @ A ) )
& ( Y
= ( zero_zero @ A ) ) ) ) ) ).
% sum_squares_le_zero_iff
thf(fact_1067_sum__squares__ge__zero,axiom,
! [A: $tType] :
( ( linordered_ring @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ ( times_times @ A @ X @ X ) @ ( times_times @ A @ Y @ Y ) ) ) ) ).
% sum_squares_ge_zero
thf(fact_1068_sum__squares__gt__zero__iff,axiom,
! [A: $tType] :
( ( linord4710134922213307826strict @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ ( times_times @ A @ X @ X ) @ ( times_times @ A @ Y @ Y ) ) )
= ( ( X
!= ( zero_zero @ A ) )
| ( Y
!= ( zero_zero @ A ) ) ) ) ) ).
% sum_squares_gt_zero_iff
thf(fact_1069_not__sum__squares__lt__zero,axiom,
! [A: $tType] :
( ( linordered_ring @ A )
=> ! [X: A,Y: A] :
~ ( ord_less @ A @ ( plus_plus @ A @ ( times_times @ A @ X @ X ) @ ( times_times @ A @ Y @ Y ) ) @ ( zero_zero @ A ) ) ) ).
% not_sum_squares_lt_zero
thf(fact_1070_divide__less__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less @ A @ ( divide_divide @ A @ B2 @ C2 ) @ A3 )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ B2 @ ( times_times @ A @ A3 @ C2 ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ) ) ) ) ).
% divide_less_eq
thf(fact_1071_less__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ B2 @ ( times_times @ A @ A3 @ C2 ) ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ) ) ) ) ).
% less_divide_eq
thf(fact_1072_neg__divide__less__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( divide_divide @ A @ B2 @ C2 ) @ A3 )
= ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 ) ) ) ) ).
% neg_divide_less_eq
thf(fact_1073_neg__less__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ord_less @ A @ B2 @ ( times_times @ A @ A3 @ C2 ) ) ) ) ) ).
% neg_less_divide_eq
thf(fact_1074_pos__divide__less__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less @ A @ ( divide_divide @ A @ B2 @ C2 ) @ A3 )
= ( ord_less @ A @ B2 @ ( times_times @ A @ A3 @ C2 ) ) ) ) ) ).
% pos_divide_less_eq
thf(fact_1075_pos__less__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 ) ) ) ) ).
% pos_less_divide_eq
thf(fact_1076_mult__imp__div__pos__less,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [Y: A,X: A,Z: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Y )
=> ( ( ord_less @ A @ X @ ( times_times @ A @ Z @ Y ) )
=> ( ord_less @ A @ ( divide_divide @ A @ X @ Y ) @ Z ) ) ) ) ).
% mult_imp_div_pos_less
thf(fact_1077_mult__imp__less__div__pos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [Y: A,Z: A,X: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Y )
=> ( ( ord_less @ A @ ( times_times @ A @ Z @ Y ) @ X )
=> ( ord_less @ A @ Z @ ( divide_divide @ A @ X @ Y ) ) ) ) ) ).
% mult_imp_less_div_pos
thf(fact_1078_divide__strict__left__mono,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) )
=> ( ord_less @ A @ ( divide_divide @ A @ C2 @ A3 ) @ ( divide_divide @ A @ C2 @ B2 ) ) ) ) ) ) ).
% divide_strict_left_mono
thf(fact_1079_divide__strict__left__mono__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) )
=> ( ord_less @ A @ ( divide_divide @ A @ C2 @ A3 ) @ ( divide_divide @ A @ C2 @ B2 ) ) ) ) ) ) ).
% divide_strict_left_mono_neg
thf(fact_1080_eq__divide__eq__numeral_I1_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [W2: num,B2: A,C2: A] :
( ( ( numeral_numeral @ A @ W2 )
= ( divide_divide @ A @ B2 @ C2 ) )
= ( ( ( C2
!= ( zero_zero @ A ) )
=> ( ( times_times @ A @ ( numeral_numeral @ A @ W2 ) @ C2 )
= B2 ) )
& ( ( C2
= ( zero_zero @ A ) )
=> ( ( numeral_numeral @ A @ W2 )
= ( zero_zero @ A ) ) ) ) ) ) ).
% eq_divide_eq_numeral(1)
thf(fact_1081_divide__eq__eq__numeral_I1_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [B2: A,C2: A,W2: num] :
( ( ( divide_divide @ A @ B2 @ C2 )
= ( numeral_numeral @ A @ W2 ) )
= ( ( ( C2
!= ( zero_zero @ A ) )
=> ( B2
= ( times_times @ A @ ( numeral_numeral @ A @ W2 ) @ C2 ) ) )
& ( ( C2
= ( zero_zero @ A ) )
=> ( ( numeral_numeral @ A @ W2 )
= ( zero_zero @ A ) ) ) ) ) ) ).
% divide_eq_eq_numeral(1)
thf(fact_1082_divide__add__eq__iff,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,X: A,Y: A] :
( ( Z
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( divide_divide @ A @ X @ Z ) @ Y )
= ( divide_divide @ A @ ( plus_plus @ A @ X @ ( times_times @ A @ Y @ Z ) ) @ Z ) ) ) ) ).
% divide_add_eq_iff
thf(fact_1083_add__divide__eq__iff,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,X: A,Y: A] :
( ( Z
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ X @ ( divide_divide @ A @ Y @ Z ) )
= ( divide_divide @ A @ ( plus_plus @ A @ ( times_times @ A @ X @ Z ) @ Y ) @ Z ) ) ) ) ).
% add_divide_eq_iff
thf(fact_1084_add__num__frac,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [Y: A,Z: A,X: A] :
( ( Y
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ Z @ ( divide_divide @ A @ X @ Y ) )
= ( divide_divide @ A @ ( plus_plus @ A @ X @ ( times_times @ A @ Z @ Y ) ) @ Y ) ) ) ) ).
% add_num_frac
thf(fact_1085_add__frac__num,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [Y: A,X: A,Z: A] :
( ( Y
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( divide_divide @ A @ X @ Y ) @ Z )
= ( divide_divide @ A @ ( plus_plus @ A @ X @ ( times_times @ A @ Z @ Y ) ) @ Y ) ) ) ) ).
% add_frac_num
thf(fact_1086_add__frac__eq,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [Y: A,Z: A,X: A,W2: A] :
( ( Y
!= ( zero_zero @ A ) )
=> ( ( Z
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( divide_divide @ A @ X @ Y ) @ ( divide_divide @ A @ W2 @ Z ) )
= ( divide_divide @ A @ ( plus_plus @ A @ ( times_times @ A @ X @ Z ) @ ( times_times @ A @ W2 @ Y ) ) @ ( times_times @ A @ Y @ Z ) ) ) ) ) ) ).
% add_frac_eq
thf(fact_1087_add__divide__eq__if__simps_I1_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,A3: A,B2: A] :
( ( ( Z
= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ A3 @ ( divide_divide @ A @ B2 @ Z ) )
= A3 ) )
& ( ( Z
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ A3 @ ( divide_divide @ A @ B2 @ Z ) )
= ( divide_divide @ A @ ( plus_plus @ A @ ( times_times @ A @ A3 @ Z ) @ B2 ) @ Z ) ) ) ) ) ).
% add_divide_eq_if_simps(1)
thf(fact_1088_add__divide__eq__if__simps_I2_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,A3: A,B2: A] :
( ( ( Z
= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( divide_divide @ A @ A3 @ Z ) @ B2 )
= B2 ) )
& ( ( Z
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( divide_divide @ A @ A3 @ Z ) @ B2 )
= ( divide_divide @ A @ ( plus_plus @ A @ A3 @ ( times_times @ A @ B2 @ Z ) ) @ Z ) ) ) ) ) ).
% add_divide_eq_if_simps(2)
thf(fact_1089_power__less__power__Suc,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less @ A @ ( one_one @ A ) @ A3 )
=> ( ord_less @ A @ ( power_power @ A @ A3 @ N2 ) @ ( times_times @ A @ A3 @ ( power_power @ A @ A3 @ N2 ) ) ) ) ) ).
% power_less_power_Suc
thf(fact_1090_power__gt1__lemma,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less @ A @ ( one_one @ A ) @ A3 )
=> ( ord_less @ A @ ( one_one @ A ) @ ( times_times @ A @ A3 @ ( power_power @ A @ A3 @ N2 ) ) ) ) ) ).
% power_gt1_lemma
thf(fact_1091_one__less__mult,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
=> ( ( ord_less @ nat @ ( suc @ ( zero_zero @ nat ) ) @ M )
=> ( ord_less @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( times_times @ nat @ M @ N2 ) ) ) ) ).
% one_less_mult
thf(fact_1092_n__less__m__mult__n,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ nat @ ( suc @ ( zero_zero @ nat ) ) @ M )
=> ( ord_less @ nat @ N2 @ ( times_times @ nat @ M @ N2 ) ) ) ) ).
% n_less_m_mult_n
thf(fact_1093_n__less__n__mult__m,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ nat @ ( suc @ ( zero_zero @ nat ) ) @ M )
=> ( ord_less @ nat @ N2 @ ( times_times @ nat @ N2 @ M ) ) ) ) ).
% n_less_n_mult_m
thf(fact_1094_div__less__iff__less__mult,axiom,
! [Q2: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ Q2 )
=> ( ( ord_less @ nat @ ( divide_divide @ nat @ M @ Q2 ) @ N2 )
= ( ord_less @ nat @ M @ ( times_times @ nat @ N2 @ Q2 ) ) ) ) ).
% div_less_iff_less_mult
thf(fact_1095_realpow__pos__nth2,axiom,
! [A3: real,N2: nat] :
( ( ord_less @ real @ ( zero_zero @ real ) @ A3 )
=> ? [R3: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ R3 )
& ( ( power_power @ real @ R3 @ ( suc @ N2 ) )
= A3 ) ) ) ).
% realpow_pos_nth2
thf(fact_1096_mult__le__cancel__left1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [C2: A,B2: A] :
( ( ord_less_eq @ A @ C2 @ ( times_times @ A @ C2 @ B2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( one_one @ A ) @ B2 ) )
& ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ B2 @ ( one_one @ A ) ) ) ) ) ) ).
% mult_le_cancel_left1
thf(fact_1097_mult__le__cancel__left2,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [C2: A,A3: A] :
( ( ord_less_eq @ A @ ( times_times @ A @ C2 @ A3 ) @ C2 )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ A3 @ ( one_one @ A ) ) )
& ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( one_one @ A ) @ A3 ) ) ) ) ) ).
% mult_le_cancel_left2
thf(fact_1098_mult__le__cancel__right1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [C2: A,B2: A] :
( ( ord_less_eq @ A @ C2 @ ( times_times @ A @ B2 @ C2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( one_one @ A ) @ B2 ) )
& ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ B2 @ ( one_one @ A ) ) ) ) ) ) ).
% mult_le_cancel_right1
thf(fact_1099_mult__le__cancel__right2,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,C2: A] :
( ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ C2 )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ A3 @ ( one_one @ A ) ) )
& ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( one_one @ A ) @ A3 ) ) ) ) ) ).
% mult_le_cancel_right2
thf(fact_1100_mult__less__cancel__left1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [C2: A,B2: A] :
( ( ord_less @ A @ C2 @ ( times_times @ A @ C2 @ B2 ) )
= ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( one_one @ A ) @ B2 ) )
& ( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ B2 @ ( one_one @ A ) ) ) ) ) ) ).
% mult_less_cancel_left1
thf(fact_1101_mult__less__cancel__left2,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [C2: A,A3: A] :
( ( ord_less @ A @ ( times_times @ A @ C2 @ A3 ) @ C2 )
= ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ A3 @ ( one_one @ A ) ) )
& ( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( one_one @ A ) @ A3 ) ) ) ) ) ).
% mult_less_cancel_left2
thf(fact_1102_mult__less__cancel__right1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [C2: A,B2: A] :
( ( ord_less @ A @ C2 @ ( times_times @ A @ B2 @ C2 ) )
= ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( one_one @ A ) @ B2 ) )
& ( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ B2 @ ( one_one @ A ) ) ) ) ) ) ).
% mult_less_cancel_right1
thf(fact_1103_mult__less__cancel__right2,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,C2: A] :
( ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ C2 )
= ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ A3 @ ( one_one @ A ) ) )
& ( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( one_one @ A ) @ A3 ) ) ) ) ) ).
% mult_less_cancel_right2
thf(fact_1104_field__le__mult__one__interval,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] :
( ! [Z2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Z2 )
=> ( ( ord_less @ A @ Z2 @ ( one_one @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ Z2 @ X ) @ Y ) ) )
=> ( ord_less_eq @ A @ X @ Y ) ) ) ).
% field_le_mult_one_interval
thf(fact_1105_divide__le__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less_eq @ A @ ( divide_divide @ A @ B2 @ C2 ) @ A3 )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ B2 @ ( times_times @ A @ A3 @ C2 ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ) ) ) ) ).
% divide_le_eq
thf(fact_1106_le__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ B2 @ ( times_times @ A @ A3 @ C2 ) ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) ) ) ) ) ) ) ).
% le_divide_eq
thf(fact_1107_divide__left__mono,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) )
=> ( ord_less_eq @ A @ ( divide_divide @ A @ C2 @ A3 ) @ ( divide_divide @ A @ C2 @ B2 ) ) ) ) ) ) ).
% divide_left_mono
thf(fact_1108_neg__divide__le__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ ( divide_divide @ A @ B2 @ C2 ) @ A3 )
= ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 ) ) ) ) ).
% neg_divide_le_eq
thf(fact_1109_neg__le__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ord_less_eq @ A @ B2 @ ( times_times @ A @ A3 @ C2 ) ) ) ) ) ).
% neg_le_divide_eq
thf(fact_1110_pos__divide__le__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less_eq @ A @ ( divide_divide @ A @ B2 @ C2 ) @ A3 )
= ( ord_less_eq @ A @ B2 @ ( times_times @ A @ A3 @ C2 ) ) ) ) ) ).
% pos_divide_le_eq
thf(fact_1111_pos__le__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less_eq @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 ) ) ) ) ).
% pos_le_divide_eq
thf(fact_1112_mult__imp__div__pos__le,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [Y: A,X: A,Z: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Y )
=> ( ( ord_less_eq @ A @ X @ ( times_times @ A @ Z @ Y ) )
=> ( ord_less_eq @ A @ ( divide_divide @ A @ X @ Y ) @ Z ) ) ) ) ).
% mult_imp_div_pos_le
thf(fact_1113_mult__imp__le__div__pos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [Y: A,Z: A,X: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Y )
=> ( ( ord_less_eq @ A @ ( times_times @ A @ Z @ Y ) @ X )
=> ( ord_less_eq @ A @ Z @ ( divide_divide @ A @ X @ Y ) ) ) ) ) ).
% mult_imp_le_div_pos
thf(fact_1114_divide__left__mono__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) )
=> ( ord_less_eq @ A @ ( divide_divide @ A @ C2 @ A3 ) @ ( divide_divide @ A @ C2 @ B2 ) ) ) ) ) ) ).
% divide_left_mono_neg
thf(fact_1115_convex__bound__le,axiom,
! [A: $tType] :
( ( linord6961819062388156250ring_1 @ A )
=> ! [X: A,A3: A,Y: A,U: A,V2: A] :
( ( ord_less_eq @ A @ X @ A3 )
=> ( ( ord_less_eq @ A @ Y @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ U )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ V2 )
=> ( ( ( plus_plus @ A @ U @ V2 )
= ( one_one @ A ) )
=> ( ord_less_eq @ A @ ( plus_plus @ A @ ( times_times @ A @ U @ X ) @ ( times_times @ A @ V2 @ Y ) ) @ A3 ) ) ) ) ) ) ) ).
% convex_bound_le
thf(fact_1116_divide__less__eq__numeral_I1_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,C2: A,W2: num] :
( ( ord_less @ A @ ( divide_divide @ A @ B2 @ C2 ) @ ( numeral_numeral @ A @ W2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ B2 @ ( times_times @ A @ ( numeral_numeral @ A @ W2 ) @ C2 ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( times_times @ A @ ( numeral_numeral @ A @ W2 ) @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ A @ W2 ) ) ) ) ) ) ) ) ).
% divide_less_eq_numeral(1)
thf(fact_1117_less__divide__eq__numeral_I1_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [W2: num,B2: A,C2: A] :
( ( ord_less @ A @ ( numeral_numeral @ A @ W2 ) @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( times_times @ A @ ( numeral_numeral @ A @ W2 ) @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ B2 @ ( times_times @ A @ ( numeral_numeral @ A @ W2 ) @ C2 ) ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( numeral_numeral @ A @ W2 ) @ ( zero_zero @ A ) ) ) ) ) ) ) ) ).
% less_divide_eq_numeral(1)
thf(fact_1118_power__Suc__less,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ A3 @ ( one_one @ A ) )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ ( power_power @ A @ A3 @ N2 ) ) @ ( power_power @ A @ A3 @ N2 ) ) ) ) ) ).
% power_Suc_less
thf(fact_1119_left__add__twice,axiom,
! [A: $tType] :
( ( semiring_numeral @ A )
=> ! [A3: A,B2: A] :
( ( plus_plus @ A @ A3 @ ( plus_plus @ A @ A3 @ B2 ) )
= ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) @ B2 ) ) ) ).
% left_add_twice
thf(fact_1120_mult__2__right,axiom,
! [A: $tType] :
( ( semiring_numeral @ A )
=> ! [Z: A] :
( ( times_times @ A @ Z @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( plus_plus @ A @ Z @ Z ) ) ) ).
% mult_2_right
thf(fact_1121_mult__2,axiom,
! [A: $tType] :
( ( semiring_numeral @ A )
=> ! [Z: A] :
( ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ Z )
= ( plus_plus @ A @ Z @ Z ) ) ) ).
% mult_2
thf(fact_1122_div__nat__eqI,axiom,
! [N2: nat,Q2: nat,M: nat] :
( ( ord_less_eq @ nat @ ( times_times @ nat @ N2 @ Q2 ) @ M )
=> ( ( ord_less @ nat @ M @ ( times_times @ nat @ N2 @ ( suc @ Q2 ) ) )
=> ( ( divide_divide @ nat @ M @ N2 )
= Q2 ) ) ) ).
% div_nat_eqI
thf(fact_1123_less__eq__div__iff__mult__less__eq,axiom,
! [Q2: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ Q2 )
=> ( ( ord_less_eq @ nat @ M @ ( divide_divide @ nat @ N2 @ Q2 ) )
= ( ord_less_eq @ nat @ ( times_times @ nat @ M @ Q2 ) @ N2 ) ) ) ).
% less_eq_div_iff_mult_less_eq
thf(fact_1124_split__div,axiom,
! [P2: nat > $o,M: nat,N2: nat] :
( ( P2 @ ( divide_divide @ nat @ M @ N2 ) )
= ( ( ( N2
= ( zero_zero @ nat ) )
=> ( P2 @ ( zero_zero @ nat ) ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ! [I5: nat,J3: nat] :
( ( ord_less @ nat @ J3 @ N2 )
=> ( ( M
= ( plus_plus @ nat @ ( times_times @ nat @ N2 @ I5 ) @ J3 ) )
=> ( P2 @ I5 ) ) ) ) ) ) ).
% split_div
thf(fact_1125_dividend__less__div__times,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less @ nat @ M @ ( plus_plus @ nat @ N2 @ ( times_times @ nat @ ( divide_divide @ nat @ M @ N2 ) @ N2 ) ) ) ) ).
% dividend_less_div_times
thf(fact_1126_dividend__less__times__div,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less @ nat @ M @ ( plus_plus @ nat @ N2 @ ( times_times @ nat @ N2 @ ( divide_divide @ nat @ M @ N2 ) ) ) ) ) ).
% dividend_less_times_div
thf(fact_1127_convex__bound__lt,axiom,
! [A: $tType] :
( ( linord715952674999750819strict @ A )
=> ! [X: A,A3: A,Y: A,U: A,V2: A] :
( ( ord_less @ A @ X @ A3 )
=> ( ( ord_less @ A @ Y @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ U )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ V2 )
=> ( ( ( plus_plus @ A @ U @ V2 )
= ( one_one @ A ) )
=> ( ord_less @ A @ ( plus_plus @ A @ ( times_times @ A @ U @ X ) @ ( times_times @ A @ V2 @ Y ) ) @ A3 ) ) ) ) ) ) ) ).
% convex_bound_lt
thf(fact_1128_divide__le__eq__numeral_I1_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,C2: A,W2: num] :
( ( ord_less_eq @ A @ ( divide_divide @ A @ B2 @ C2 ) @ ( numeral_numeral @ A @ W2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ B2 @ ( times_times @ A @ ( numeral_numeral @ A @ W2 ) @ C2 ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ ( numeral_numeral @ A @ W2 ) @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ A @ W2 ) ) ) ) ) ) ) ) ).
% divide_le_eq_numeral(1)
thf(fact_1129_le__divide__eq__numeral_I1_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [W2: num,B2: A,C2: A] :
( ( ord_less_eq @ A @ ( numeral_numeral @ A @ W2 ) @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( times_times @ A @ ( numeral_numeral @ A @ W2 ) @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ B2 @ ( times_times @ A @ ( numeral_numeral @ A @ W2 ) @ C2 ) ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( numeral_numeral @ A @ W2 ) @ ( zero_zero @ A ) ) ) ) ) ) ) ) ).
% le_divide_eq_numeral(1)
thf(fact_1130_sum__squares__bound,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ A @ ( times_times @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ X ) @ Y ) @ ( plus_plus @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ).
% sum_squares_bound
thf(fact_1131_split__div_H,axiom,
! [P2: nat > $o,M: nat,N2: nat] :
( ( P2 @ ( divide_divide @ nat @ M @ N2 ) )
= ( ( ( N2
= ( zero_zero @ nat ) )
& ( P2 @ ( zero_zero @ nat ) ) )
| ? [Q5: nat] :
( ( ord_less_eq @ nat @ ( times_times @ nat @ N2 @ Q5 ) @ M )
& ( ord_less @ nat @ M @ ( times_times @ nat @ N2 @ ( suc @ Q5 ) ) )
& ( P2 @ Q5 ) ) ) ) ).
% split_div'
thf(fact_1132_power2__sum,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [X: A,Y: A] :
( ( power_power @ A @ ( plus_plus @ A @ X @ Y ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( plus_plus @ A @ ( plus_plus @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( times_times @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ X ) @ Y ) ) ) ) ).
% power2_sum
thf(fact_1133_zero__le__even__power_H,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,N2: nat] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ).
% zero_le_even_power'
thf(fact_1134_nat__bit__induct,axiom,
! [P2: nat > $o,N2: nat] :
( ( P2 @ ( zero_zero @ nat ) )
=> ( ! [N3: nat] :
( ( P2 @ N3 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 )
=> ( P2 @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N3 ) ) ) )
=> ( ! [N3: nat] :
( ( P2 @ N3 )
=> ( P2 @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N3 ) ) ) )
=> ( P2 @ N2 ) ) ) ) ).
% nat_bit_induct
thf(fact_1135_arith__geo__mean,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [U: A,X: A,Y: A] :
( ( ( power_power @ A @ U @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( times_times @ A @ X @ Y ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( ord_less_eq @ A @ U @ ( divide_divide @ A @ ( plus_plus @ A @ X @ Y ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% arith_geo_mean
thf(fact_1136_triangle__def,axiom,
( nat_triangle
= ( ^ [N: nat] : ( divide_divide @ nat @ ( times_times @ nat @ N @ ( suc @ N ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ).
% triangle_def
thf(fact_1137_realpow__pos__nth,axiom,
! [N2: nat,A3: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ A3 )
=> ? [R3: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ R3 )
& ( ( power_power @ real @ R3 @ N2 )
= A3 ) ) ) ) ).
% realpow_pos_nth
thf(fact_1138_realpow__pos__nth__unique,axiom,
! [N2: nat,A3: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ A3 )
=> ? [X5: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ X5 )
& ( ( power_power @ real @ X5 @ N2 )
= A3 )
& ! [Y3: real] :
( ( ( ord_less @ real @ ( zero_zero @ real ) @ Y3 )
& ( ( power_power @ real @ Y3 @ N2 )
= A3 ) )
=> ( Y3 = X5 ) ) ) ) ) ).
% realpow_pos_nth_unique
thf(fact_1139_odd__0__le__power__imp__0__le,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% odd_0_le_power_imp_0_le
thf(fact_1140_odd__power__less__zero,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( power_power @ A @ A3 @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) @ ( zero_zero @ A ) ) ) ) ).
% odd_power_less_zero
thf(fact_1141_nat__mult__le__cancel__disj,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) )
= ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ord_less_eq @ nat @ M @ N2 ) ) ) ).
% nat_mult_le_cancel_disj
thf(fact_1142_nat__mult__div__cancel__disj,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ( K
= ( zero_zero @ nat ) )
=> ( ( divide_divide @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) )
= ( zero_zero @ nat ) ) )
& ( ( K
!= ( zero_zero @ nat ) )
=> ( ( divide_divide @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) )
= ( divide_divide @ nat @ M @ N2 ) ) ) ) ).
% nat_mult_div_cancel_disj
thf(fact_1143_nat__mult__less__cancel__disj,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) )
= ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
& ( ord_less @ nat @ M @ N2 ) ) ) ).
% nat_mult_less_cancel_disj
thf(fact_1144_set__bit__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se5668285175392031749et_bit @ A @ ( zero_zero @ nat ) @ A3 )
= ( plus_plus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ).
% set_bit_0
thf(fact_1145_unset__bit__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se2638667681897837118et_bit @ A @ ( zero_zero @ nat ) @ A3 )
= ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% unset_bit_0
thf(fact_1146_nat__mult__div__cancel1,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ( divide_divide @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) )
= ( divide_divide @ nat @ M @ N2 ) ) ) ).
% nat_mult_div_cancel1
thf(fact_1147_nat__mult__le__cancel1,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ( ord_less_eq @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ) ).
% nat_mult_le_cancel1
thf(fact_1148_mult__le__cancel__iff1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: A,X: A,Y: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Z )
=> ( ( ord_less_eq @ A @ ( times_times @ A @ X @ Z ) @ ( times_times @ A @ Y @ Z ) )
= ( ord_less_eq @ A @ X @ Y ) ) ) ) ).
% mult_le_cancel_iff1
thf(fact_1149_mult__le__cancel__iff2,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: A,X: A,Y: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Z )
=> ( ( ord_less_eq @ A @ ( times_times @ A @ Z @ X ) @ ( times_times @ A @ Z @ Y ) )
= ( ord_less_eq @ A @ X @ Y ) ) ) ) ).
% mult_le_cancel_iff2
thf(fact_1150_nat__mult__eq__cancel__disj,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ( times_times @ nat @ K @ M )
= ( times_times @ nat @ K @ N2 ) )
= ( ( K
= ( zero_zero @ nat ) )
| ( M = N2 ) ) ) ).
% nat_mult_eq_cancel_disj
thf(fact_1151_left__add__mult__distrib,axiom,
! [I: nat,U: nat,J: nat,K: nat] :
( ( plus_plus @ nat @ ( times_times @ nat @ I @ U ) @ ( plus_plus @ nat @ ( times_times @ nat @ J @ U ) @ K ) )
= ( plus_plus @ nat @ ( times_times @ nat @ ( plus_plus @ nat @ I @ J ) @ U ) @ K ) ) ).
% left_add_mult_distrib
thf(fact_1152_mult__less__iff1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: A,X: A,Y: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Z )
=> ( ( ord_less @ A @ ( times_times @ A @ X @ Z ) @ ( times_times @ A @ Y @ Z ) )
= ( ord_less @ A @ X @ Y ) ) ) ) ).
% mult_less_iff1
thf(fact_1153_nat__mult__less__cancel1,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ( ord_less @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) )
= ( ord_less @ nat @ M @ N2 ) ) ) ).
% nat_mult_less_cancel1
thf(fact_1154_nat__mult__eq__cancel1,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ( ( times_times @ nat @ K @ M )
= ( times_times @ nat @ K @ N2 ) )
= ( M = N2 ) ) ) ).
% nat_mult_eq_cancel1
thf(fact_1155_divides__aux__eq,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [Q2: A,R2: A] :
( ( unique5940410009612947441es_aux @ A @ ( product_Pair @ A @ A @ Q2 @ R2 ) )
= ( R2
= ( zero_zero @ A ) ) ) ) ).
% divides_aux_eq
thf(fact_1156_low__def,axiom,
( vEBT_VEBT_low
= ( ^ [X2: nat,N: nat] : ( modulo_modulo @ nat @ X2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) ) ) ) ).
% low_def
thf(fact_1157_invar__vebt_Ointros_I3_J,axiom,
! [TreeList2: list @ vEBT_VEBT,N2: nat,Summary: vEBT_VEBT,M: nat,Deg: nat] :
( ! [X5: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X5 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ( vEBT_invar_vebt @ X5 @ N2 ) )
=> ( ( vEBT_invar_vebt @ Summary @ M )
=> ( ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) )
=> ( ( M
= ( suc @ N2 ) )
=> ( ( Deg
= ( plus_plus @ nat @ N2 @ M ) )
=> ( ~ ? [X_12: nat] : ( vEBT_V8194947554948674370ptions @ Summary @ X_12 )
=> ( ! [X5: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X5 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ~ ? [X_12: nat] : ( vEBT_V8194947554948674370ptions @ X5 @ X_12 ) )
=> ( vEBT_invar_vebt @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Deg @ TreeList2 @ Summary ) @ Deg ) ) ) ) ) ) ) ) ).
% invar_vebt.intros(3)
thf(fact_1158_invar__vebt_Ointros_I2_J,axiom,
! [TreeList2: list @ vEBT_VEBT,N2: nat,Summary: vEBT_VEBT,M: nat,Deg: nat] :
( ! [X5: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X5 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ( vEBT_invar_vebt @ X5 @ N2 ) )
=> ( ( vEBT_invar_vebt @ Summary @ M )
=> ( ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) )
=> ( ( M = N2 )
=> ( ( Deg
= ( plus_plus @ nat @ N2 @ M ) )
=> ( ~ ? [X_12: nat] : ( vEBT_V8194947554948674370ptions @ Summary @ X_12 )
=> ( ! [X5: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X5 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ~ ? [X_12: nat] : ( vEBT_V8194947554948674370ptions @ X5 @ X_12 ) )
=> ( vEBT_invar_vebt @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Deg @ TreeList2 @ Summary ) @ Deg ) ) ) ) ) ) ) ) ).
% invar_vebt.intros(2)
thf(fact_1159_even__succ__div__exp,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,N2: nat] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ ( one_one @ A ) @ A3 ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( divide_divide @ A @ A3 @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ) ) ).
% even_succ_div_exp
thf(fact_1160_set__decode__Suc,axiom,
! [N2: nat,X: nat] :
( ( member2 @ nat @ ( suc @ N2 ) @ ( nat_set_decode @ X ) )
= ( member2 @ nat @ N2 @ ( nat_set_decode @ ( divide_divide @ nat @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ).
% set_decode_Suc
thf(fact_1161_length__product,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B] :
( ( size_size @ ( list @ ( product_prod @ A @ B ) ) @ ( product @ A @ B @ Xs @ Ys ) )
= ( times_times @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ B ) @ Ys ) ) ) ).
% length_product
thf(fact_1162_num_Osize__gen_I2_J,axiom,
! [X22: num] :
( ( size_num @ ( bit0 @ X22 ) )
= ( plus_plus @ nat @ ( size_num @ X22 ) @ ( suc @ ( zero_zero @ nat ) ) ) ) ).
% num.size_gen(2)
thf(fact_1163_Leaf__0__not,axiom,
! [A3: $o,B2: $o] :
~ ( vEBT_invar_vebt @ ( vEBT_Leaf @ A3 @ B2 ) @ ( zero_zero @ nat ) ) ).
% Leaf_0_not
thf(fact_1164_deg1Leaf,axiom,
! [T2: vEBT_VEBT] :
( ( vEBT_invar_vebt @ T2 @ ( one_one @ nat ) )
= ( ? [A5: $o,B4: $o] :
( T2
= ( vEBT_Leaf @ A5 @ B4 ) ) ) ) ).
% deg1Leaf
thf(fact_1165_deg__1__Leaf,axiom,
! [T2: vEBT_VEBT] :
( ( vEBT_invar_vebt @ T2 @ ( one_one @ nat ) )
=> ? [A7: $o,B5: $o] :
( T2
= ( vEBT_Leaf @ A7 @ B5 ) ) ) ).
% deg_1_Leaf
thf(fact_1166_deg__1__Leafy,axiom,
! [T2: vEBT_VEBT,N2: nat] :
( ( vEBT_invar_vebt @ T2 @ N2 )
=> ( ( N2
= ( one_one @ nat ) )
=> ? [A7: $o,B5: $o] :
( T2
= ( vEBT_Leaf @ A7 @ B5 ) ) ) ) ).
% deg_1_Leafy
thf(fact_1167_nat__dvd__1__iff__1,axiom,
! [M: nat] :
( ( dvd_dvd @ nat @ M @ ( one_one @ nat ) )
= ( M
= ( one_one @ nat ) ) ) ).
% nat_dvd_1_iff_1
thf(fact_1168_dvd__0__right,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A] : ( dvd_dvd @ A @ A3 @ ( zero_zero @ A ) ) ) ).
% dvd_0_right
thf(fact_1169_dvd__0__left__iff,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A] :
( ( dvd_dvd @ A @ ( zero_zero @ A ) @ A3 )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% dvd_0_left_iff
thf(fact_1170_dvd__add__triv__left__iff,axiom,
! [A: $tType] :
( ( comm_s4317794764714335236cancel @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ ( plus_plus @ A @ A3 @ B2 ) )
= ( dvd_dvd @ A @ A3 @ B2 ) ) ) ).
% dvd_add_triv_left_iff
thf(fact_1171_dvd__add__triv__right__iff,axiom,
! [A: $tType] :
( ( comm_s4317794764714335236cancel @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ ( plus_plus @ A @ B2 @ A3 ) )
= ( dvd_dvd @ A @ A3 @ B2 ) ) ) ).
% dvd_add_triv_right_iff
thf(fact_1172_dvd__1__iff__1,axiom,
! [M: nat] :
( ( dvd_dvd @ nat @ M @ ( suc @ ( zero_zero @ nat ) ) )
= ( M
= ( suc @ ( zero_zero @ nat ) ) ) ) ).
% dvd_1_iff_1
thf(fact_1173_dvd__1__left,axiom,
! [K: nat] : ( dvd_dvd @ nat @ ( suc @ ( zero_zero @ nat ) ) @ K ) ).
% dvd_1_left
thf(fact_1174_mod__0,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ! [A3: A] :
( ( modulo_modulo @ A @ ( zero_zero @ A ) @ A3 )
= ( zero_zero @ A ) ) ) ).
% mod_0
thf(fact_1175_mod__by__0,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ! [A3: A] :
( ( modulo_modulo @ A @ A3 @ ( zero_zero @ A ) )
= A3 ) ) ).
% mod_by_0
thf(fact_1176_mod__self,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ! [A3: A] :
( ( modulo_modulo @ A @ A3 @ A3 )
= ( zero_zero @ A ) ) ) ).
% mod_self
thf(fact_1177_bits__mod__0,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A] :
( ( modulo_modulo @ A @ ( zero_zero @ A ) @ A3 )
= ( zero_zero @ A ) ) ) ).
% bits_mod_0
thf(fact_1178_div__dvd__div,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( dvd_dvd @ A @ A3 @ C2 )
=> ( ( dvd_dvd @ A @ ( divide_divide @ A @ B2 @ A3 ) @ ( divide_divide @ A @ C2 @ A3 ) )
= ( dvd_dvd @ A @ B2 @ C2 ) ) ) ) ) ).
% div_dvd_div
thf(fact_1179_mod__add__self1,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [B2: A,A3: A] :
( ( modulo_modulo @ A @ ( plus_plus @ A @ B2 @ A3 ) @ B2 )
= ( modulo_modulo @ A @ A3 @ B2 ) ) ) ).
% mod_add_self1
thf(fact_1180_mod__add__self2,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [A3: A,B2: A] :
( ( modulo_modulo @ A @ ( plus_plus @ A @ A3 @ B2 ) @ B2 )
= ( modulo_modulo @ A @ A3 @ B2 ) ) ) ).
% mod_add_self2
thf(fact_1181_nat__mult__dvd__cancel__disj,axiom,
! [K: nat,M: nat,N2: nat] :
( ( dvd_dvd @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) )
= ( ( K
= ( zero_zero @ nat ) )
| ( dvd_dvd @ nat @ M @ N2 ) ) ) ).
% nat_mult_dvd_cancel_disj
thf(fact_1182_mod__less,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ( ( modulo_modulo @ nat @ M @ N2 )
= M ) ) ).
% mod_less
thf(fact_1183_not__None__eq,axiom,
! [A: $tType,X: option @ A] :
( ( X
!= ( none @ A ) )
= ( ? [Y2: A] :
( X
= ( some @ A @ Y2 ) ) ) ) ).
% not_None_eq
thf(fact_1184_not__Some__eq,axiom,
! [A: $tType,X: option @ A] :
( ( ! [Y2: A] :
( X
!= ( some @ A @ Y2 ) ) )
= ( X
= ( none @ A ) ) ) ).
% not_Some_eq
thf(fact_1185_dvd__times__right__cancel__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( dvd_dvd @ A @ ( times_times @ A @ B2 @ A3 ) @ ( times_times @ A @ C2 @ A3 ) )
= ( dvd_dvd @ A @ B2 @ C2 ) ) ) ) ).
% dvd_times_right_cancel_iff
thf(fact_1186_dvd__times__left__cancel__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( dvd_dvd @ A @ ( times_times @ A @ A3 @ B2 ) @ ( times_times @ A @ A3 @ C2 ) )
= ( dvd_dvd @ A @ B2 @ C2 ) ) ) ) ).
% dvd_times_left_cancel_iff
thf(fact_1187_dvd__mult__cancel__right,axiom,
! [A: $tType] :
( ( idom @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( dvd_dvd @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( dvd_dvd @ A @ A3 @ B2 ) ) ) ) ).
% dvd_mult_cancel_right
thf(fact_1188_dvd__mult__cancel__left,axiom,
! [A: $tType] :
( ( idom @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( dvd_dvd @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( dvd_dvd @ A @ A3 @ B2 ) ) ) ) ).
% dvd_mult_cancel_left
thf(fact_1189_unit__prod,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( dvd_dvd @ A @ ( times_times @ A @ A3 @ B2 ) @ ( one_one @ A ) ) ) ) ) ).
% unit_prod
thf(fact_1190_dvd__add__times__triv__left__iff,axiom,
! [A: $tType] :
( ( comm_s4317794764714335236cancel @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ ( plus_plus @ A @ ( times_times @ A @ C2 @ A3 ) @ B2 ) )
= ( dvd_dvd @ A @ A3 @ B2 ) ) ) ).
% dvd_add_times_triv_left_iff
thf(fact_1191_dvd__add__times__triv__right__iff,axiom,
! [A: $tType] :
( ( comm_s4317794764714335236cancel @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ A3 @ ( plus_plus @ A @ B2 @ ( times_times @ A @ C2 @ A3 ) ) )
= ( dvd_dvd @ A @ A3 @ B2 ) ) ) ).
% dvd_add_times_triv_right_iff
thf(fact_1192_mod__mult__self2__is__0,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [A3: A,B2: A] :
( ( modulo_modulo @ A @ ( times_times @ A @ A3 @ B2 ) @ B2 )
= ( zero_zero @ A ) ) ) ).
% mod_mult_self2_is_0
thf(fact_1193_mod__mult__self1__is__0,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [B2: A,A3: A] :
( ( modulo_modulo @ A @ ( times_times @ A @ B2 @ A3 ) @ B2 )
= ( zero_zero @ A ) ) ) ).
% mod_mult_self1_is_0
thf(fact_1194_mod__by__1,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ! [A3: A] :
( ( modulo_modulo @ A @ A3 @ ( one_one @ A ) )
= ( zero_zero @ A ) ) ) ).
% mod_by_1
thf(fact_1195_bits__mod__by__1,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A] :
( ( modulo_modulo @ A @ A3 @ ( one_one @ A ) )
= ( zero_zero @ A ) ) ) ).
% bits_mod_by_1
thf(fact_1196_dvd__mult__div__cancel,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( times_times @ A @ A3 @ ( divide_divide @ A @ B2 @ A3 ) )
= B2 ) ) ) ).
% dvd_mult_div_cancel
thf(fact_1197_dvd__div__mult__self,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( times_times @ A @ ( divide_divide @ A @ B2 @ A3 ) @ A3 )
= B2 ) ) ) ).
% dvd_div_mult_self
thf(fact_1198_unit__div__1__div__1,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( ( divide_divide @ A @ ( one_one @ A ) @ ( divide_divide @ A @ ( one_one @ A ) @ A3 ) )
= A3 ) ) ) ).
% unit_div_1_div_1
thf(fact_1199_unit__div__1__unit,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( dvd_dvd @ A @ ( divide_divide @ A @ ( one_one @ A ) @ A3 ) @ ( one_one @ A ) ) ) ) ).
% unit_div_1_unit
thf(fact_1200_unit__div,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( dvd_dvd @ A @ ( divide_divide @ A @ A3 @ B2 ) @ ( one_one @ A ) ) ) ) ) ).
% unit_div
thf(fact_1201_div__add,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( dvd_dvd @ A @ C2 @ A3 )
=> ( ( dvd_dvd @ A @ C2 @ B2 )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) ) ) ) ) ) ).
% div_add
thf(fact_1202_bits__mod__div__trivial,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,B2: A] :
( ( divide_divide @ A @ ( modulo_modulo @ A @ A3 @ B2 ) @ B2 )
= ( zero_zero @ A ) ) ) ).
% bits_mod_div_trivial
thf(fact_1203_mod__div__trivial,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [A3: A,B2: A] :
( ( divide_divide @ A @ ( modulo_modulo @ A @ A3 @ B2 ) @ B2 )
= ( zero_zero @ A ) ) ) ).
% mod_div_trivial
thf(fact_1204_mod__mult__self1,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( modulo_modulo @ A @ ( plus_plus @ A @ A3 @ ( times_times @ A @ C2 @ B2 ) ) @ B2 )
= ( modulo_modulo @ A @ A3 @ B2 ) ) ) ).
% mod_mult_self1
thf(fact_1205_mod__mult__self2,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( modulo_modulo @ A @ ( plus_plus @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) ) @ B2 )
= ( modulo_modulo @ A @ A3 @ B2 ) ) ) ).
% mod_mult_self2
thf(fact_1206_mod__mult__self3,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( modulo_modulo @ A @ ( plus_plus @ A @ ( times_times @ A @ C2 @ B2 ) @ A3 ) @ B2 )
= ( modulo_modulo @ A @ A3 @ B2 ) ) ) ).
% mod_mult_self3
thf(fact_1207_mod__mult__self4,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( modulo_modulo @ A @ ( plus_plus @ A @ ( times_times @ A @ B2 @ C2 ) @ A3 ) @ B2 )
= ( modulo_modulo @ A @ A3 @ B2 ) ) ) ).
% mod_mult_self4
thf(fact_1208_dvd__imp__mod__0,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( modulo_modulo @ A @ B2 @ A3 )
= ( zero_zero @ A ) ) ) ) ).
% dvd_imp_mod_0
thf(fact_1209_mod__by__Suc__0,axiom,
! [M: nat] :
( ( modulo_modulo @ nat @ M @ ( suc @ ( zero_zero @ nat ) ) )
= ( zero_zero @ nat ) ) ).
% mod_by_Suc_0
thf(fact_1210_set__decode__zero,axiom,
( ( nat_set_decode @ ( zero_zero @ nat ) )
= ( bot_bot @ ( set @ nat ) ) ) ).
% set_decode_zero
thf(fact_1211_unit__mult__div__div,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( ( times_times @ A @ B2 @ ( divide_divide @ A @ ( one_one @ A ) @ A3 ) )
= ( divide_divide @ A @ B2 @ A3 ) ) ) ) ).
% unit_mult_div_div
thf(fact_1212_unit__div__mult__self,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( ( times_times @ A @ ( divide_divide @ A @ B2 @ A3 ) @ A3 )
= B2 ) ) ) ).
% unit_div_mult_self
thf(fact_1213_even__Suc__Suc__iff,axiom,
! [N2: nat] :
( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ ( suc @ N2 ) ) )
= ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ).
% even_Suc_Suc_iff
thf(fact_1214_even__Suc,axiom,
! [N2: nat] :
( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ N2 ) )
= ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) ).
% even_Suc
thf(fact_1215_pow__divides__pow__iff,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [N2: nat,A3: A,B2: A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( dvd_dvd @ A @ ( power_power @ A @ A3 @ N2 ) @ ( power_power @ A @ B2 @ N2 ) )
= ( dvd_dvd @ A @ A3 @ B2 ) ) ) ) ).
% pow_divides_pow_iff
thf(fact_1216_Suc__mod__mult__self1,axiom,
! [M: nat,K: nat,N2: nat] :
( ( modulo_modulo @ nat @ ( suc @ ( plus_plus @ nat @ M @ ( times_times @ nat @ K @ N2 ) ) ) @ N2 )
= ( modulo_modulo @ nat @ ( suc @ M ) @ N2 ) ) ).
% Suc_mod_mult_self1
thf(fact_1217_Suc__mod__mult__self2,axiom,
! [M: nat,N2: nat,K: nat] :
( ( modulo_modulo @ nat @ ( suc @ ( plus_plus @ nat @ M @ ( times_times @ nat @ N2 @ K ) ) ) @ N2 )
= ( modulo_modulo @ nat @ ( suc @ M ) @ N2 ) ) ).
% Suc_mod_mult_self2
thf(fact_1218_Suc__mod__mult__self3,axiom,
! [K: nat,N2: nat,M: nat] :
( ( modulo_modulo @ nat @ ( suc @ ( plus_plus @ nat @ ( times_times @ nat @ K @ N2 ) @ M ) ) @ N2 )
= ( modulo_modulo @ nat @ ( suc @ M ) @ N2 ) ) ).
% Suc_mod_mult_self3
thf(fact_1219_Suc__mod__mult__self4,axiom,
! [N2: nat,K: nat,M: nat] :
( ( modulo_modulo @ nat @ ( suc @ ( plus_plus @ nat @ ( times_times @ nat @ N2 @ K ) @ M ) ) @ N2 )
= ( modulo_modulo @ nat @ ( suc @ M ) @ N2 ) ) ).
% Suc_mod_mult_self4
thf(fact_1220_odd__add,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [A3: A,B2: A] :
( ( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( plus_plus @ A @ A3 @ B2 ) ) )
= ( ( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) )
!= ( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) ) ) ) ) ).
% odd_add
thf(fact_1221_even__add,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( plus_plus @ A @ A3 @ B2 ) )
= ( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
= ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) ) ) ) ).
% even_add
thf(fact_1222_even__Suc__div__two,axiom,
! [N2: nat] :
( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( divide_divide @ nat @ ( suc @ N2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( divide_divide @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ).
% even_Suc_div_two
thf(fact_1223_odd__Suc__div__two,axiom,
! [N2: nat] :
( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( divide_divide @ nat @ ( suc @ N2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( suc @ ( divide_divide @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ).
% odd_Suc_div_two
thf(fact_1224_mod2__Suc__Suc,axiom,
! [M: nat] :
( ( modulo_modulo @ nat @ ( suc @ ( suc @ M ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( modulo_modulo @ nat @ M @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ).
% mod2_Suc_Suc
thf(fact_1225_Suc__times__numeral__mod__eq,axiom,
! [K: num,N2: nat] :
( ( ( numeral_numeral @ nat @ K )
!= ( one_one @ nat ) )
=> ( ( modulo_modulo @ nat @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ K ) @ N2 ) ) @ ( numeral_numeral @ nat @ K ) )
= ( one_one @ nat ) ) ) ).
% Suc_times_numeral_mod_eq
thf(fact_1226_set__decode__0,axiom,
! [X: nat] :
( ( member2 @ nat @ ( zero_zero @ nat ) @ ( nat_set_decode @ X ) )
= ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ X ) ) ) ).
% set_decode_0
thf(fact_1227_zero__le__power__eq__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,W2: num] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ ( numeral_numeral @ nat @ W2 ) ) )
= ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( numeral_numeral @ nat @ W2 ) )
| ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( numeral_numeral @ nat @ W2 ) )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ) ) ).
% zero_le_power_eq_numeral
thf(fact_1228_power__less__zero__eq,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less @ A @ ( power_power @ A @ A3 @ N2 ) @ ( zero_zero @ A ) )
= ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
& ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ) ).
% power_less_zero_eq
thf(fact_1229_power__less__zero__eq__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,W2: num] :
( ( ord_less @ A @ ( power_power @ A @ A3 @ ( numeral_numeral @ nat @ W2 ) ) @ ( zero_zero @ A ) )
= ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( numeral_numeral @ nat @ W2 ) )
& ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ) ).
% power_less_zero_eq_numeral
thf(fact_1230_even__plus__one__iff,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [A3: A] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) )
= ( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) ) ) ).
% even_plus_one_iff
thf(fact_1231_not__mod__2__eq__0__eq__1,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [A3: A] :
( ( ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
!= ( zero_zero @ A ) )
= ( ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( one_one @ A ) ) ) ) ).
% not_mod_2_eq_0_eq_1
thf(fact_1232_not__mod__2__eq__1__eq__0,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [A3: A] :
( ( ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
!= ( one_one @ A ) )
= ( ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( zero_zero @ A ) ) ) ) ).
% not_mod_2_eq_1_eq_0
thf(fact_1233_not__mod2__eq__Suc__0__eq__0,axiom,
! [N2: nat] :
( ( ( modulo_modulo @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
!= ( suc @ ( zero_zero @ nat ) ) )
= ( ( modulo_modulo @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( zero_zero @ nat ) ) ) ).
% not_mod2_eq_Suc_0_eq_0
thf(fact_1234_add__self__mod__2,axiom,
! [M: nat] :
( ( modulo_modulo @ nat @ ( plus_plus @ nat @ M @ M ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( zero_zero @ nat ) ) ).
% add_self_mod_2
thf(fact_1235_zero__less__power__eq__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,W2: num] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ ( numeral_numeral @ nat @ W2 ) ) )
= ( ( ( numeral_numeral @ nat @ W2 )
= ( zero_zero @ nat ) )
| ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( numeral_numeral @ nat @ W2 ) )
& ( A3
!= ( zero_zero @ A ) ) )
| ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( numeral_numeral @ nat @ W2 ) )
& ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ) ) ).
% zero_less_power_eq_numeral
thf(fact_1236_odd__succ__div__two,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [A3: A] :
( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( plus_plus @ A @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( one_one @ A ) ) ) ) ) ).
% odd_succ_div_two
thf(fact_1237_even__succ__div__two,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [A3: A] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% even_succ_div_two
thf(fact_1238_even__succ__div__2,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ ( one_one @ A ) @ A3 ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% even_succ_div_2
thf(fact_1239_even__power,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [A3: A,N2: nat] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( power_power @ A @ A3 @ N2 ) )
= ( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
& ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% even_power
thf(fact_1240_mod2__gr__0,axiom,
! [M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( modulo_modulo @ nat @ M @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
= ( ( modulo_modulo @ nat @ M @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( one_one @ nat ) ) ) ).
% mod2_gr_0
thf(fact_1241_odd__two__times__div__two__succ,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [A3: A] :
( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) @ ( one_one @ A ) )
= A3 ) ) ) ).
% odd_two_times_div_two_succ
thf(fact_1242_power__le__zero__eq__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,W2: num] :
( ( ord_less_eq @ A @ ( power_power @ A @ A3 @ ( numeral_numeral @ nat @ W2 ) ) @ ( zero_zero @ A ) )
= ( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( numeral_numeral @ nat @ W2 ) )
& ( ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( numeral_numeral @ nat @ W2 ) )
& ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) )
| ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( numeral_numeral @ nat @ W2 ) )
& ( A3
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% power_le_zero_eq_numeral
thf(fact_1243_even__succ__mod__exp,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,N2: nat] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( modulo_modulo @ A @ ( plus_plus @ A @ ( one_one @ A ) @ A3 ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( plus_plus @ A @ ( one_one @ A ) @ ( modulo_modulo @ A @ A3 @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ) ) ) ).
% even_succ_mod_exp
thf(fact_1244_mod__0__imp__dvd,axiom,
! [A: $tType] :
( ( semiring_modulo @ A )
=> ! [A3: A,B2: A] :
( ( ( modulo_modulo @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
=> ( dvd_dvd @ A @ B2 @ A3 ) ) ) ).
% mod_0_imp_dvd
thf(fact_1245_dvd__eq__mod__eq__0,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ( ( dvd_dvd @ A )
= ( ^ [A5: A,B4: A] :
( ( modulo_modulo @ A @ B4 @ A5 )
= ( zero_zero @ A ) ) ) ) ) ).
% dvd_eq_mod_eq_0
thf(fact_1246_mod__eq__0__iff__dvd,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ! [A3: A,B2: A] :
( ( ( modulo_modulo @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
= ( dvd_dvd @ A @ B2 @ A3 ) ) ) ).
% mod_eq_0_iff_dvd
thf(fact_1247_dvd__mod__imp__dvd,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( dvd_dvd @ A @ C2 @ ( modulo_modulo @ A @ A3 @ B2 ) )
=> ( ( dvd_dvd @ A @ C2 @ B2 )
=> ( dvd_dvd @ A @ C2 @ A3 ) ) ) ) ).
% dvd_mod_imp_dvd
thf(fact_1248_dvd__mod__iff,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( dvd_dvd @ A @ C2 @ B2 )
=> ( ( dvd_dvd @ A @ C2 @ ( modulo_modulo @ A @ A3 @ B2 ) )
= ( dvd_dvd @ A @ C2 @ A3 ) ) ) ) ).
% dvd_mod_iff
thf(fact_1249_dvd__trans,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( dvd_dvd @ A @ B2 @ C2 )
=> ( dvd_dvd @ A @ A3 @ C2 ) ) ) ) ).
% dvd_trans
thf(fact_1250_dvd__refl,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A] : ( dvd_dvd @ A @ A3 @ A3 ) ) ).
% dvd_refl
thf(fact_1251_unit__imp__mod__eq__0,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [B2: A,A3: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( modulo_modulo @ A @ A3 @ B2 )
= ( zero_zero @ A ) ) ) ) ).
% unit_imp_mod_eq_0
thf(fact_1252_mod__greater__zero__iff__not__dvd,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( modulo_modulo @ nat @ M @ N2 ) )
= ( ~ ( dvd_dvd @ nat @ N2 @ M ) ) ) ).
% mod_greater_zero_iff_not_dvd
thf(fact_1253_VEBT__internal_OminNull_Ocases,axiom,
! [X: vEBT_VEBT] :
( ( X
!= ( vEBT_Leaf @ $false @ $false ) )
=> ( ! [Uv2: $o] :
( X
!= ( vEBT_Leaf @ $true @ Uv2 ) )
=> ( ! [Uu2: $o] :
( X
!= ( vEBT_Leaf @ Uu2 @ $true ) )
=> ( ! [Uw2: nat,Ux2: list @ vEBT_VEBT,Uy2: vEBT_VEBT] :
( X
!= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uw2 @ Ux2 @ Uy2 ) )
=> ~ ! [Uz2: product_prod @ nat @ nat,Va3: nat,Vb2: list @ vEBT_VEBT,Vc2: vEBT_VEBT] :
( X
!= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ Uz2 ) @ Va3 @ Vb2 @ Vc2 ) ) ) ) ) ) ).
% VEBT_internal.minNull.cases
thf(fact_1254_VEBT_Osize_I4_J,axiom,
! [X21: $o,X222: $o] :
( ( size_size @ vEBT_VEBT @ ( vEBT_Leaf @ X21 @ X222 ) )
= ( zero_zero @ nat ) ) ).
% VEBT.size(4)
thf(fact_1255_VEBT__internal_OminNull_Oelims_I2_J,axiom,
! [X: vEBT_VEBT] :
( ( vEBT_VEBT_minNull @ X )
=> ( ( X
!= ( vEBT_Leaf @ $false @ $false ) )
=> ~ ! [Uw2: nat,Ux2: list @ vEBT_VEBT,Uy2: vEBT_VEBT] :
( X
!= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uw2 @ Ux2 @ Uy2 ) ) ) ) ).
% VEBT_internal.minNull.elims(2)
thf(fact_1256_mod__add__eq,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( modulo_modulo @ A @ ( plus_plus @ A @ ( modulo_modulo @ A @ A3 @ C2 ) @ ( modulo_modulo @ A @ B2 @ C2 ) ) @ C2 )
= ( modulo_modulo @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% mod_add_eq
thf(fact_1257_mod__add__cong,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [A3: A,C2: A,A8: A,B2: A,B7: A] :
( ( ( modulo_modulo @ A @ A3 @ C2 )
= ( modulo_modulo @ A @ A8 @ C2 ) )
=> ( ( ( modulo_modulo @ A @ B2 @ C2 )
= ( modulo_modulo @ A @ B7 @ C2 ) )
=> ( ( modulo_modulo @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( modulo_modulo @ A @ ( plus_plus @ A @ A8 @ B7 ) @ C2 ) ) ) ) ) ).
% mod_add_cong
thf(fact_1258_mod__add__left__eq,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( modulo_modulo @ A @ ( plus_plus @ A @ ( modulo_modulo @ A @ A3 @ C2 ) @ B2 ) @ C2 )
= ( modulo_modulo @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% mod_add_left_eq
thf(fact_1259_mod__add__right__eq,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( modulo_modulo @ A @ ( plus_plus @ A @ A3 @ ( modulo_modulo @ A @ B2 @ C2 ) ) @ C2 )
= ( modulo_modulo @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% mod_add_right_eq
thf(fact_1260_dvd__field__iff,axiom,
! [A: $tType] :
( ( field @ A )
=> ( ( dvd_dvd @ A )
= ( ^ [A5: A,B4: A] :
( ( A5
= ( zero_zero @ A ) )
=> ( B4
= ( zero_zero @ A ) ) ) ) ) ) ).
% dvd_field_iff
thf(fact_1261_dvd__0__left,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A] :
( ( dvd_dvd @ A @ ( zero_zero @ A ) @ A3 )
=> ( A3
= ( zero_zero @ A ) ) ) ) ).
% dvd_0_left
thf(fact_1262_VEBT__internal_Ovalid_H_Ocases,axiom,
! [X: product_prod @ vEBT_VEBT @ nat] :
( ! [Uu2: $o,Uv2: $o,D3: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ Uu2 @ Uv2 ) @ D3 ) )
=> ~ ! [Mima: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT,Deg3: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Mima @ Deg2 @ TreeList3 @ Summary2 ) @ Deg3 ) ) ) ).
% VEBT_internal.valid'.cases
thf(fact_1263_VEBT_Odistinct_I1_J,axiom,
! [X11: option @ ( product_prod @ nat @ nat ),X12: nat,X13: list @ vEBT_VEBT,X14: vEBT_VEBT,X21: $o,X222: $o] :
( ( vEBT_Node @ X11 @ X12 @ X13 @ X14 )
!= ( vEBT_Leaf @ X21 @ X222 ) ) ).
% VEBT.distinct(1)
thf(fact_1264_VEBT_Oexhaust,axiom,
! [Y: vEBT_VEBT] :
( ! [X112: option @ ( product_prod @ nat @ nat ),X122: nat,X132: list @ vEBT_VEBT,X142: vEBT_VEBT] :
( Y
!= ( vEBT_Node @ X112 @ X122 @ X132 @ X142 ) )
=> ~ ! [X212: $o,X223: $o] :
( Y
!= ( vEBT_Leaf @ X212 @ X223 ) ) ) ).
% VEBT.exhaust
thf(fact_1265_mod__Suc__eq,axiom,
! [M: nat,N2: nat] :
( ( modulo_modulo @ nat @ ( suc @ ( modulo_modulo @ nat @ M @ N2 ) ) @ N2 )
= ( modulo_modulo @ nat @ ( suc @ M ) @ N2 ) ) ).
% mod_Suc_eq
thf(fact_1266_mod__Suc__Suc__eq,axiom,
! [M: nat,N2: nat] :
( ( modulo_modulo @ nat @ ( suc @ ( suc @ ( modulo_modulo @ nat @ M @ N2 ) ) ) @ N2 )
= ( modulo_modulo @ nat @ ( suc @ ( suc @ M ) ) @ N2 ) ) ).
% mod_Suc_Suc_eq
thf(fact_1267_dvd__triv__right,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A,B2: A] : ( dvd_dvd @ A @ A3 @ ( times_times @ A @ B2 @ A3 ) ) ) ).
% dvd_triv_right
thf(fact_1268_dvd__mult__right,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ ( times_times @ A @ A3 @ B2 ) @ C2 )
=> ( dvd_dvd @ A @ B2 @ C2 ) ) ) ).
% dvd_mult_right
thf(fact_1269_mult__dvd__mono,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( dvd_dvd @ A @ C2 @ D2 )
=> ( dvd_dvd @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ D2 ) ) ) ) ) ).
% mult_dvd_mono
thf(fact_1270_dvd__triv__left,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A,B2: A] : ( dvd_dvd @ A @ A3 @ ( times_times @ A @ A3 @ B2 ) ) ) ).
% dvd_triv_left
thf(fact_1271_dvd__mult__left,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ ( times_times @ A @ A3 @ B2 ) @ C2 )
=> ( dvd_dvd @ A @ A3 @ C2 ) ) ) ).
% dvd_mult_left
thf(fact_1272_dvd__mult2,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( dvd_dvd @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) ) ) ) ).
% dvd_mult2
thf(fact_1273_dvd__mult,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ C2 )
=> ( dvd_dvd @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) ) ) ) ).
% dvd_mult
thf(fact_1274_dvd__def,axiom,
! [A: $tType] :
( ( dvd @ A )
=> ( ( dvd_dvd @ A )
= ( ^ [B4: A,A5: A] :
? [K2: A] :
( A5
= ( times_times @ A @ B4 @ K2 ) ) ) ) ) ).
% dvd_def
thf(fact_1275_dvdI,axiom,
! [A: $tType] :
( ( dvd @ A )
=> ! [A3: A,B2: A,K: A] :
( ( A3
= ( times_times @ A @ B2 @ K ) )
=> ( dvd_dvd @ A @ B2 @ A3 ) ) ) ).
% dvdI
thf(fact_1276_dvdE,axiom,
! [A: $tType] :
( ( dvd @ A )
=> ! [B2: A,A3: A] :
( ( dvd_dvd @ A @ B2 @ A3 )
=> ~ ! [K3: A] :
( A3
!= ( times_times @ A @ B2 @ K3 ) ) ) ) ).
% dvdE
thf(fact_1277_dvd__unit__imp__unit,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( dvd_dvd @ A @ A3 @ ( one_one @ A ) ) ) ) ) ).
% dvd_unit_imp_unit
thf(fact_1278_unit__imp__dvd,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( dvd_dvd @ A @ B2 @ A3 ) ) ) ).
% unit_imp_dvd
thf(fact_1279_one__dvd,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A] : ( dvd_dvd @ A @ ( one_one @ A ) @ A3 ) ) ).
% one_dvd
thf(fact_1280_dvd__add,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( dvd_dvd @ A @ A3 @ C2 )
=> ( dvd_dvd @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) ) ) ) ) ).
% dvd_add
thf(fact_1281_dvd__add__left__iff,axiom,
! [A: $tType] :
( ( comm_s4317794764714335236cancel @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ C2 )
=> ( ( dvd_dvd @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) )
= ( dvd_dvd @ A @ A3 @ B2 ) ) ) ) ).
% dvd_add_left_iff
thf(fact_1282_dvd__add__right__iff,axiom,
! [A: $tType] :
( ( comm_s4317794764714335236cancel @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( dvd_dvd @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) )
= ( dvd_dvd @ A @ A3 @ C2 ) ) ) ) ).
% dvd_add_right_iff
thf(fact_1283_div__div__div__same,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [D2: A,B2: A,A3: A] :
( ( dvd_dvd @ A @ D2 @ B2 )
=> ( ( dvd_dvd @ A @ B2 @ A3 )
=> ( ( divide_divide @ A @ ( divide_divide @ A @ A3 @ D2 ) @ ( divide_divide @ A @ B2 @ D2 ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ).
% div_div_div_same
thf(fact_1284_dvd__div__eq__cancel,axiom,
! [A: $tType] :
( ( semidom_divide @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ( divide_divide @ A @ A3 @ C2 )
= ( divide_divide @ A @ B2 @ C2 ) )
=> ( ( dvd_dvd @ A @ C2 @ A3 )
=> ( ( dvd_dvd @ A @ C2 @ B2 )
=> ( A3 = B2 ) ) ) ) ) ).
% dvd_div_eq_cancel
thf(fact_1285_dvd__div__eq__iff,axiom,
! [A: $tType] :
( ( semidom_divide @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( dvd_dvd @ A @ C2 @ A3 )
=> ( ( dvd_dvd @ A @ C2 @ B2 )
=> ( ( ( divide_divide @ A @ A3 @ C2 )
= ( divide_divide @ A @ B2 @ C2 ) )
= ( A3 = B2 ) ) ) ) ) ).
% dvd_div_eq_iff
thf(fact_1286_mod__less__eq__dividend,axiom,
! [M: nat,N2: nat] : ( ord_less_eq @ nat @ ( modulo_modulo @ nat @ M @ N2 ) @ M ) ).
% mod_less_eq_dividend
thf(fact_1287_gcd__nat_Oextremum,axiom,
! [A3: nat] : ( dvd_dvd @ nat @ A3 @ ( zero_zero @ nat ) ) ).
% gcd_nat.extremum
thf(fact_1288_gcd__nat_Oextremum__strict,axiom,
! [A3: nat] :
~ ( ( dvd_dvd @ nat @ ( zero_zero @ nat ) @ A3 )
& ( ( zero_zero @ nat )
!= A3 ) ) ).
% gcd_nat.extremum_strict
thf(fact_1289_gcd__nat_Oextremum__unique,axiom,
! [A3: nat] :
( ( dvd_dvd @ nat @ ( zero_zero @ nat ) @ A3 )
= ( A3
= ( zero_zero @ nat ) ) ) ).
% gcd_nat.extremum_unique
thf(fact_1290_gcd__nat_Onot__eq__extremum,axiom,
! [A3: nat] :
( ( A3
!= ( zero_zero @ nat ) )
= ( ( dvd_dvd @ nat @ A3 @ ( zero_zero @ nat ) )
& ( A3
!= ( zero_zero @ nat ) ) ) ) ).
% gcd_nat.not_eq_extremum
thf(fact_1291_gcd__nat_Oextremum__uniqueI,axiom,
! [A3: nat] :
( ( dvd_dvd @ nat @ ( zero_zero @ nat ) @ A3 )
=> ( A3
= ( zero_zero @ nat ) ) ) ).
% gcd_nat.extremum_uniqueI
thf(fact_1292_option_Odistinct_I1_J,axiom,
! [A: $tType,X22: A] :
( ( none @ A )
!= ( some @ A @ X22 ) ) ).
% option.distinct(1)
thf(fact_1293_option_OdiscI,axiom,
! [A: $tType,Option: option @ A,X22: A] :
( ( Option
= ( some @ A @ X22 ) )
=> ( Option
!= ( none @ A ) ) ) ).
% option.discI
thf(fact_1294_option_Oexhaust,axiom,
! [A: $tType,Y: option @ A] :
( ( Y
!= ( none @ A ) )
=> ~ ! [X23: A] :
( Y
!= ( some @ A @ X23 ) ) ) ).
% option.exhaust
thf(fact_1295_split__option__ex,axiom,
! [A: $tType] :
( ( ^ [P3: ( option @ A ) > $o] :
? [X6: option @ A] : ( P3 @ X6 ) )
= ( ^ [P: ( option @ A ) > $o] :
( ( P @ ( none @ A ) )
| ? [X2: A] : ( P @ ( some @ A @ X2 ) ) ) ) ) ).
% split_option_ex
thf(fact_1296_split__option__all,axiom,
! [A: $tType] :
( ( ^ [P3: ( option @ A ) > $o] :
! [X6: option @ A] : ( P3 @ X6 ) )
= ( ^ [P: ( option @ A ) > $o] :
( ( P @ ( none @ A ) )
& ! [X2: A] : ( P @ ( some @ A @ X2 ) ) ) ) ) ).
% split_option_all
thf(fact_1297_combine__options__cases,axiom,
! [A: $tType,B: $tType,X: option @ A,P2: ( option @ A ) > ( option @ B ) > $o,Y: option @ B] :
( ( ( X
= ( none @ A ) )
=> ( P2 @ X @ Y ) )
=> ( ( ( Y
= ( none @ B ) )
=> ( P2 @ X @ Y ) )
=> ( ! [A7: A,B5: B] :
( ( X
= ( some @ A @ A7 ) )
=> ( ( Y
= ( some @ B @ B5 ) )
=> ( P2 @ X @ Y ) ) )
=> ( P2 @ X @ Y ) ) ) ) ).
% combine_options_cases
thf(fact_1298_VEBT__internal_OminNull_Osimps_I3_J,axiom,
! [Uu: $o] :
~ ( vEBT_VEBT_minNull @ ( vEBT_Leaf @ Uu @ $true ) ) ).
% VEBT_internal.minNull.simps(3)
thf(fact_1299_VEBT__internal_OminNull_Osimps_I2_J,axiom,
! [Uv: $o] :
~ ( vEBT_VEBT_minNull @ ( vEBT_Leaf @ $true @ Uv ) ) ).
% VEBT_internal.minNull.simps(2)
thf(fact_1300_VEBT__internal_OminNull_Osimps_I1_J,axiom,
vEBT_VEBT_minNull @ ( vEBT_Leaf @ $false @ $false ) ).
% VEBT_internal.minNull.simps(1)
thf(fact_1301_VEBT__internal_OminNull_Oelims_I1_J,axiom,
! [X: vEBT_VEBT,Y: $o] :
( ( ( vEBT_VEBT_minNull @ X )
= Y )
=> ( ( ( X
= ( vEBT_Leaf @ $false @ $false ) )
=> ~ Y )
=> ( ( ? [Uv2: $o] :
( X
= ( vEBT_Leaf @ $true @ Uv2 ) )
=> Y )
=> ( ( ? [Uu2: $o] :
( X
= ( vEBT_Leaf @ Uu2 @ $true ) )
=> Y )
=> ( ( ? [Uw2: nat,Ux2: list @ vEBT_VEBT,Uy2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uw2 @ Ux2 @ Uy2 ) )
=> ~ Y )
=> ~ ( ? [Uz2: product_prod @ nat @ nat,Va3: nat,Vb2: list @ vEBT_VEBT,Vc2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ Uz2 ) @ Va3 @ Vb2 @ Vc2 ) )
=> Y ) ) ) ) ) ) ).
% VEBT_internal.minNull.elims(1)
thf(fact_1302_even__iff__mod__2__eq__zero,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [A3: A] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
= ( ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( zero_zero @ A ) ) ) ) ).
% even_iff_mod_2_eq_zero
thf(fact_1303_subset__decode__imp__le,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ ( set @ nat ) @ ( nat_set_decode @ M ) @ ( nat_set_decode @ N2 ) )
=> ( ord_less_eq @ nat @ M @ N2 ) ) ).
% subset_decode_imp_le
thf(fact_1304_unique__euclidean__semiring__numeral__class_Omod__less__eq__dividend,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less_eq @ A @ ( modulo_modulo @ A @ A3 @ B2 ) @ A3 ) ) ) ).
% unique_euclidean_semiring_numeral_class.mod_less_eq_dividend
thf(fact_1305_unique__euclidean__semiring__numeral__class_Opos__mod__bound,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less @ A @ ( modulo_modulo @ A @ A3 @ B2 ) @ B2 ) ) ) ).
% unique_euclidean_semiring_numeral_class.pos_mod_bound
thf(fact_1306_mod__eq__self__iff__div__eq__0,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [A3: A,B2: A] :
( ( ( modulo_modulo @ A @ A3 @ B2 )
= A3 )
= ( ( divide_divide @ A @ A3 @ B2 )
= ( zero_zero @ A ) ) ) ) ).
% mod_eq_self_iff_div_eq_0
thf(fact_1307_mod__eqE,axiom,
! [A: $tType] :
( ( euclid8851590272496341667cancel @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ( modulo_modulo @ A @ A3 @ C2 )
= ( modulo_modulo @ A @ B2 @ C2 ) )
=> ~ ! [D3: A] :
( B2
!= ( plus_plus @ A @ A3 @ ( times_times @ A @ C2 @ D3 ) ) ) ) ) ).
% mod_eqE
thf(fact_1308_div__add1__eq,axiom,
! [A: $tType] :
( ( euclid3128863361964157862miring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( divide_divide @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ ( plus_plus @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) ) @ ( divide_divide @ A @ ( plus_plus @ A @ ( modulo_modulo @ A @ A3 @ C2 ) @ ( modulo_modulo @ A @ B2 @ C2 ) ) @ C2 ) ) ) ) ).
% div_add1_eq
thf(fact_1309_not__is__unit__0,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ~ ( dvd_dvd @ A @ ( zero_zero @ A ) @ ( one_one @ A ) ) ) ).
% not_is_unit_0
thf(fact_1310_pinf_I9_J,axiom,
! [B: $tType] :
( ( ( plus @ B )
& ( linorder @ B )
& ( dvd @ B ) )
=> ! [D2: B,S: B] :
? [Z2: B] :
! [X3: B] :
( ( ord_less @ B @ Z2 @ X3 )
=> ( ( dvd_dvd @ B @ D2 @ ( plus_plus @ B @ X3 @ S ) )
= ( dvd_dvd @ B @ D2 @ ( plus_plus @ B @ X3 @ S ) ) ) ) ) ).
% pinf(9)
thf(fact_1311_pinf_I10_J,axiom,
! [B: $tType] :
( ( ( plus @ B )
& ( linorder @ B )
& ( dvd @ B ) )
=> ! [D2: B,S: B] :
? [Z2: B] :
! [X3: B] :
( ( ord_less @ B @ Z2 @ X3 )
=> ( ( ~ ( dvd_dvd @ B @ D2 @ ( plus_plus @ B @ X3 @ S ) ) )
= ( ~ ( dvd_dvd @ B @ D2 @ ( plus_plus @ B @ X3 @ S ) ) ) ) ) ) ).
% pinf(10)
thf(fact_1312_minf_I9_J,axiom,
! [B: $tType] :
( ( ( plus @ B )
& ( linorder @ B )
& ( dvd @ B ) )
=> ! [D2: B,S: B] :
? [Z2: B] :
! [X3: B] :
( ( ord_less @ B @ X3 @ Z2 )
=> ( ( dvd_dvd @ B @ D2 @ ( plus_plus @ B @ X3 @ S ) )
= ( dvd_dvd @ B @ D2 @ ( plus_plus @ B @ X3 @ S ) ) ) ) ) ).
% minf(9)
thf(fact_1313_minf_I10_J,axiom,
! [B: $tType] :
( ( ( plus @ B )
& ( linorder @ B )
& ( dvd @ B ) )
=> ! [D2: B,S: B] :
? [Z2: B] :
! [X3: B] :
( ( ord_less @ B @ X3 @ Z2 )
=> ( ( ~ ( dvd_dvd @ B @ D2 @ ( plus_plus @ B @ X3 @ S ) ) )
= ( ~ ( dvd_dvd @ B @ D2 @ ( plus_plus @ B @ X3 @ S ) ) ) ) ) ) ).
% minf(10)
thf(fact_1314_dvd__div__eq__0__iff,axiom,
! [A: $tType] :
( ( semidom_divide @ A )
=> ! [B2: A,A3: A] :
( ( dvd_dvd @ A @ B2 @ A3 )
=> ( ( ( divide_divide @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ) ).
% dvd_div_eq_0_iff
thf(fact_1315_is__unit__mult__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ ( times_times @ A @ A3 @ B2 ) @ ( one_one @ A ) )
= ( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
& ( dvd_dvd @ A @ B2 @ ( one_one @ A ) ) ) ) ) ).
% is_unit_mult_iff
thf(fact_1316_dvd__mult__unit__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ A3 @ ( times_times @ A @ C2 @ B2 ) )
= ( dvd_dvd @ A @ A3 @ C2 ) ) ) ) ).
% dvd_mult_unit_iff
thf(fact_1317_mult__unit__dvd__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ ( times_times @ A @ A3 @ B2 ) @ C2 )
= ( dvd_dvd @ A @ A3 @ C2 ) ) ) ) ).
% mult_unit_dvd_iff
thf(fact_1318_dvd__mult__unit__iff_H,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) )
= ( dvd_dvd @ A @ A3 @ C2 ) ) ) ) ).
% dvd_mult_unit_iff'
thf(fact_1319_mult__unit__dvd__iff_H,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ ( times_times @ A @ A3 @ B2 ) @ C2 )
= ( dvd_dvd @ A @ B2 @ C2 ) ) ) ) ).
% mult_unit_dvd_iff'
thf(fact_1320_unit__mult__left__cancel,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( ( ( times_times @ A @ A3 @ B2 )
= ( times_times @ A @ A3 @ C2 ) )
= ( B2 = C2 ) ) ) ) ).
% unit_mult_left_cancel
thf(fact_1321_unit__mult__right__cancel,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( ( ( times_times @ A @ B2 @ A3 )
= ( times_times @ A @ C2 @ A3 ) )
= ( B2 = C2 ) ) ) ) ).
% unit_mult_right_cancel
thf(fact_1322_mod__Suc,axiom,
! [M: nat,N2: nat] :
( ( ( ( suc @ ( modulo_modulo @ nat @ M @ N2 ) )
= N2 )
=> ( ( modulo_modulo @ nat @ ( suc @ M ) @ N2 )
= ( zero_zero @ nat ) ) )
& ( ( ( suc @ ( modulo_modulo @ nat @ M @ N2 ) )
!= N2 )
=> ( ( modulo_modulo @ nat @ ( suc @ M ) @ N2 )
= ( suc @ ( modulo_modulo @ nat @ M @ N2 ) ) ) ) ) ).
% mod_Suc
thf(fact_1323_mod__induct,axiom,
! [P2: nat > $o,N2: nat,P4: nat,M: nat] :
( ( P2 @ N2 )
=> ( ( ord_less @ nat @ N2 @ P4 )
=> ( ( ord_less @ nat @ M @ P4 )
=> ( ! [N3: nat] :
( ( ord_less @ nat @ N3 @ P4 )
=> ( ( P2 @ N3 )
=> ( P2 @ ( modulo_modulo @ nat @ ( suc @ N3 ) @ P4 ) ) ) )
=> ( P2 @ M ) ) ) ) ) ).
% mod_induct
thf(fact_1324_div__mult__div__if__dvd,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A,D2: A,C2: A] :
( ( dvd_dvd @ A @ B2 @ A3 )
=> ( ( dvd_dvd @ A @ D2 @ C2 )
=> ( ( times_times @ A @ ( divide_divide @ A @ A3 @ B2 ) @ ( divide_divide @ A @ C2 @ D2 ) )
= ( divide_divide @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ D2 ) ) ) ) ) ) ).
% div_mult_div_if_dvd
thf(fact_1325_dvd__mult__imp__div,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( dvd_dvd @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 )
=> ( dvd_dvd @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) ) ) ) ).
% dvd_mult_imp_div
thf(fact_1326_dvd__div__mult2__eq,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( dvd_dvd @ A @ ( times_times @ A @ B2 @ C2 ) @ A3 )
=> ( ( divide_divide @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) )
= ( divide_divide @ A @ ( divide_divide @ A @ A3 @ B2 ) @ C2 ) ) ) ) ).
% dvd_div_mult2_eq
thf(fact_1327_div__div__eq__right,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( dvd_dvd @ A @ C2 @ B2 )
=> ( ( dvd_dvd @ A @ B2 @ A3 )
=> ( ( divide_divide @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( times_times @ A @ ( divide_divide @ A @ A3 @ B2 ) @ C2 ) ) ) ) ) ).
% div_div_eq_right
thf(fact_1328_div__mult__swap,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( dvd_dvd @ A @ C2 @ B2 )
=> ( ( times_times @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( divide_divide @ A @ ( times_times @ A @ A3 @ B2 ) @ C2 ) ) ) ) ).
% div_mult_swap
thf(fact_1329_dvd__div__mult,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( dvd_dvd @ A @ C2 @ B2 )
=> ( ( times_times @ A @ ( divide_divide @ A @ B2 @ C2 ) @ A3 )
= ( divide_divide @ A @ ( times_times @ A @ B2 @ A3 ) @ C2 ) ) ) ) ).
% dvd_div_mult
thf(fact_1330_gcd__nat__induct,axiom,
! [P2: nat > nat > $o,M: nat,N2: nat] :
( ! [M3: nat] : ( P2 @ M3 @ ( zero_zero @ nat ) )
=> ( ! [M3: nat,N3: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 )
=> ( ( P2 @ N3 @ ( modulo_modulo @ nat @ M3 @ N3 ) )
=> ( P2 @ M3 @ N3 ) ) )
=> ( P2 @ M @ N2 ) ) ) ).
% gcd_nat_induct
thf(fact_1331_mod__less__divisor,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less @ nat @ ( modulo_modulo @ nat @ M @ N2 ) @ N2 ) ) ).
% mod_less_divisor
thf(fact_1332_unit__div__cancel,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( ( ( divide_divide @ A @ B2 @ A3 )
= ( divide_divide @ A @ C2 @ A3 ) )
= ( B2 = C2 ) ) ) ) ).
% unit_div_cancel
thf(fact_1333_div__unit__dvd__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ ( divide_divide @ A @ A3 @ B2 ) @ C2 )
= ( dvd_dvd @ A @ A3 @ C2 ) ) ) ) ).
% div_unit_dvd_iff
thf(fact_1334_dvd__div__unit__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ A3 @ ( divide_divide @ A @ C2 @ B2 ) )
= ( dvd_dvd @ A @ A3 @ C2 ) ) ) ) ).
% dvd_div_unit_iff
thf(fact_1335_div__plus__div__distrib__dvd__left,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( dvd_dvd @ A @ C2 @ A3 )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) ) ) ) ) ).
% div_plus_div_distrib_dvd_left
thf(fact_1336_div__plus__div__distrib__dvd__right,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( dvd_dvd @ A @ C2 @ B2 )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) ) ) ) ) ).
% div_plus_div_distrib_dvd_right
thf(fact_1337_mod__Suc__le__divisor,axiom,
! [M: nat,N2: nat] : ( ord_less_eq @ nat @ ( modulo_modulo @ nat @ M @ ( suc @ N2 ) ) @ N2 ) ).
% mod_Suc_le_divisor
thf(fact_1338_mod__eq__0D,axiom,
! [M: nat,D2: nat] :
( ( ( modulo_modulo @ nat @ M @ D2 )
= ( zero_zero @ nat ) )
=> ? [Q3: nat] :
( M
= ( times_times @ nat @ D2 @ Q3 ) ) ) ).
% mod_eq_0D
thf(fact_1339_le__imp__power__dvd,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [M: nat,N2: nat,A3: A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( dvd_dvd @ A @ ( power_power @ A @ A3 @ M ) @ ( power_power @ A @ A3 @ N2 ) ) ) ) ).
% le_imp_power_dvd
thf(fact_1340_power__le__dvd,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A,N2: nat,B2: A,M: nat] :
( ( dvd_dvd @ A @ ( power_power @ A @ A3 @ N2 ) @ B2 )
=> ( ( ord_less_eq @ nat @ M @ N2 )
=> ( dvd_dvd @ A @ ( power_power @ A @ A3 @ M ) @ B2 ) ) ) ) ).
% power_le_dvd
thf(fact_1341_dvd__power__le,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [X: A,Y: A,N2: nat,M: nat] :
( ( dvd_dvd @ A @ X @ Y )
=> ( ( ord_less_eq @ nat @ N2 @ M )
=> ( dvd_dvd @ A @ ( power_power @ A @ X @ N2 ) @ ( power_power @ A @ Y @ M ) ) ) ) ) ).
% dvd_power_le
thf(fact_1342_nat__mod__eq__iff,axiom,
! [X: nat,N2: nat,Y: nat] :
( ( ( modulo_modulo @ nat @ X @ N2 )
= ( modulo_modulo @ nat @ Y @ N2 ) )
= ( ? [Q1: nat,Q22: nat] :
( ( plus_plus @ nat @ X @ ( times_times @ nat @ N2 @ Q1 ) )
= ( plus_plus @ nat @ Y @ ( times_times @ nat @ N2 @ Q22 ) ) ) ) ) ).
% nat_mod_eq_iff
thf(fact_1343_dvd__pos__nat,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( dvd_dvd @ nat @ M @ N2 )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ M ) ) ) ).
% dvd_pos_nat
thf(fact_1344_nat__dvd__not__less,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ( ord_less @ nat @ M @ N2 )
=> ~ ( dvd_dvd @ nat @ N2 @ M ) ) ) ).
% nat_dvd_not_less
thf(fact_1345_bezout__lemma__nat,axiom,
! [D2: nat,A3: nat,B2: nat,X: nat,Y: nat] :
( ( dvd_dvd @ nat @ D2 @ A3 )
=> ( ( dvd_dvd @ nat @ D2 @ B2 )
=> ( ( ( ( times_times @ nat @ A3 @ X )
= ( plus_plus @ nat @ ( times_times @ nat @ B2 @ Y ) @ D2 ) )
| ( ( times_times @ nat @ B2 @ X )
= ( plus_plus @ nat @ ( times_times @ nat @ A3 @ Y ) @ D2 ) ) )
=> ? [X5: nat,Y4: nat] :
( ( dvd_dvd @ nat @ D2 @ A3 )
& ( dvd_dvd @ nat @ D2 @ ( plus_plus @ nat @ A3 @ B2 ) )
& ( ( ( times_times @ nat @ A3 @ X5 )
= ( plus_plus @ nat @ ( times_times @ nat @ ( plus_plus @ nat @ A3 @ B2 ) @ Y4 ) @ D2 ) )
| ( ( times_times @ nat @ ( plus_plus @ nat @ A3 @ B2 ) @ X5 )
= ( plus_plus @ nat @ ( times_times @ nat @ A3 @ Y4 ) @ D2 ) ) ) ) ) ) ) ).
% bezout_lemma_nat
thf(fact_1346_bezout__add__nat,axiom,
! [A3: nat,B2: nat] :
? [D3: nat,X5: nat,Y4: nat] :
( ( dvd_dvd @ nat @ D3 @ A3 )
& ( dvd_dvd @ nat @ D3 @ B2 )
& ( ( ( times_times @ nat @ A3 @ X5 )
= ( plus_plus @ nat @ ( times_times @ nat @ B2 @ Y4 ) @ D3 ) )
| ( ( times_times @ nat @ B2 @ X5 )
= ( plus_plus @ nat @ ( times_times @ nat @ A3 @ Y4 ) @ D3 ) ) ) ) ).
% bezout_add_nat
thf(fact_1347_vebt__buildup_Osimps_I1_J,axiom,
( ( vEBT_vebt_buildup @ ( zero_zero @ nat ) )
= ( vEBT_Leaf @ $false @ $false ) ) ).
% vebt_buildup.simps(1)
thf(fact_1348_VEBT__internal_Ovalid_H_Osimps_I1_J,axiom,
! [Uu: $o,Uv: $o,D2: nat] :
( ( vEBT_VEBT_valid @ ( vEBT_Leaf @ Uu @ Uv ) @ D2 )
= ( D2
= ( one_one @ nat ) ) ) ).
% VEBT_internal.valid'.simps(1)
thf(fact_1349_mod2__eq__if,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [A3: A] :
( ( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( zero_zero @ A ) ) )
& ( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( one_one @ A ) ) ) ) ) ).
% mod2_eq_if
thf(fact_1350_parity__cases,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [A3: A] :
( ( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
!= ( zero_zero @ A ) ) )
=> ~ ( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
!= ( one_one @ A ) ) ) ) ) ).
% parity_cases
thf(fact_1351_vebt__member_Osimps_I2_J,axiom,
! [Uu: nat,Uv: list @ vEBT_VEBT,Uw: vEBT_VEBT,X: nat] :
~ ( vEBT_vebt_member @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uu @ Uv @ Uw ) @ X ) ).
% vebt_member.simps(2)
thf(fact_1352_vebt__insert_Ocases,axiom,
! [X: product_prod @ vEBT_VEBT @ nat] :
( ! [A7: $o,B5: $o,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ A7 @ B5 ) @ X5 ) )
=> ( ! [Info2: option @ ( product_prod @ nat @ nat ),Ts2: list @ vEBT_VEBT,S2: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Info2 @ ( zero_zero @ nat ) @ Ts2 @ S2 ) @ X5 ) )
=> ( ! [Info2: option @ ( product_prod @ nat @ nat ),Ts2: list @ vEBT_VEBT,S2: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Info2 @ ( suc @ ( zero_zero @ nat ) ) @ Ts2 @ S2 ) @ X5 ) )
=> ( ! [V3: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ ( suc @ V3 ) ) @ TreeList3 @ Summary2 ) @ X5 ) )
=> ~ ! [Mi2: nat,Ma2: nat,Va2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) @ X5 ) ) ) ) ) ) ).
% vebt_insert.cases
thf(fact_1353_vebt__member_Ocases,axiom,
! [X: product_prod @ vEBT_VEBT @ nat] :
( ! [A7: $o,B5: $o,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ A7 @ B5 ) @ X5 ) )
=> ( ! [Uu2: nat,Uv2: list @ vEBT_VEBT,Uw2: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uu2 @ Uv2 @ Uw2 ) @ X5 ) )
=> ( ! [V3: product_prod @ nat @ nat,Uy2: list @ vEBT_VEBT,Uz2: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( zero_zero @ nat ) @ Uy2 @ Uz2 ) @ X5 ) )
=> ( ! [V3: product_prod @ nat @ nat,Vb2: list @ vEBT_VEBT,Vc2: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( suc @ ( zero_zero @ nat ) ) @ Vb2 @ Vc2 ) @ X5 ) )
=> ~ ! [Mi2: nat,Ma2: nat,Va2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) @ X5 ) ) ) ) ) ) ).
% vebt_member.cases
thf(fact_1354_VEBT__internal_Omembermima_Ocases,axiom,
! [X: product_prod @ vEBT_VEBT @ nat] :
( ! [Uu2: $o,Uv2: $o,Uw2: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ Uu2 @ Uv2 ) @ Uw2 ) )
=> ( ! [Ux2: list @ vEBT_VEBT,Uy2: vEBT_VEBT,Uz2: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( zero_zero @ nat ) @ Ux2 @ Uy2 ) @ Uz2 ) )
=> ( ! [Mi2: nat,Ma2: nat,Va3: list @ vEBT_VEBT,Vb2: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( zero_zero @ nat ) @ Va3 @ Vb2 ) @ X5 ) )
=> ( ! [Mi2: nat,Ma2: nat,V3: nat,TreeList3: list @ vEBT_VEBT,Vc2: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ V3 ) @ TreeList3 @ Vc2 ) @ X5 ) )
=> ~ ! [V3: nat,TreeList3: list @ vEBT_VEBT,Vd: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ V3 ) @ TreeList3 @ Vd ) @ X5 ) ) ) ) ) ) ).
% VEBT_internal.membermima.cases
thf(fact_1355_VEBT__internal_OminNull_Osimps_I4_J,axiom,
! [Uw: nat,Ux: list @ vEBT_VEBT,Uy: vEBT_VEBT] : ( vEBT_VEBT_minNull @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uw @ Ux @ Uy ) ) ).
% VEBT_internal.minNull.simps(4)
thf(fact_1356_find__None__iff,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ( find @ A @ P2 @ Xs )
= ( none @ A ) )
= ( ~ ? [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
& ( P2 @ X2 ) ) ) ) ).
% find_None_iff
thf(fact_1357_find__None__iff2,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ( none @ A )
= ( find @ A @ P2 @ Xs ) )
= ( ~ ? [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
& ( P2 @ X2 ) ) ) ) ).
% find_None_iff2
thf(fact_1358_unique__euclidean__semiring__numeral__class_Omod__less,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ A3 @ B2 )
=> ( ( modulo_modulo @ A @ A3 @ B2 )
= A3 ) ) ) ) ).
% unique_euclidean_semiring_numeral_class.mod_less
thf(fact_1359_unique__euclidean__semiring__numeral__class_Opos__mod__sign,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( modulo_modulo @ A @ A3 @ B2 ) ) ) ) ).
% unique_euclidean_semiring_numeral_class.pos_mod_sign
thf(fact_1360_cong__exp__iff__simps_I2_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [N2: num,Q2: num] :
( ( ( modulo_modulo @ A @ ( numeral_numeral @ A @ ( bit0 @ N2 ) ) @ ( numeral_numeral @ A @ ( bit0 @ Q2 ) ) )
= ( zero_zero @ A ) )
= ( ( modulo_modulo @ A @ ( numeral_numeral @ A @ N2 ) @ ( numeral_numeral @ A @ Q2 ) )
= ( zero_zero @ A ) ) ) ) ).
% cong_exp_iff_simps(2)
thf(fact_1361_cong__exp__iff__simps_I1_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [N2: num] :
( ( modulo_modulo @ A @ ( numeral_numeral @ A @ N2 ) @ ( numeral_numeral @ A @ one2 ) )
= ( zero_zero @ A ) ) ) ).
% cong_exp_iff_simps(1)
thf(fact_1362_VEBT__internal_Onaive__member_Ocases,axiom,
! [X: product_prod @ vEBT_VEBT @ nat] :
( ! [A7: $o,B5: $o,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ A7 @ B5 ) @ X5 ) )
=> ( ! [Uu2: option @ ( product_prod @ nat @ nat ),Uv2: list @ vEBT_VEBT,Uw2: vEBT_VEBT,Ux2: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Uu2 @ ( zero_zero @ nat ) @ Uv2 @ Uw2 ) @ Ux2 ) )
=> ~ ! [Uy2: option @ ( product_prod @ nat @ nat ),V3: nat,TreeList3: list @ vEBT_VEBT,S2: vEBT_VEBT,X5: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Uy2 @ ( suc @ V3 ) @ TreeList3 @ S2 ) @ X5 ) ) ) ) ).
% VEBT_internal.naive_member.cases
thf(fact_1363_mult__div__mod__eq,axiom,
! [A: $tType] :
( ( semiring_modulo @ A )
=> ! [B2: A,A3: A] :
( ( plus_plus @ A @ ( times_times @ A @ B2 @ ( divide_divide @ A @ A3 @ B2 ) ) @ ( modulo_modulo @ A @ A3 @ B2 ) )
= A3 ) ) ).
% mult_div_mod_eq
thf(fact_1364_mod__mult__div__eq,axiom,
! [A: $tType] :
( ( semiring_modulo @ A )
=> ! [A3: A,B2: A] :
( ( plus_plus @ A @ ( modulo_modulo @ A @ A3 @ B2 ) @ ( times_times @ A @ B2 @ ( divide_divide @ A @ A3 @ B2 ) ) )
= A3 ) ) ).
% mod_mult_div_eq
thf(fact_1365_mod__div__mult__eq,axiom,
! [A: $tType] :
( ( semiring_modulo @ A )
=> ! [A3: A,B2: A] :
( ( plus_plus @ A @ ( modulo_modulo @ A @ A3 @ B2 ) @ ( times_times @ A @ ( divide_divide @ A @ A3 @ B2 ) @ B2 ) )
= A3 ) ) ).
% mod_div_mult_eq
thf(fact_1366_div__mult__mod__eq,axiom,
! [A: $tType] :
( ( semiring_modulo @ A )
=> ! [A3: A,B2: A] :
( ( plus_plus @ A @ ( times_times @ A @ ( divide_divide @ A @ A3 @ B2 ) @ B2 ) @ ( modulo_modulo @ A @ A3 @ B2 ) )
= A3 ) ) ).
% div_mult_mod_eq
thf(fact_1367_mod__div__decomp,axiom,
! [A: $tType] :
( ( semiring_modulo @ A )
=> ! [A3: A,B2: A] :
( A3
= ( plus_plus @ A @ ( times_times @ A @ ( divide_divide @ A @ A3 @ B2 ) @ B2 ) @ ( modulo_modulo @ A @ A3 @ B2 ) ) ) ) ).
% mod_div_decomp
thf(fact_1368_cancel__div__mod__rules_I1_J,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( plus_plus @ A @ ( plus_plus @ A @ ( times_times @ A @ ( divide_divide @ A @ A3 @ B2 ) @ B2 ) @ ( modulo_modulo @ A @ A3 @ B2 ) ) @ C2 )
= ( plus_plus @ A @ A3 @ C2 ) ) ) ).
% cancel_div_mod_rules(1)
thf(fact_1369_cancel__div__mod__rules_I2_J,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( plus_plus @ A @ ( plus_plus @ A @ ( times_times @ A @ B2 @ ( divide_divide @ A @ A3 @ B2 ) ) @ ( modulo_modulo @ A @ A3 @ B2 ) ) @ C2 )
= ( plus_plus @ A @ A3 @ C2 ) ) ) ).
% cancel_div_mod_rules(2)
thf(fact_1370_div__mult1__eq,axiom,
! [A: $tType] :
( ( euclid3128863361964157862miring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( divide_divide @ A @ ( times_times @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ ( times_times @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) ) @ ( divide_divide @ A @ ( times_times @ A @ A3 @ ( modulo_modulo @ A @ B2 @ C2 ) ) @ C2 ) ) ) ) ).
% div_mult1_eq
thf(fact_1371_invar__vebt_Ointros_I1_J,axiom,
! [A3: $o,B2: $o] : ( vEBT_invar_vebt @ ( vEBT_Leaf @ A3 @ B2 ) @ ( suc @ ( zero_zero @ nat ) ) ) ).
% invar_vebt.intros(1)
thf(fact_1372_unit__dvdE,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ~ ( ( A3
!= ( zero_zero @ A ) )
=> ! [C4: A] :
( B2
!= ( times_times @ A @ A3 @ C4 ) ) ) ) ) ).
% unit_dvdE
thf(fact_1373_unity__coeff__ex,axiom,
! [A: $tType] :
( ( ( dvd @ A )
& ( semiring_0 @ A ) )
=> ! [P2: A > $o,L: A] :
( ( ? [X2: A] : ( P2 @ ( times_times @ A @ L @ X2 ) ) )
= ( ? [X2: A] :
( ( dvd_dvd @ A @ L @ ( plus_plus @ A @ X2 @ ( zero_zero @ A ) ) )
& ( P2 @ X2 ) ) ) ) ) ).
% unity_coeff_ex
thf(fact_1374_dvd__div__div__eq__mult,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,C2: A,B2: A,D2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( C2
!= ( zero_zero @ A ) )
=> ( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( dvd_dvd @ A @ C2 @ D2 )
=> ( ( ( divide_divide @ A @ B2 @ A3 )
= ( divide_divide @ A @ D2 @ C2 ) )
= ( ( times_times @ A @ B2 @ C2 )
= ( times_times @ A @ A3 @ D2 ) ) ) ) ) ) ) ) ).
% dvd_div_div_eq_mult
thf(fact_1375_dvd__div__iff__mult,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( dvd_dvd @ A @ C2 @ B2 )
=> ( ( dvd_dvd @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( dvd_dvd @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 ) ) ) ) ) ).
% dvd_div_iff_mult
thf(fact_1376_div__dvd__iff__mult,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( dvd_dvd @ A @ B2 @ A3 )
=> ( ( dvd_dvd @ A @ ( divide_divide @ A @ A3 @ B2 ) @ C2 )
= ( dvd_dvd @ A @ A3 @ ( times_times @ A @ C2 @ B2 ) ) ) ) ) ) ).
% div_dvd_iff_mult
thf(fact_1377_dvd__div__eq__mult,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( ( divide_divide @ A @ B2 @ A3 )
= C2 )
= ( B2
= ( times_times @ A @ C2 @ A3 ) ) ) ) ) ) ).
% dvd_div_eq_mult
thf(fact_1378_unit__div__eq__0__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( ( divide_divide @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ) ).
% unit_div_eq_0_iff
thf(fact_1379_unit__eq__div1,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( ( divide_divide @ A @ A3 @ B2 )
= C2 )
= ( A3
= ( times_times @ A @ C2 @ B2 ) ) ) ) ) ).
% unit_eq_div1
thf(fact_1380_unit__eq__div2,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( A3
= ( divide_divide @ A @ C2 @ B2 ) )
= ( ( times_times @ A @ A3 @ B2 )
= C2 ) ) ) ) ).
% unit_eq_div2
thf(fact_1381_div__mult__unit2,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( dvd_dvd @ A @ C2 @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ B2 @ A3 )
=> ( ( divide_divide @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) )
= ( divide_divide @ A @ ( divide_divide @ A @ A3 @ B2 ) @ C2 ) ) ) ) ) ).
% div_mult_unit2
thf(fact_1382_unit__div__commute,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( times_times @ A @ ( divide_divide @ A @ A3 @ B2 ) @ C2 )
= ( divide_divide @ A @ ( times_times @ A @ A3 @ C2 ) @ B2 ) ) ) ) ).
% unit_div_commute
thf(fact_1383_unit__div__mult__swap,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( dvd_dvd @ A @ C2 @ ( one_one @ A ) )
=> ( ( times_times @ A @ A3 @ ( divide_divide @ A @ B2 @ C2 ) )
= ( divide_divide @ A @ ( times_times @ A @ A3 @ B2 ) @ C2 ) ) ) ) ).
% unit_div_mult_swap
thf(fact_1384_is__unit__div__mult2__eq,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ C2 @ ( one_one @ A ) )
=> ( ( divide_divide @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) )
= ( divide_divide @ A @ ( divide_divide @ A @ A3 @ B2 ) @ C2 ) ) ) ) ) ).
% is_unit_div_mult2_eq
thf(fact_1385_mod__le__divisor,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less_eq @ nat @ ( modulo_modulo @ nat @ M @ N2 ) @ N2 ) ) ).
% mod_le_divisor
thf(fact_1386_is__unit__power__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,N2: nat] :
( ( dvd_dvd @ A @ ( power_power @ A @ A3 @ N2 ) @ ( one_one @ A ) )
= ( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
| ( N2
= ( zero_zero @ nat ) ) ) ) ) ).
% is_unit_power_iff
thf(fact_1387_vebt__insert_Osimps_I1_J,axiom,
! [X: nat,A3: $o,B2: $o] :
( ( ( X
= ( zero_zero @ nat ) )
=> ( ( vEBT_vebt_insert @ ( vEBT_Leaf @ A3 @ B2 ) @ X )
= ( vEBT_Leaf @ $true @ B2 ) ) )
& ( ( X
!= ( zero_zero @ nat ) )
=> ( ( ( X
= ( one_one @ nat ) )
=> ( ( vEBT_vebt_insert @ ( vEBT_Leaf @ A3 @ B2 ) @ X )
= ( vEBT_Leaf @ A3 @ $true ) ) )
& ( ( X
!= ( one_one @ nat ) )
=> ( ( vEBT_vebt_insert @ ( vEBT_Leaf @ A3 @ B2 ) @ X )
= ( vEBT_Leaf @ A3 @ B2 ) ) ) ) ) ) ).
% vebt_insert.simps(1)
thf(fact_1388_div__less__mono,axiom,
! [A4: nat,B3: nat,N2: nat] :
( ( ord_less @ nat @ A4 @ B3 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ( modulo_modulo @ nat @ A4 @ N2 )
= ( zero_zero @ nat ) )
=> ( ( ( modulo_modulo @ nat @ B3 @ N2 )
= ( zero_zero @ nat ) )
=> ( ord_less @ nat @ ( divide_divide @ nat @ A4 @ N2 ) @ ( divide_divide @ nat @ B3 @ N2 ) ) ) ) ) ) ).
% div_less_mono
thf(fact_1389_nat__mod__eq__lemma,axiom,
! [X: nat,N2: nat,Y: nat] :
( ( ( modulo_modulo @ nat @ X @ N2 )
= ( modulo_modulo @ nat @ Y @ N2 ) )
=> ( ( ord_less_eq @ nat @ Y @ X )
=> ? [Q3: nat] :
( X
= ( plus_plus @ nat @ Y @ ( times_times @ nat @ N2 @ Q3 ) ) ) ) ) ).
% nat_mod_eq_lemma
thf(fact_1390_mod__eq__nat2E,axiom,
! [M: nat,Q2: nat,N2: nat] :
( ( ( modulo_modulo @ nat @ M @ Q2 )
= ( modulo_modulo @ nat @ N2 @ Q2 ) )
=> ( ( ord_less_eq @ nat @ M @ N2 )
=> ~ ! [S2: nat] :
( N2
!= ( plus_plus @ nat @ M @ ( times_times @ nat @ Q2 @ S2 ) ) ) ) ) ).
% mod_eq_nat2E
thf(fact_1391_mod__eq__nat1E,axiom,
! [M: nat,Q2: nat,N2: nat] :
( ( ( modulo_modulo @ nat @ M @ Q2 )
= ( modulo_modulo @ nat @ N2 @ Q2 ) )
=> ( ( ord_less_eq @ nat @ N2 @ M )
=> ~ ! [S2: nat] :
( M
!= ( plus_plus @ nat @ N2 @ ( times_times @ nat @ Q2 @ S2 ) ) ) ) ) ).
% mod_eq_nat1E
thf(fact_1392_vebt__buildup_Osimps_I2_J,axiom,
( ( vEBT_vebt_buildup @ ( suc @ ( zero_zero @ nat ) ) )
= ( vEBT_Leaf @ $false @ $false ) ) ).
% vebt_buildup.simps(2)
thf(fact_1393_vebt__member_Osimps_I1_J,axiom,
! [A3: $o,B2: $o,X: nat] :
( ( vEBT_vebt_member @ ( vEBT_Leaf @ A3 @ B2 ) @ X )
= ( ( ( X
= ( zero_zero @ nat ) )
=> A3 )
& ( ( X
!= ( zero_zero @ nat ) )
=> ( ( ( X
= ( one_one @ nat ) )
=> B2 )
& ( X
= ( one_one @ nat ) ) ) ) ) ) ).
% vebt_member.simps(1)
thf(fact_1394_dvd__imp__le,axiom,
! [K: nat,N2: nat] :
( ( dvd_dvd @ nat @ K @ N2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less_eq @ nat @ K @ N2 ) ) ) ).
% dvd_imp_le
thf(fact_1395_div__mod__decomp,axiom,
! [A4: nat,N2: nat] :
( A4
= ( plus_plus @ nat @ ( times_times @ nat @ ( divide_divide @ nat @ A4 @ N2 ) @ N2 ) @ ( modulo_modulo @ nat @ A4 @ N2 ) ) ) ).
% div_mod_decomp
thf(fact_1396_mod__mult2__eq,axiom,
! [M: nat,N2: nat,Q2: nat] :
( ( modulo_modulo @ nat @ M @ ( times_times @ nat @ N2 @ Q2 ) )
= ( plus_plus @ nat @ ( times_times @ nat @ N2 @ ( modulo_modulo @ nat @ ( divide_divide @ nat @ M @ N2 ) @ Q2 ) ) @ ( modulo_modulo @ nat @ M @ N2 ) ) ) ).
% mod_mult2_eq
thf(fact_1397_dvd__mult__cancel,axiom,
! [K: nat,M: nat,N2: nat] :
( ( dvd_dvd @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( dvd_dvd @ nat @ M @ N2 ) ) ) ).
% dvd_mult_cancel
thf(fact_1398_nat__mult__dvd__cancel1,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ( dvd_dvd @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) )
= ( dvd_dvd @ nat @ M @ N2 ) ) ) ).
% nat_mult_dvd_cancel1
thf(fact_1399_VEBT__internal_Onaive__member_Osimps_I1_J,axiom,
! [A3: $o,B2: $o,X: nat] :
( ( vEBT_V5719532721284313246member @ ( vEBT_Leaf @ A3 @ B2 ) @ X )
= ( ( ( X
= ( zero_zero @ nat ) )
=> A3 )
& ( ( X
!= ( zero_zero @ nat ) )
=> ( ( ( X
= ( one_one @ nat ) )
=> B2 )
& ( X
= ( one_one @ nat ) ) ) ) ) ) ).
% VEBT_internal.naive_member.simps(1)
thf(fact_1400_bezout__add__strong__nat,axiom,
! [A3: nat,B2: nat] :
( ( A3
!= ( zero_zero @ nat ) )
=> ? [D3: nat,X5: nat,Y4: nat] :
( ( dvd_dvd @ nat @ D3 @ A3 )
& ( dvd_dvd @ nat @ D3 @ B2 )
& ( ( times_times @ nat @ A3 @ X5 )
= ( plus_plus @ nat @ ( times_times @ nat @ B2 @ Y4 ) @ D3 ) ) ) ) ).
% bezout_add_strong_nat
thf(fact_1401_VEBT__internal_OminNull_Oelims_I3_J,axiom,
! [X: vEBT_VEBT] :
( ~ ( vEBT_VEBT_minNull @ X )
=> ( ! [Uv2: $o] :
( X
!= ( vEBT_Leaf @ $true @ Uv2 ) )
=> ( ! [Uu2: $o] :
( X
!= ( vEBT_Leaf @ Uu2 @ $true ) )
=> ~ ! [Uz2: product_prod @ nat @ nat,Va3: nat,Vb2: list @ vEBT_VEBT,Vc2: vEBT_VEBT] :
( X
!= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ Uz2 ) @ Va3 @ Vb2 @ Vc2 ) ) ) ) ) ).
% VEBT_internal.minNull.elims(3)
thf(fact_1402_VEBT__internal_Omembermima_Osimps_I2_J,axiom,
! [Ux: list @ vEBT_VEBT,Uy: vEBT_VEBT,Uz: nat] :
~ ( vEBT_VEBT_membermima @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( zero_zero @ nat ) @ Ux @ Uy ) @ Uz ) ).
% VEBT_internal.membermima.simps(2)
thf(fact_1403_option_Osize__gen_I1_J,axiom,
! [A: $tType,X: A > nat] :
( ( size_option @ A @ X @ ( none @ A ) )
= ( suc @ ( zero_zero @ nat ) ) ) ).
% option.size_gen(1)
thf(fact_1404_even__zero,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( zero_zero @ A ) ) ) ).
% even_zero
thf(fact_1405_is__unit__div__mult__cancel__right,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( divide_divide @ A @ A3 @ ( times_times @ A @ B2 @ A3 ) )
= ( divide_divide @ A @ ( one_one @ A ) @ B2 ) ) ) ) ) ).
% is_unit_div_mult_cancel_right
thf(fact_1406_is__unit__div__mult__cancel__left,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( ( divide_divide @ A @ A3 @ ( times_times @ A @ A3 @ B2 ) )
= ( divide_divide @ A @ ( one_one @ A ) @ B2 ) ) ) ) ) ).
% is_unit_div_mult_cancel_left
thf(fact_1407_is__unitE,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,C2: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ~ ( ( A3
!= ( zero_zero @ A ) )
=> ! [B5: A] :
( ( B5
!= ( zero_zero @ A ) )
=> ( ( dvd_dvd @ A @ B5 @ ( one_one @ A ) )
=> ( ( ( divide_divide @ A @ ( one_one @ A ) @ A3 )
= B5 )
=> ( ( ( divide_divide @ A @ ( one_one @ A ) @ B5 )
= A3 )
=> ( ( ( times_times @ A @ A3 @ B5 )
= ( one_one @ A ) )
=> ( ( divide_divide @ A @ C2 @ A3 )
!= ( times_times @ A @ C2 @ B5 ) ) ) ) ) ) ) ) ) ) ).
% is_unitE
thf(fact_1408_odd__even__add,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [A3: A,B2: A] :
( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 )
=> ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( plus_plus @ A @ A3 @ B2 ) ) ) ) ) ).
% odd_even_add
thf(fact_1409_option_Osize_I3_J,axiom,
! [A: $tType] :
( ( size_size @ ( option @ A ) @ ( none @ A ) )
= ( suc @ ( zero_zero @ nat ) ) ) ).
% option.size(3)
thf(fact_1410_dvd__power__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [X: A,M: nat,N2: nat] :
( ( X
!= ( zero_zero @ A ) )
=> ( ( dvd_dvd @ A @ ( power_power @ A @ X @ M ) @ ( power_power @ A @ X @ N2 ) )
= ( ( dvd_dvd @ A @ X @ ( one_one @ A ) )
| ( ord_less_eq @ nat @ M @ N2 ) ) ) ) ) ).
% dvd_power_iff
thf(fact_1411_dvd__power,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [N2: nat,X: A] :
( ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
| ( X
= ( one_one @ A ) ) )
=> ( dvd_dvd @ A @ X @ ( power_power @ A @ X @ N2 ) ) ) ) ).
% dvd_power
thf(fact_1412_split__mod,axiom,
! [P2: nat > $o,M: nat,N2: nat] :
( ( P2 @ ( modulo_modulo @ nat @ M @ N2 ) )
= ( ( ( N2
= ( zero_zero @ nat ) )
=> ( P2 @ M ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ! [I5: nat,J3: nat] :
( ( ord_less @ nat @ J3 @ N2 )
=> ( ( M
= ( plus_plus @ nat @ ( times_times @ nat @ N2 @ I5 ) @ J3 ) )
=> ( P2 @ J3 ) ) ) ) ) ) ).
% split_mod
thf(fact_1413_dvd__mult__cancel1,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ( dvd_dvd @ nat @ ( times_times @ nat @ M @ N2 ) @ M )
= ( N2
= ( one_one @ nat ) ) ) ) ).
% dvd_mult_cancel1
thf(fact_1414_dvd__mult__cancel2,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ( dvd_dvd @ nat @ ( times_times @ nat @ N2 @ M ) @ M )
= ( N2
= ( one_one @ nat ) ) ) ) ).
% dvd_mult_cancel2
thf(fact_1415_power__dvd__imp__le,axiom,
! [I: nat,M: nat,N2: nat] :
( ( dvd_dvd @ nat @ ( power_power @ nat @ I @ M ) @ ( power_power @ nat @ I @ N2 ) )
=> ( ( ord_less @ nat @ ( one_one @ nat ) @ I )
=> ( ord_less_eq @ nat @ M @ N2 ) ) ) ).
% power_dvd_imp_le
thf(fact_1416_unique__euclidean__semiring__numeral__class_Omod__mult2__eq,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( modulo_modulo @ A @ A3 @ ( times_times @ A @ B2 @ C2 ) )
= ( plus_plus @ A @ ( times_times @ A @ B2 @ ( modulo_modulo @ A @ ( divide_divide @ A @ A3 @ B2 ) @ C2 ) ) @ ( modulo_modulo @ A @ A3 @ B2 ) ) ) ) ) ).
% unique_euclidean_semiring_numeral_class.mod_mult2_eq
thf(fact_1417_product__nth,axiom,
! [A: $tType,B: $tType,N2: nat,Xs: list @ A,Ys: list @ B] :
( ( ord_less @ nat @ N2 @ ( times_times @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ B ) @ Ys ) ) )
=> ( ( nth @ ( product_prod @ A @ B ) @ ( product @ A @ B @ Xs @ Ys ) @ N2 )
= ( product_Pair @ A @ B @ ( nth @ A @ Xs @ ( divide_divide @ nat @ N2 @ ( size_size @ ( list @ B ) @ Ys ) ) ) @ ( nth @ B @ Ys @ ( modulo_modulo @ nat @ N2 @ ( size_size @ ( list @ B ) @ Ys ) ) ) ) ) ) ).
% product_nth
thf(fact_1418_power__mono__odd,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: nat,A3: A,B2: A] :
( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ord_less_eq @ A @ ( power_power @ A @ A3 @ N2 ) @ ( power_power @ A @ B2 @ N2 ) ) ) ) ) ).
% power_mono_odd
thf(fact_1419_Suc__times__mod__eq,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( suc @ ( zero_zero @ nat ) ) @ M )
=> ( ( modulo_modulo @ nat @ ( suc @ ( times_times @ nat @ M @ N2 ) ) @ M )
= ( one_one @ nat ) ) ) ).
% Suc_times_mod_eq
thf(fact_1420_odd__pos,axiom,
! [N2: nat] :
( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ).
% odd_pos
thf(fact_1421_dvd__power__iff__le,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ K )
=> ( ( dvd_dvd @ nat @ ( power_power @ nat @ K @ M ) @ ( power_power @ nat @ K @ N2 ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ) ).
% dvd_power_iff_le
thf(fact_1422_even__unset__bit__iff,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,A3: A] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se2638667681897837118et_bit @ A @ M @ A3 ) )
= ( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
| ( M
= ( zero_zero @ nat ) ) ) ) ) ).
% even_unset_bit_iff
thf(fact_1423_even__set__bit__iff,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,A3: A] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se5668285175392031749et_bit @ A @ M @ A3 ) )
= ( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
& ( M
!= ( zero_zero @ nat ) ) ) ) ) ).
% even_set_bit_iff
thf(fact_1424_num_Osize__gen_I1_J,axiom,
( ( size_num @ one2 )
= ( zero_zero @ nat ) ) ).
% num.size_gen(1)
thf(fact_1425_vebt__insert_Osimps_I4_J,axiom,
! [V2: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,X: nat] :
( ( vEBT_vebt_insert @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ ( suc @ V2 ) ) @ TreeList2 @ Summary ) @ X )
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ X @ X ) ) @ ( suc @ ( suc @ V2 ) ) @ TreeList2 @ Summary ) ) ).
% vebt_insert.simps(4)
thf(fact_1426_divmod__digit__0_I2_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less @ A @ ( modulo_modulo @ A @ A3 @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) ) @ B2 )
=> ( ( modulo_modulo @ A @ A3 @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) )
= ( modulo_modulo @ A @ A3 @ B2 ) ) ) ) ) ).
% divmod_digit_0(2)
thf(fact_1427_bits__stable__imp__add__self,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A] :
( ( ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= A3 )
=> ( ( plus_plus @ A @ A3 @ ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) )
= ( zero_zero @ A ) ) ) ) ).
% bits_stable_imp_add_self
thf(fact_1428_div__exp__mod__exp__eq,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,N2: nat,M: nat] :
( ( modulo_modulo @ A @ ( divide_divide @ A @ A3 @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) )
= ( divide_divide @ A @ ( modulo_modulo @ A @ A3 @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( plus_plus @ nat @ N2 @ M ) ) ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ).
% div_exp_mod_exp_eq
thf(fact_1429_oddE,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [A3: A] :
( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ~ ! [B5: A] :
( A3
!= ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B5 ) @ ( one_one @ A ) ) ) ) ) ).
% oddE
thf(fact_1430_zero__le__even__power,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: nat,A3: A] :
( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ N2 ) ) ) ) ).
% zero_le_even_power
thf(fact_1431_zero__le__odd__power,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: nat,A3: A] :
( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ N2 ) )
= ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ) ).
% zero_le_odd_power
thf(fact_1432_zero__le__power__eq,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ N2 ) )
= ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
| ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ) ) ).
% zero_le_power_eq
thf(fact_1433_verit__le__mono__div,axiom,
! [A4: nat,B3: nat,N2: nat] :
( ( ord_less @ nat @ A4 @ B3 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less_eq @ nat
@ ( plus_plus @ nat @ ( divide_divide @ nat @ A4 @ N2 )
@ ( if @ nat
@ ( ( modulo_modulo @ nat @ B3 @ N2 )
= ( zero_zero @ nat ) )
@ ( one_one @ nat )
@ ( zero_zero @ nat ) ) )
@ ( divide_divide @ nat @ B3 @ N2 ) ) ) ) ).
% verit_le_mono_div
thf(fact_1434_divmod__digit__0_I1_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less @ A @ ( modulo_modulo @ A @ A3 @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) ) @ B2 )
=> ( ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( divide_divide @ A @ A3 @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ).
% divmod_digit_0(1)
thf(fact_1435_zero__less__power__eq,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( power_power @ A @ A3 @ N2 ) )
= ( ( N2
= ( zero_zero @ nat ) )
| ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
& ( A3
!= ( zero_zero @ A ) ) )
| ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
& ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ) ) ).
% zero_less_power_eq
thf(fact_1436_mod__double__modulus,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [M: A,X: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ M )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ( modulo_modulo @ A @ X @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) )
= ( modulo_modulo @ A @ X @ M ) )
| ( ( modulo_modulo @ A @ X @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) )
= ( plus_plus @ A @ ( modulo_modulo @ A @ X @ M ) @ M ) ) ) ) ) ) ).
% mod_double_modulus
thf(fact_1437_unset__bit__Suc,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( bit_se2638667681897837118et_bit @ A @ ( suc @ N2 ) @ A3 )
= ( plus_plus @ A @ ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se2638667681897837118et_bit @ A @ N2 @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% unset_bit_Suc
thf(fact_1438_set__bit__Suc,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( bit_se5668285175392031749et_bit @ A @ ( suc @ N2 ) @ A3 )
= ( plus_plus @ A @ ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se5668285175392031749et_bit @ A @ N2 @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% set_bit_Suc
thf(fact_1439_power__le__zero__eq,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less_eq @ A @ ( power_power @ A @ A3 @ N2 ) @ ( zero_zero @ A ) )
= ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
& ( ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
& ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) )
| ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
& ( A3
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% power_le_zero_eq
thf(fact_1440_divmod__digit__1_I1_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less_eq @ A @ B2 @ ( modulo_modulo @ A @ A3 @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) ) )
=> ( ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( divide_divide @ A @ A3 @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) ) ) @ ( one_one @ A ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ) ).
% divmod_digit_1(1)
thf(fact_1441_invar__vebt_Osimps,axiom,
( vEBT_invar_vebt
= ( ^ [A1: vEBT_VEBT,A22: nat] :
( ( ? [A5: $o,B4: $o] :
( A1
= ( vEBT_Leaf @ A5 @ B4 ) )
& ( A22
= ( suc @ ( zero_zero @ nat ) ) ) )
| ? [TreeList: list @ vEBT_VEBT,N: nat,Summary3: vEBT_VEBT] :
( ( A1
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ A22 @ TreeList @ Summary3 ) )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList ) )
=> ( vEBT_invar_vebt @ X2 @ N ) )
& ( vEBT_invar_vebt @ Summary3 @ N )
& ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) )
& ( A22
= ( plus_plus @ nat @ N @ N ) )
& ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ Summary3 @ X8 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
| ? [TreeList: list @ vEBT_VEBT,N: nat,Summary3: vEBT_VEBT] :
( ( A1
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ A22 @ TreeList @ Summary3 ) )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList ) )
=> ( vEBT_invar_vebt @ X2 @ N ) )
& ( vEBT_invar_vebt @ Summary3 @ ( suc @ N ) )
& ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ N ) ) )
& ( A22
= ( plus_plus @ nat @ N @ ( suc @ N ) ) )
& ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ Summary3 @ X8 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
| ? [TreeList: list @ vEBT_VEBT,N: nat,Summary3: vEBT_VEBT,Mi3: nat,Ma3: nat] :
( ( A1
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi3 @ Ma3 ) ) @ A22 @ TreeList @ Summary3 ) )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList ) )
=> ( vEBT_invar_vebt @ X2 @ N ) )
& ( vEBT_invar_vebt @ Summary3 @ N )
& ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) )
& ( A22
= ( plus_plus @ nat @ N @ N ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList @ I5 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary3 @ I5 ) ) )
& ( ( Mi3 = Ma3 )
=> ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
& ( ord_less_eq @ nat @ Mi3 @ Ma3 )
& ( ord_less @ nat @ Ma3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ A22 ) )
& ( ( Mi3 != Ma3 )
=> ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) )
=> ( ( ( ( vEBT_VEBT_high @ Ma3 @ N )
= I5 )
=> ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList @ I5 ) @ ( vEBT_VEBT_low @ Ma3 @ N ) ) )
& ! [X2: nat] :
( ( ( ( vEBT_VEBT_high @ X2 @ N )
= I5 )
& ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList @ I5 ) @ ( vEBT_VEBT_low @ X2 @ N ) ) )
=> ( ( ord_less @ nat @ Mi3 @ X2 )
& ( ord_less_eq @ nat @ X2 @ Ma3 ) ) ) ) ) ) )
| ? [TreeList: list @ vEBT_VEBT,N: nat,Summary3: vEBT_VEBT,Mi3: nat,Ma3: nat] :
( ( A1
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi3 @ Ma3 ) ) @ A22 @ TreeList @ Summary3 ) )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList ) )
=> ( vEBT_invar_vebt @ X2 @ N ) )
& ( vEBT_invar_vebt @ Summary3 @ ( suc @ N ) )
& ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ N ) ) )
& ( A22
= ( plus_plus @ nat @ N @ ( suc @ N ) ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ N ) ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList @ I5 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary3 @ I5 ) ) )
& ( ( Mi3 = Ma3 )
=> ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
& ( ord_less_eq @ nat @ Mi3 @ Ma3 )
& ( ord_less @ nat @ Ma3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ A22 ) )
& ( ( Mi3 != Ma3 )
=> ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ N ) ) )
=> ( ( ( ( vEBT_VEBT_high @ Ma3 @ N )
= I5 )
=> ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList @ I5 ) @ ( vEBT_VEBT_low @ Ma3 @ N ) ) )
& ! [X2: nat] :
( ( ( ( vEBT_VEBT_high @ X2 @ N )
= I5 )
& ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList @ I5 ) @ ( vEBT_VEBT_low @ X2 @ N ) ) )
=> ( ( ord_less @ nat @ Mi3 @ X2 )
& ( ord_less_eq @ nat @ X2 @ Ma3 ) ) ) ) ) ) ) ) ) ) ).
% invar_vebt.simps
thf(fact_1442_invar__vebt_Ocases,axiom,
! [A12: vEBT_VEBT,A23: nat] :
( ( vEBT_invar_vebt @ A12 @ A23 )
=> ( ( ? [A7: $o,B5: $o] :
( A12
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( A23
!= ( suc @ ( zero_zero @ nat ) ) ) )
=> ( ! [TreeList3: list @ vEBT_VEBT,N3: nat,Summary2: vEBT_VEBT,M3: nat,Deg2: nat] :
( ( A12
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Deg2 @ TreeList3 @ Summary2 ) )
=> ( ( A23 = Deg2 )
=> ( ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ( vEBT_invar_vebt @ X3 @ N3 ) )
=> ( ( vEBT_invar_vebt @ Summary2 @ M3 )
=> ( ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M3 ) )
=> ( ( M3 = N3 )
=> ( ( Deg2
= ( plus_plus @ nat @ N3 @ M3 ) )
=> ( ~ ? [X_1: nat] : ( vEBT_V8194947554948674370ptions @ Summary2 @ X_1 )
=> ~ ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X_1: nat] : ( vEBT_V8194947554948674370ptions @ X3 @ X_1 ) ) ) ) ) ) ) ) ) )
=> ( ! [TreeList3: list @ vEBT_VEBT,N3: nat,Summary2: vEBT_VEBT,M3: nat,Deg2: nat] :
( ( A12
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Deg2 @ TreeList3 @ Summary2 ) )
=> ( ( A23 = Deg2 )
=> ( ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ( vEBT_invar_vebt @ X3 @ N3 ) )
=> ( ( vEBT_invar_vebt @ Summary2 @ M3 )
=> ( ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M3 ) )
=> ( ( M3
= ( suc @ N3 ) )
=> ( ( Deg2
= ( plus_plus @ nat @ N3 @ M3 ) )
=> ( ~ ? [X_1: nat] : ( vEBT_V8194947554948674370ptions @ Summary2 @ X_1 )
=> ~ ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X_1: nat] : ( vEBT_V8194947554948674370ptions @ X3 @ X_1 ) ) ) ) ) ) ) ) ) )
=> ( ! [TreeList3: list @ vEBT_VEBT,N3: nat,Summary2: vEBT_VEBT,M3: nat,Deg2: nat,Mi2: nat,Ma2: nat] :
( ( A12
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ Deg2 @ TreeList3 @ Summary2 ) )
=> ( ( A23 = Deg2 )
=> ( ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ( vEBT_invar_vebt @ X3 @ N3 ) )
=> ( ( vEBT_invar_vebt @ Summary2 @ M3 )
=> ( ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M3 ) )
=> ( ( M3 = N3 )
=> ( ( Deg2
= ( plus_plus @ nat @ N3 @ M3 ) )
=> ( ! [I4: nat] :
( ( ord_less @ nat @ I4 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M3 ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I4 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary2 @ I4 ) ) )
=> ( ( ( Mi2 = Ma2 )
=> ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X_1: nat] : ( vEBT_V8194947554948674370ptions @ X3 @ X_1 ) ) )
=> ( ( ord_less_eq @ nat @ Mi2 @ Ma2 )
=> ( ( ord_less @ nat @ Ma2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
=> ~ ( ( Mi2 != Ma2 )
=> ! [I4: nat] :
( ( ord_less @ nat @ I4 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M3 ) )
=> ( ( ( ( vEBT_VEBT_high @ Ma2 @ N3 )
= I4 )
=> ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I4 ) @ ( vEBT_VEBT_low @ Ma2 @ N3 ) ) )
& ! [X3: nat] :
( ( ( ( vEBT_VEBT_high @ X3 @ N3 )
= I4 )
& ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I4 ) @ ( vEBT_VEBT_low @ X3 @ N3 ) ) )
=> ( ( ord_less @ nat @ Mi2 @ X3 )
& ( ord_less_eq @ nat @ X3 @ Ma2 ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) )
=> ~ ! [TreeList3: list @ vEBT_VEBT,N3: nat,Summary2: vEBT_VEBT,M3: nat,Deg2: nat,Mi2: nat,Ma2: nat] :
( ( A12
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ Deg2 @ TreeList3 @ Summary2 ) )
=> ( ( A23 = Deg2 )
=> ( ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ( vEBT_invar_vebt @ X3 @ N3 ) )
=> ( ( vEBT_invar_vebt @ Summary2 @ M3 )
=> ( ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M3 ) )
=> ( ( M3
= ( suc @ N3 ) )
=> ( ( Deg2
= ( plus_plus @ nat @ N3 @ M3 ) )
=> ( ! [I4: nat] :
( ( ord_less @ nat @ I4 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M3 ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I4 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary2 @ I4 ) ) )
=> ( ( ( Mi2 = Ma2 )
=> ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X_1: nat] : ( vEBT_V8194947554948674370ptions @ X3 @ X_1 ) ) )
=> ( ( ord_less_eq @ nat @ Mi2 @ Ma2 )
=> ( ( ord_less @ nat @ Ma2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
=> ~ ( ( Mi2 != Ma2 )
=> ! [I4: nat] :
( ( ord_less @ nat @ I4 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M3 ) )
=> ( ( ( ( vEBT_VEBT_high @ Ma2 @ N3 )
= I4 )
=> ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I4 ) @ ( vEBT_VEBT_low @ Ma2 @ N3 ) ) )
& ! [X3: nat] :
( ( ( ( vEBT_VEBT_high @ X3 @ N3 )
= I4 )
& ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I4 ) @ ( vEBT_VEBT_low @ X3 @ N3 ) ) )
=> ( ( ord_less @ nat @ Mi2 @ X3 )
& ( ord_less_eq @ nat @ X3 @ Ma2 ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ).
% invar_vebt.cases
thf(fact_1443_flip__bit__Suc,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( bit_se8732182000553998342ip_bit @ A @ ( suc @ N2 ) @ A3 )
= ( plus_plus @ A @ ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se8732182000553998342ip_bit @ A @ N2 @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% flip_bit_Suc
thf(fact_1444_signed__take__bit__Suc,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [N2: nat,A3: A] :
( ( bit_ri4674362597316999326ke_bit @ A @ ( suc @ N2 ) @ A3 )
= ( plus_plus @ A @ ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_ri4674362597316999326ke_bit @ A @ N2 @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% signed_take_bit_Suc
thf(fact_1445_vebt__insert_Oelims,axiom,
! [X: vEBT_VEBT,Xa2: nat,Y: vEBT_VEBT] :
( ( ( vEBT_vebt_insert @ X @ Xa2 )
= Y )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ~ ( ( ( Xa2
= ( zero_zero @ nat ) )
=> ( Y
= ( vEBT_Leaf @ $true @ B5 ) ) )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> ( Y
= ( vEBT_Leaf @ A7 @ $true ) ) )
& ( ( Xa2
!= ( one_one @ nat ) )
=> ( Y
= ( vEBT_Leaf @ A7 @ B5 ) ) ) ) ) ) )
=> ( ! [Info2: option @ ( product_prod @ nat @ nat ),Ts2: list @ vEBT_VEBT,S2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Info2 @ ( zero_zero @ nat ) @ Ts2 @ S2 ) )
=> ( Y
!= ( vEBT_Node @ Info2 @ ( zero_zero @ nat ) @ Ts2 @ S2 ) ) )
=> ( ! [Info2: option @ ( product_prod @ nat @ nat ),Ts2: list @ vEBT_VEBT,S2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Info2 @ ( suc @ ( zero_zero @ nat ) ) @ Ts2 @ S2 ) )
=> ( Y
!= ( vEBT_Node @ Info2 @ ( suc @ ( zero_zero @ nat ) ) @ Ts2 @ S2 ) ) )
=> ( ! [V3: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ ( suc @ V3 ) ) @ TreeList3 @ Summary2 ) )
=> ( Y
!= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Xa2 @ Xa2 ) ) @ ( suc @ ( suc @ V3 ) ) @ TreeList3 @ Summary2 ) ) )
=> ~ ! [Mi2: nat,Ma2: nat,Va2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) )
=> ( Y
!= ( if @ vEBT_VEBT
@ ( ( ord_less @ nat @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
& ~ ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 ) ) )
@ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Xa2 @ Mi2 ) @ ( ord_max @ nat @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ Ma2 ) ) ) @ ( suc @ ( suc @ Va2 ) ) @ ( list_update @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) @ ( if @ vEBT_VEBT @ ( vEBT_VEBT_minNull @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) @ ( vEBT_vebt_insert @ Summary2 @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ Summary2 ) )
@ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) ) ) ) ) ) ) ) ) ).
% vebt_insert.elims
thf(fact_1446_even__mult__exp__div__exp__iff,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,M: nat,N2: nat] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( divide_divide @ A @ ( times_times @ A @ A3 @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) ) )
= ( ( ord_less @ nat @ N2 @ M )
| ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 )
= ( zero_zero @ A ) )
| ( ( ord_less_eq @ nat @ M @ N2 )
& ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( divide_divide @ A @ A3 @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ) ) ) ) ).
% even_mult_exp_div_exp_iff
thf(fact_1447_even__flip__bit__iff,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,A3: A] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se8732182000553998342ip_bit @ A @ M @ A3 ) )
= ( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
!= ( M
= ( zero_zero @ nat ) ) ) ) ) ).
% even_flip_bit_iff
thf(fact_1448_one__mod__2__pow__eq,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [N2: nat] :
( ( modulo_modulo @ A @ ( one_one @ A ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( zero_neq_one_of_bool @ A @ ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% one_mod_2_pow_eq
thf(fact_1449_even__mask__div__iff,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [M: nat,N2: nat] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( divide_divide @ A @ ( minus_minus @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) @ ( one_one @ A ) ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) ) )
= ( ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 )
= ( zero_zero @ A ) )
| ( ord_less_eq @ nat @ M @ N2 ) ) ) ) ).
% even_mask_div_iff
thf(fact_1450_divmod__algorithm__code_I3_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [N2: num] :
( ( unique8689654367752047608divmod @ A @ one2 @ ( bit0 @ N2 ) )
= ( product_Pair @ A @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ A @ one2 ) ) ) ) ).
% divmod_algorithm_code(3)
thf(fact_1451_vebt__member_Oelims_I1_J,axiom,
! [X: vEBT_VEBT,Xa2: nat,Y: $o] :
( ( ( vEBT_vebt_member @ X @ Xa2 )
= Y )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( Y
= ( ~ ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) ) ) )
=> ( ( ? [Uu2: nat,Uv2: list @ vEBT_VEBT,Uw2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uu2 @ Uv2 @ Uw2 ) )
=> Y )
=> ( ( ? [V3: product_prod @ nat @ nat,Uy2: list @ vEBT_VEBT,Uz2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( zero_zero @ nat ) @ Uy2 @ Uz2 ) )
=> Y )
=> ( ( ? [V3: product_prod @ nat @ nat,Vb2: list @ vEBT_VEBT,Vc2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( suc @ ( zero_zero @ nat ) ) @ Vb2 @ Vc2 ) )
=> Y )
=> ~ ! [Mi2: nat,Ma2: nat,Va2: nat,TreeList3: list @ vEBT_VEBT] :
( ? [Summary2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) )
=> ( Y
= ( ~ ( ( Xa2 != Mi2 )
=> ( ( Xa2 != Ma2 )
=> ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
& ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
=> ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
& ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
=> ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_vebt_member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ).
% vebt_member.elims(1)
thf(fact_1452_set__vebt_H__def,axiom,
( vEBT_VEBT_set_vebt
= ( ^ [T3: vEBT_VEBT] : ( collect @ nat @ ( vEBT_vebt_member @ T3 ) ) ) ) ).
% set_vebt'_def
thf(fact_1453_minus__apply,axiom,
! [B: $tType,A: $tType] :
( ( minus @ B )
=> ( ( minus_minus @ ( A > B ) )
= ( ^ [A6: A > B,B6: A > B,X2: A] : ( minus_minus @ B @ ( A6 @ X2 ) @ ( B6 @ X2 ) ) ) ) ) ).
% minus_apply
thf(fact_1454_Diff__cancel,axiom,
! [A: $tType,A4: set @ A] :
( ( minus_minus @ ( set @ A ) @ A4 @ A4 )
= ( bot_bot @ ( set @ A ) ) ) ).
% Diff_cancel
thf(fact_1455_empty__Diff,axiom,
! [A: $tType,A4: set @ A] :
( ( minus_minus @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) @ A4 )
= ( bot_bot @ ( set @ A ) ) ) ).
% empty_Diff
thf(fact_1456_Diff__empty,axiom,
! [A: $tType,A4: set @ A] :
( ( minus_minus @ ( set @ A ) @ A4 @ ( bot_bot @ ( set @ A ) ) )
= A4 ) ).
% Diff_empty
thf(fact_1457_cancel__comm__monoid__add__class_Odiff__cancel,axiom,
! [A: $tType] :
( ( cancel1802427076303600483id_add @ A )
=> ! [A3: A] :
( ( minus_minus @ A @ A3 @ A3 )
= ( zero_zero @ A ) ) ) ).
% cancel_comm_monoid_add_class.diff_cancel
thf(fact_1458_diff__zero,axiom,
! [A: $tType] :
( ( cancel1802427076303600483id_add @ A )
=> ! [A3: A] :
( ( minus_minus @ A @ A3 @ ( zero_zero @ A ) )
= A3 ) ) ).
% diff_zero
thf(fact_1459_zero__diff,axiom,
! [A: $tType] :
( ( comm_monoid_diff @ A )
=> ! [A3: A] :
( ( minus_minus @ A @ ( zero_zero @ A ) @ A3 )
= ( zero_zero @ A ) ) ) ).
% zero_diff
thf(fact_1460_diff__0__right,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A] :
( ( minus_minus @ A @ A3 @ ( zero_zero @ A ) )
= A3 ) ) ).
% diff_0_right
thf(fact_1461_diff__self,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A] :
( ( minus_minus @ A @ A3 @ A3 )
= ( zero_zero @ A ) ) ) ).
% diff_self
thf(fact_1462_add__diff__cancel__right_H,axiom,
! [A: $tType] :
( ( cancel2418104881723323429up_add @ A )
=> ! [A3: A,B2: A] :
( ( minus_minus @ A @ ( plus_plus @ A @ A3 @ B2 ) @ B2 )
= A3 ) ) ).
% add_diff_cancel_right'
thf(fact_1463_add__diff__cancel__right,axiom,
! [A: $tType] :
( ( cancel2418104881723323429up_add @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( minus_minus @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ C2 ) )
= ( minus_minus @ A @ A3 @ B2 ) ) ) ).
% add_diff_cancel_right
thf(fact_1464_add__diff__cancel__left_H,axiom,
! [A: $tType] :
( ( cancel2418104881723323429up_add @ A )
=> ! [A3: A,B2: A] :
( ( minus_minus @ A @ ( plus_plus @ A @ A3 @ B2 ) @ A3 )
= B2 ) ) ).
% add_diff_cancel_left'
thf(fact_1465_add__diff__cancel__left,axiom,
! [A: $tType] :
( ( cancel2418104881723323429up_add @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( minus_minus @ A @ ( plus_plus @ A @ C2 @ A3 ) @ ( plus_plus @ A @ C2 @ B2 ) )
= ( minus_minus @ A @ A3 @ B2 ) ) ) ).
% add_diff_cancel_left
thf(fact_1466_diff__add__cancel,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( plus_plus @ A @ ( minus_minus @ A @ A3 @ B2 ) @ B2 )
= A3 ) ) ).
% diff_add_cancel
thf(fact_1467_add__diff__cancel,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( minus_minus @ A @ ( plus_plus @ A @ A3 @ B2 ) @ B2 )
= A3 ) ) ).
% add_diff_cancel
thf(fact_1468_Diff__eq__empty__iff,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ( minus_minus @ ( set @ A ) @ A4 @ B3 )
= ( bot_bot @ ( set @ A ) ) )
= ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ).
% Diff_eq_empty_iff
thf(fact_1469_diff__Suc__Suc,axiom,
! [M: nat,N2: nat] :
( ( minus_minus @ nat @ ( suc @ M ) @ ( suc @ N2 ) )
= ( minus_minus @ nat @ M @ N2 ) ) ).
% diff_Suc_Suc
thf(fact_1470_Suc__diff__diff,axiom,
! [M: nat,N2: nat,K: nat] :
( ( minus_minus @ nat @ ( minus_minus @ nat @ ( suc @ M ) @ N2 ) @ ( suc @ K ) )
= ( minus_minus @ nat @ ( minus_minus @ nat @ M @ N2 ) @ K ) ) ).
% Suc_diff_diff
thf(fact_1471_diff__self__eq__0,axiom,
! [M: nat] :
( ( minus_minus @ nat @ M @ M )
= ( zero_zero @ nat ) ) ).
% diff_self_eq_0
thf(fact_1472_diff__0__eq__0,axiom,
! [N2: nat] :
( ( minus_minus @ nat @ ( zero_zero @ nat ) @ N2 )
= ( zero_zero @ nat ) ) ).
% diff_0_eq_0
thf(fact_1473_diff__diff__cancel,axiom,
! [I: nat,N2: nat] :
( ( ord_less_eq @ nat @ I @ N2 )
=> ( ( minus_minus @ nat @ N2 @ ( minus_minus @ nat @ N2 @ I ) )
= I ) ) ).
% diff_diff_cancel
thf(fact_1474_diff__diff__left,axiom,
! [I: nat,J: nat,K: nat] :
( ( minus_minus @ nat @ ( minus_minus @ nat @ I @ J ) @ K )
= ( minus_minus @ nat @ I @ ( plus_plus @ nat @ J @ K ) ) ) ).
% diff_diff_left
thf(fact_1475_of__bool__less__eq__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [P2: $o,Q: $o] :
( ( ord_less_eq @ A @ ( zero_neq_one_of_bool @ A @ P2 ) @ ( zero_neq_one_of_bool @ A @ Q ) )
= ( P2
=> Q ) ) ) ).
% of_bool_less_eq_iff
thf(fact_1476_of__bool__eq__0__iff,axiom,
! [A: $tType] :
( ( zero_neq_one @ A )
=> ! [P2: $o] :
( ( ( zero_neq_one_of_bool @ A @ P2 )
= ( zero_zero @ A ) )
= ( ~ P2 ) ) ) ).
% of_bool_eq_0_iff
thf(fact_1477_of__bool__eq_I1_J,axiom,
! [A: $tType] :
( ( zero_neq_one @ A )
=> ( ( zero_neq_one_of_bool @ A @ $false )
= ( zero_zero @ A ) ) ) ).
% of_bool_eq(1)
thf(fact_1478_of__bool__less__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [P2: $o,Q: $o] :
( ( ord_less @ A @ ( zero_neq_one_of_bool @ A @ P2 ) @ ( zero_neq_one_of_bool @ A @ Q ) )
= ( ~ P2
& Q ) ) ) ).
% of_bool_less_iff
thf(fact_1479_of__bool__eq_I2_J,axiom,
! [A: $tType] :
( ( zero_neq_one @ A )
=> ( ( zero_neq_one_of_bool @ A @ $true )
= ( one_one @ A ) ) ) ).
% of_bool_eq(2)
thf(fact_1480_of__bool__eq__1__iff,axiom,
! [A: $tType] :
( ( zero_neq_one @ A )
=> ! [P2: $o] :
( ( ( zero_neq_one_of_bool @ A @ P2 )
= ( one_one @ A ) )
= P2 ) ) ).
% of_bool_eq_1_iff
thf(fact_1481_signed__take__bit__of__0,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [N2: nat] :
( ( bit_ri4674362597316999326ke_bit @ A @ N2 @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% signed_take_bit_of_0
thf(fact_1482_of__bool__or__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [P2: $o,Q: $o] :
( ( zero_neq_one_of_bool @ A
@ ( P2
| Q ) )
= ( ord_max @ A @ ( zero_neq_one_of_bool @ A @ P2 ) @ ( zero_neq_one_of_bool @ A @ Q ) ) ) ) ).
% of_bool_or_iff
thf(fact_1483_finite__Collect__subsets,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( finite_finite @ ( set @ A )
@ ( collect @ ( set @ A )
@ ^ [B6: set @ A] : ( ord_less_eq @ ( set @ A ) @ B6 @ A4 ) ) ) ) ).
% finite_Collect_subsets
thf(fact_1484_finite__Collect__less__nat,axiom,
! [K: nat] :
( finite_finite @ nat
@ ( collect @ nat
@ ^ [N: nat] : ( ord_less @ nat @ N @ K ) ) ) ).
% finite_Collect_less_nat
thf(fact_1485_finite__Collect__le__nat,axiom,
! [K: nat] :
( finite_finite @ nat
@ ( collect @ nat
@ ^ [N: nat] : ( ord_less_eq @ nat @ N @ K ) ) ) ).
% finite_Collect_le_nat
thf(fact_1486_diff__ge__0__iff__ge,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( minus_minus @ A @ A3 @ B2 ) )
= ( ord_less_eq @ A @ B2 @ A3 ) ) ) ).
% diff_ge_0_iff_ge
thf(fact_1487_diff__gt__0__iff__gt,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( minus_minus @ A @ A3 @ B2 ) )
= ( ord_less @ A @ B2 @ A3 ) ) ) ).
% diff_gt_0_iff_gt
thf(fact_1488_le__add__diff__inverse,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( plus_plus @ A @ B2 @ ( minus_minus @ A @ A3 @ B2 ) )
= A3 ) ) ) ).
% le_add_diff_inverse
thf(fact_1489_le__add__diff__inverse2,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( plus_plus @ A @ ( minus_minus @ A @ A3 @ B2 ) @ B2 )
= A3 ) ) ) ).
% le_add_diff_inverse2
thf(fact_1490_diff__numeral__special_I9_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ( ( minus_minus @ A @ ( one_one @ A ) @ ( one_one @ A ) )
= ( zero_zero @ A ) ) ) ).
% diff_numeral_special(9)
thf(fact_1491_diff__add__zero,axiom,
! [A: $tType] :
( ( comm_monoid_diff @ A )
=> ! [A3: A,B2: A] :
( ( minus_minus @ A @ A3 @ ( plus_plus @ A @ A3 @ B2 ) )
= ( zero_zero @ A ) ) ) ).
% diff_add_zero
thf(fact_1492_signed__take__bit__Suc__bit0,axiom,
! [N2: nat,K: num] :
( ( bit_ri4674362597316999326ke_bit @ int @ ( suc @ N2 ) @ ( numeral_numeral @ int @ ( bit0 @ K ) ) )
= ( times_times @ int @ ( bit_ri4674362597316999326ke_bit @ int @ N2 @ ( numeral_numeral @ int @ K ) ) @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) ) ).
% signed_take_bit_Suc_bit0
thf(fact_1493_div__diff,axiom,
! [A: $tType] :
( ( idom_modulo @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( dvd_dvd @ A @ C2 @ A3 )
=> ( ( dvd_dvd @ A @ C2 @ B2 )
=> ( ( divide_divide @ A @ ( minus_minus @ A @ A3 @ B2 ) @ C2 )
= ( minus_minus @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) ) ) ) ) ) ).
% div_diff
thf(fact_1494_zero__less__of__bool__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [P2: $o] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( zero_neq_one_of_bool @ A @ P2 ) )
= P2 ) ) ).
% zero_less_of_bool_iff
thf(fact_1495_zero__less__diff,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( minus_minus @ nat @ N2 @ M ) )
= ( ord_less @ nat @ M @ N2 ) ) ).
% zero_less_diff
thf(fact_1496_diff__is__0__eq_H,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( minus_minus @ nat @ M @ N2 )
= ( zero_zero @ nat ) ) ) ).
% diff_is_0_eq'
thf(fact_1497_diff__is__0__eq,axiom,
! [M: nat,N2: nat] :
( ( ( minus_minus @ nat @ M @ N2 )
= ( zero_zero @ nat ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ).
% diff_is_0_eq
thf(fact_1498_of__bool__less__one__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [P2: $o] :
( ( ord_less @ A @ ( zero_neq_one_of_bool @ A @ P2 ) @ ( one_one @ A ) )
= ( ~ P2 ) ) ) ).
% of_bool_less_one_iff
thf(fact_1499_of__bool__not__iff,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [P2: $o] :
( ( zero_neq_one_of_bool @ A @ ~ P2 )
= ( minus_minus @ A @ ( one_one @ A ) @ ( zero_neq_one_of_bool @ A @ P2 ) ) ) ) ).
% of_bool_not_iff
thf(fact_1500_Nat_Oadd__diff__assoc,axiom,
! [K: nat,J: nat,I: nat] :
( ( ord_less_eq @ nat @ K @ J )
=> ( ( plus_plus @ nat @ I @ ( minus_minus @ nat @ J @ K ) )
= ( minus_minus @ nat @ ( plus_plus @ nat @ I @ J ) @ K ) ) ) ).
% Nat.add_diff_assoc
thf(fact_1501_Nat_Oadd__diff__assoc2,axiom,
! [K: nat,J: nat,I: nat] :
( ( ord_less_eq @ nat @ K @ J )
=> ( ( plus_plus @ nat @ ( minus_minus @ nat @ J @ K ) @ I )
= ( minus_minus @ nat @ ( plus_plus @ nat @ J @ I ) @ K ) ) ) ).
% Nat.add_diff_assoc2
thf(fact_1502_Nat_Odiff__diff__right,axiom,
! [K: nat,J: nat,I: nat] :
( ( ord_less_eq @ nat @ K @ J )
=> ( ( minus_minus @ nat @ I @ ( minus_minus @ nat @ J @ K ) )
= ( minus_minus @ nat @ ( plus_plus @ nat @ I @ K ) @ J ) ) ) ).
% Nat.diff_diff_right
thf(fact_1503_diff__Suc__1,axiom,
! [N2: nat] :
( ( minus_minus @ nat @ ( suc @ N2 ) @ ( one_one @ nat ) )
= N2 ) ).
% diff_Suc_1
thf(fact_1504_Suc__0__mod__eq,axiom,
! [N2: nat] :
( ( modulo_modulo @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
= ( zero_neq_one_of_bool @ nat
@ ( N2
!= ( suc @ ( zero_zero @ nat ) ) ) ) ) ).
% Suc_0_mod_eq
thf(fact_1505_signed__take__bit__Suc__1,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [N2: nat] :
( ( bit_ri4674362597316999326ke_bit @ A @ ( suc @ N2 ) @ ( one_one @ A ) )
= ( one_one @ A ) ) ) ).
% signed_take_bit_Suc_1
thf(fact_1506_Suc__pred,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( suc @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) )
= N2 ) ) ).
% Suc_pred
thf(fact_1507_diff__Suc__diff__eq1,axiom,
! [K: nat,J: nat,I: nat] :
( ( ord_less_eq @ nat @ K @ J )
=> ( ( minus_minus @ nat @ I @ ( suc @ ( minus_minus @ nat @ J @ K ) ) )
= ( minus_minus @ nat @ ( plus_plus @ nat @ I @ K ) @ ( suc @ J ) ) ) ) ).
% diff_Suc_diff_eq1
thf(fact_1508_diff__Suc__diff__eq2,axiom,
! [K: nat,J: nat,I: nat] :
( ( ord_less_eq @ nat @ K @ J )
=> ( ( minus_minus @ nat @ ( suc @ ( minus_minus @ nat @ J @ K ) ) @ I )
= ( minus_minus @ nat @ ( suc @ J ) @ ( plus_plus @ nat @ K @ I ) ) ) ) ).
% diff_Suc_diff_eq2
thf(fact_1509_Suc__diff__1,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( suc @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) )
= N2 ) ) ).
% Suc_diff_1
thf(fact_1510_divmod__algorithm__code_I2_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [M: num] :
( ( unique8689654367752047608divmod @ A @ M @ one2 )
= ( product_Pair @ A @ A @ ( numeral_numeral @ A @ M ) @ ( zero_zero @ A ) ) ) ) ).
% divmod_algorithm_code(2)
thf(fact_1511_even__diff,axiom,
! [A: $tType] :
( ( ring_parity @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( minus_minus @ A @ A3 @ B2 ) )
= ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( plus_plus @ A @ A3 @ B2 ) ) ) ) ).
% even_diff
thf(fact_1512_of__bool__half__eq__0,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [B2: $o] :
( ( divide_divide @ A @ ( zero_neq_one_of_bool @ A @ B2 ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( zero_zero @ A ) ) ) ).
% of_bool_half_eq_0
thf(fact_1513_odd__Suc__minus__one,axiom,
! [N2: nat] :
( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( suc @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) )
= N2 ) ) ).
% odd_Suc_minus_one
thf(fact_1514_even__diff__nat,axiom,
! [M: nat,N2: nat] :
( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ M @ N2 ) )
= ( ( ord_less @ nat @ M @ N2 )
| ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( plus_plus @ nat @ M @ N2 ) ) ) ) ).
% even_diff_nat
thf(fact_1515_semiring__parity__class_Oeven__mask__iff,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [N2: nat] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( minus_minus @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) @ ( one_one @ A ) ) )
= ( N2
= ( zero_zero @ nat ) ) ) ) ).
% semiring_parity_class.even_mask_iff
thf(fact_1516_one__div__2__pow__eq,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [N2: nat] :
( ( divide_divide @ A @ ( one_one @ A ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( zero_neq_one_of_bool @ A
@ ( N2
= ( zero_zero @ nat ) ) ) ) ) ).
% one_div_2_pow_eq
thf(fact_1517_bits__1__div__exp,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [N2: nat] :
( ( divide_divide @ A @ ( one_one @ A ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( zero_neq_one_of_bool @ A
@ ( N2
= ( zero_zero @ nat ) ) ) ) ) ).
% bits_1_div_exp
thf(fact_1518_flip__bit__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se8732182000553998342ip_bit @ A @ ( zero_zero @ nat ) @ A3 )
= ( plus_plus @ A @ ( zero_neq_one_of_bool @ A @ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ).
% flip_bit_0
thf(fact_1519_dvd__diff__nat,axiom,
! [K: nat,M: nat,N2: nat] :
( ( dvd_dvd @ nat @ K @ M )
=> ( ( dvd_dvd @ nat @ K @ N2 )
=> ( dvd_dvd @ nat @ K @ ( minus_minus @ nat @ M @ N2 ) ) ) ) ).
% dvd_diff_nat
thf(fact_1520_dvd__antisym,axiom,
! [M: nat,N2: nat] :
( ( dvd_dvd @ nat @ M @ N2 )
=> ( ( dvd_dvd @ nat @ N2 @ M )
=> ( M = N2 ) ) ) ).
% dvd_antisym
thf(fact_1521_pred__subset__eq,axiom,
! [A: $tType,R: set @ A,S3: set @ A] :
( ( ord_less_eq @ ( A > $o )
@ ^ [X2: A] : ( member2 @ A @ X2 @ R )
@ ^ [X2: A] : ( member2 @ A @ X2 @ S3 ) )
= ( ord_less_eq @ ( set @ A ) @ R @ S3 ) ) ).
% pred_subset_eq
thf(fact_1522_prop__restrict,axiom,
! [A: $tType,X: A,Z5: set @ A,X7: set @ A,P2: A > $o] :
( ( member2 @ A @ X @ Z5 )
=> ( ( ord_less_eq @ ( set @ A ) @ Z5
@ ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ X7 )
& ( P2 @ X2 ) ) ) )
=> ( P2 @ X ) ) ) ).
% prop_restrict
thf(fact_1523_Collect__restrict,axiom,
! [A: $tType,X7: set @ A,P2: A > $o] :
( ord_less_eq @ ( set @ A )
@ ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ X7 )
& ( P2 @ X2 ) ) )
@ X7 ) ).
% Collect_restrict
thf(fact_1524_less__eq__set__def,axiom,
! [A: $tType] :
( ( ord_less_eq @ ( set @ A ) )
= ( ^ [A6: set @ A,B6: set @ A] :
( ord_less_eq @ ( A > $o )
@ ^ [X2: A] : ( member2 @ A @ X2 @ A6 )
@ ^ [X2: A] : ( member2 @ A @ X2 @ B6 ) ) ) ) ).
% less_eq_set_def
thf(fact_1525_Collect__subset,axiom,
! [A: $tType,A4: set @ A,P2: A > $o] :
( ord_less_eq @ ( set @ A )
@ ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( P2 @ X2 ) ) )
@ A4 ) ).
% Collect_subset
thf(fact_1526_of__bool__eq__iff,axiom,
! [A: $tType] :
( ( zero_neq_one @ A )
=> ! [P4: $o,Q2: $o] :
( ( ( zero_neq_one_of_bool @ A @ P4 )
= ( zero_neq_one_of_bool @ A @ Q2 ) )
= ( P4 = Q2 ) ) ) ).
% of_bool_eq_iff
thf(fact_1527_diff__commute,axiom,
! [I: nat,J: nat,K: nat] :
( ( minus_minus @ nat @ ( minus_minus @ nat @ I @ J ) @ K )
= ( minus_minus @ nat @ ( minus_minus @ nat @ I @ K ) @ J ) ) ).
% diff_commute
thf(fact_1528_fun__diff__def,axiom,
! [B: $tType,A: $tType] :
( ( minus @ B )
=> ( ( minus_minus @ ( A > B ) )
= ( ^ [A6: A > B,B6: A > B,X2: A] : ( minus_minus @ B @ ( A6 @ X2 ) @ ( B6 @ X2 ) ) ) ) ) ).
% fun_diff_def
thf(fact_1529_diff__eq__diff__eq,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ( minus_minus @ A @ A3 @ B2 )
= ( minus_minus @ A @ C2 @ D2 ) )
=> ( ( A3 = B2 )
= ( C2 = D2 ) ) ) ) ).
% diff_eq_diff_eq
thf(fact_1530_diff__right__commute,axiom,
! [A: $tType] :
( ( cancel2418104881723323429up_add @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( minus_minus @ A @ ( minus_minus @ A @ A3 @ C2 ) @ B2 )
= ( minus_minus @ A @ ( minus_minus @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% diff_right_commute
thf(fact_1531_empty__def,axiom,
! [A: $tType] :
( ( bot_bot @ ( set @ A ) )
= ( collect @ A
@ ^ [X2: A] : $false ) ) ).
% empty_def
thf(fact_1532_pred__equals__eq2,axiom,
! [B: $tType,A: $tType,R: set @ ( product_prod @ A @ B ),S3: set @ ( product_prod @ A @ B )] :
( ( ( ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R ) )
= ( ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ S3 ) ) )
= ( R = S3 ) ) ).
% pred_equals_eq2
thf(fact_1533_lambda__zero,axiom,
! [A: $tType] :
( ( mult_zero @ A )
=> ( ( ^ [H: A] : ( zero_zero @ A ) )
= ( times_times @ A @ ( zero_zero @ A ) ) ) ) ).
% lambda_zero
thf(fact_1534_lambda__one,axiom,
! [A: $tType] :
( ( monoid_mult @ A )
=> ( ( ^ [X2: A] : X2 )
= ( times_times @ A @ ( one_one @ A ) ) ) ) ).
% lambda_one
thf(fact_1535_subset__divisors__dvd,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ ( set @ A )
@ ( collect @ A
@ ^ [C3: A] : ( dvd_dvd @ A @ C3 @ A3 ) )
@ ( collect @ A
@ ^ [C3: A] : ( dvd_dvd @ A @ C3 @ B2 ) ) )
= ( dvd_dvd @ A @ A3 @ B2 ) ) ) ).
% subset_divisors_dvd
thf(fact_1536_max__def__raw,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( ord_max @ A )
= ( ^ [A5: A,B4: A] : ( if @ A @ ( ord_less_eq @ A @ A5 @ B4 ) @ B4 @ A5 ) ) ) ) ).
% max_def_raw
thf(fact_1537_pred__subset__eq2,axiom,
! [B: $tType,A: $tType,R: set @ ( product_prod @ A @ B ),S3: set @ ( product_prod @ A @ B )] :
( ( ord_less_eq @ ( A > B > $o )
@ ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R )
@ ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ S3 ) )
= ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) ) @ R @ S3 ) ) ).
% pred_subset_eq2
thf(fact_1538_strict__subset__divisors__dvd,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ ( set @ A )
@ ( collect @ A
@ ^ [C3: A] : ( dvd_dvd @ A @ C3 @ A3 ) )
@ ( collect @ A
@ ^ [C3: A] : ( dvd_dvd @ A @ C3 @ B2 ) ) )
= ( ( dvd_dvd @ A @ A3 @ B2 )
& ~ ( dvd_dvd @ A @ B2 @ A3 ) ) ) ) ).
% strict_subset_divisors_dvd
thf(fact_1539_bot__empty__eq2,axiom,
! [B: $tType,A: $tType] :
( ( bot_bot @ ( A > B > $o ) )
= ( ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) ) ) ) ).
% bot_empty_eq2
thf(fact_1540_finite__M__bounded__by__nat,axiom,
! [P2: nat > $o,I: nat] :
( finite_finite @ nat
@ ( collect @ nat
@ ^ [K2: nat] :
( ( P2 @ K2 )
& ( ord_less @ nat @ K2 @ I ) ) ) ) ).
% finite_M_bounded_by_nat
thf(fact_1541_finite__less__ub,axiom,
! [F2: nat > nat,U: nat] :
( ! [N3: nat] : ( ord_less_eq @ nat @ N3 @ ( F2 @ N3 ) )
=> ( finite_finite @ nat
@ ( collect @ nat
@ ^ [N: nat] : ( ord_less_eq @ nat @ ( F2 @ N ) @ U ) ) ) ) ).
% finite_less_ub
thf(fact_1542_of__bool__conj,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [P2: $o,Q: $o] :
( ( zero_neq_one_of_bool @ A
@ ( P2
& Q ) )
= ( times_times @ A @ ( zero_neq_one_of_bool @ A @ P2 ) @ ( zero_neq_one_of_bool @ A @ Q ) ) ) ) ).
% of_bool_conj
thf(fact_1543_diff__eq__diff__less__eq,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ( minus_minus @ A @ A3 @ B2 )
= ( minus_minus @ A @ C2 @ D2 ) )
=> ( ( ord_less_eq @ A @ A3 @ B2 )
= ( ord_less_eq @ A @ C2 @ D2 ) ) ) ) ).
% diff_eq_diff_less_eq
thf(fact_1544_diff__right__mono,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ord_less_eq @ A @ ( minus_minus @ A @ A3 @ C2 ) @ ( minus_minus @ A @ B2 @ C2 ) ) ) ) ).
% diff_right_mono
thf(fact_1545_diff__left__mono,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ord_less_eq @ A @ ( minus_minus @ A @ C2 @ A3 ) @ ( minus_minus @ A @ C2 @ B2 ) ) ) ) ).
% diff_left_mono
thf(fact_1546_diff__mono,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A,D2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ D2 @ C2 )
=> ( ord_less_eq @ A @ ( minus_minus @ A @ A3 @ C2 ) @ ( minus_minus @ A @ B2 @ D2 ) ) ) ) ) ).
% diff_mono
thf(fact_1547_eq__iff__diff__eq__0,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ( ( ^ [Y5: A,Z3: A] : ( Y5 = Z3 ) )
= ( ^ [A5: A,B4: A] :
( ( minus_minus @ A @ A5 @ B4 )
= ( zero_zero @ A ) ) ) ) ) ).
% eq_iff_diff_eq_0
thf(fact_1548_diff__strict__right__mono,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ord_less @ A @ ( minus_minus @ A @ A3 @ C2 ) @ ( minus_minus @ A @ B2 @ C2 ) ) ) ) ).
% diff_strict_right_mono
thf(fact_1549_diff__strict__left__mono,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ord_less @ A @ ( minus_minus @ A @ C2 @ A3 ) @ ( minus_minus @ A @ C2 @ B2 ) ) ) ) ).
% diff_strict_left_mono
thf(fact_1550_diff__eq__diff__less,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ( minus_minus @ A @ A3 @ B2 )
= ( minus_minus @ A @ C2 @ D2 ) )
=> ( ( ord_less @ A @ A3 @ B2 )
= ( ord_less @ A @ C2 @ D2 ) ) ) ) ).
% diff_eq_diff_less
thf(fact_1551_diff__strict__mono,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A,D2: A,C2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ D2 @ C2 )
=> ( ord_less @ A @ ( minus_minus @ A @ A3 @ C2 ) @ ( minus_minus @ A @ B2 @ D2 ) ) ) ) ) ).
% diff_strict_mono
thf(fact_1552_left__diff__distrib,axiom,
! [A: $tType] :
( ( ring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( times_times @ A @ ( minus_minus @ A @ A3 @ B2 ) @ C2 )
= ( minus_minus @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) ) ) ) ).
% left_diff_distrib
thf(fact_1553_right__diff__distrib,axiom,
! [A: $tType] :
( ( ring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( times_times @ A @ A3 @ ( minus_minus @ A @ B2 @ C2 ) )
= ( minus_minus @ A @ ( times_times @ A @ A3 @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) ) ) ).
% right_diff_distrib
thf(fact_1554_left__diff__distrib_H,axiom,
! [A: $tType] :
( ( comm_s4317794764714335236cancel @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( times_times @ A @ ( minus_minus @ A @ B2 @ C2 ) @ A3 )
= ( minus_minus @ A @ ( times_times @ A @ B2 @ A3 ) @ ( times_times @ A @ C2 @ A3 ) ) ) ) ).
% left_diff_distrib'
thf(fact_1555_right__diff__distrib_H,axiom,
! [A: $tType] :
( ( comm_s4317794764714335236cancel @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( times_times @ A @ A3 @ ( minus_minus @ A @ B2 @ C2 ) )
= ( minus_minus @ A @ ( times_times @ A @ A3 @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) ) ) ).
% right_diff_distrib'
thf(fact_1556_diff__diff__eq,axiom,
! [A: $tType] :
( ( cancel2418104881723323429up_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( minus_minus @ A @ ( minus_minus @ A @ A3 @ B2 ) @ C2 )
= ( minus_minus @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) ) ) ) ).
% diff_diff_eq
thf(fact_1557_add__implies__diff,axiom,
! [A: $tType] :
( ( cancel1802427076303600483id_add @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ( plus_plus @ A @ C2 @ B2 )
= A3 )
=> ( C2
= ( minus_minus @ A @ A3 @ B2 ) ) ) ) ).
% add_implies_diff
thf(fact_1558_diff__add__eq__diff__diff__swap,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( minus_minus @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) )
= ( minus_minus @ A @ ( minus_minus @ A @ A3 @ C2 ) @ B2 ) ) ) ).
% diff_add_eq_diff_diff_swap
thf(fact_1559_diff__add__eq,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( plus_plus @ A @ ( minus_minus @ A @ A3 @ B2 ) @ C2 )
= ( minus_minus @ A @ ( plus_plus @ A @ A3 @ C2 ) @ B2 ) ) ) ).
% diff_add_eq
thf(fact_1560_diff__diff__eq2,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( minus_minus @ A @ A3 @ ( minus_minus @ A @ B2 @ C2 ) )
= ( minus_minus @ A @ ( plus_plus @ A @ A3 @ C2 ) @ B2 ) ) ) ).
% diff_diff_eq2
thf(fact_1561_add__diff__eq,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( plus_plus @ A @ A3 @ ( minus_minus @ A @ B2 @ C2 ) )
= ( minus_minus @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% add_diff_eq
thf(fact_1562_eq__diff__eq,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( A3
= ( minus_minus @ A @ C2 @ B2 ) )
= ( ( plus_plus @ A @ A3 @ B2 )
= C2 ) ) ) ).
% eq_diff_eq
thf(fact_1563_diff__eq__eq,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ( minus_minus @ A @ A3 @ B2 )
= C2 )
= ( A3
= ( plus_plus @ A @ C2 @ B2 ) ) ) ) ).
% diff_eq_eq
thf(fact_1564_group__cancel_Osub1,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [A4: A,K: A,A3: A,B2: A] :
( ( A4
= ( plus_plus @ A @ K @ A3 ) )
=> ( ( minus_minus @ A @ A4 @ B2 )
= ( plus_plus @ A @ K @ ( minus_minus @ A @ A3 @ B2 ) ) ) ) ) ).
% group_cancel.sub1
thf(fact_1565_add__diff__add,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [A3: A,C2: A,B2: A,D2: A] :
( ( minus_minus @ A @ ( plus_plus @ A @ A3 @ C2 ) @ ( plus_plus @ A @ B2 @ D2 ) )
= ( plus_plus @ A @ ( minus_minus @ A @ A3 @ B2 ) @ ( minus_minus @ A @ C2 @ D2 ) ) ) ) ).
% add_diff_add
thf(fact_1566_diff__divide__distrib,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( divide_divide @ A @ ( minus_minus @ A @ A3 @ B2 ) @ C2 )
= ( minus_minus @ A @ ( divide_divide @ A @ A3 @ C2 ) @ ( divide_divide @ A @ B2 @ C2 ) ) ) ) ).
% diff_divide_distrib
thf(fact_1567_dvd__diff,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [X: A,Y: A,Z: A] :
( ( dvd_dvd @ A @ X @ Y )
=> ( ( dvd_dvd @ A @ X @ Z )
=> ( dvd_dvd @ A @ X @ ( minus_minus @ A @ Y @ Z ) ) ) ) ) ).
% dvd_diff
thf(fact_1568_zero__induct__lemma,axiom,
! [P2: nat > $o,K: nat,I: nat] :
( ( P2 @ K )
=> ( ! [N3: nat] :
( ( P2 @ ( suc @ N3 ) )
=> ( P2 @ N3 ) )
=> ( P2 @ ( minus_minus @ nat @ K @ I ) ) ) ) ).
% zero_induct_lemma
thf(fact_1569_double__diff,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,C5: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ C5 )
=> ( ( minus_minus @ ( set @ A ) @ B3 @ ( minus_minus @ ( set @ A ) @ C5 @ A4 ) )
= A4 ) ) ) ).
% double_diff
thf(fact_1570_Diff__subset,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] : ( ord_less_eq @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) @ A4 ) ).
% Diff_subset
thf(fact_1571_Diff__mono,axiom,
! [A: $tType,A4: set @ A,C5: set @ A,D6: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ D6 @ B3 )
=> ( ord_less_eq @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) @ ( minus_minus @ ( set @ A ) @ C5 @ D6 ) ) ) ) ).
% Diff_mono
thf(fact_1572_diffs0__imp__equal,axiom,
! [M: nat,N2: nat] :
( ( ( minus_minus @ nat @ M @ N2 )
= ( zero_zero @ nat ) )
=> ( ( ( minus_minus @ nat @ N2 @ M )
= ( zero_zero @ nat ) )
=> ( M = N2 ) ) ) ).
% diffs0_imp_equal
thf(fact_1573_minus__nat_Odiff__0,axiom,
! [M: nat] :
( ( minus_minus @ nat @ M @ ( zero_zero @ nat ) )
= M ) ).
% minus_nat.diff_0
thf(fact_1574_less__imp__diff__less,axiom,
! [J: nat,K: nat,N2: nat] :
( ( ord_less @ nat @ J @ K )
=> ( ord_less @ nat @ ( minus_minus @ nat @ J @ N2 ) @ K ) ) ).
% less_imp_diff_less
thf(fact_1575_diff__less__mono2,axiom,
! [M: nat,N2: nat,L: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ( ( ord_less @ nat @ M @ L )
=> ( ord_less @ nat @ ( minus_minus @ nat @ L @ N2 ) @ ( minus_minus @ nat @ L @ M ) ) ) ) ).
% diff_less_mono2
thf(fact_1576_dvd__minus__self,axiom,
! [M: nat,N2: nat] :
( ( dvd_dvd @ nat @ M @ ( minus_minus @ nat @ N2 @ M ) )
= ( ( ord_less @ nat @ N2 @ M )
| ( dvd_dvd @ nat @ M @ N2 ) ) ) ).
% dvd_minus_self
thf(fact_1577_diff__le__mono2,axiom,
! [M: nat,N2: nat,L: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ord_less_eq @ nat @ ( minus_minus @ nat @ L @ N2 ) @ ( minus_minus @ nat @ L @ M ) ) ) ).
% diff_le_mono2
thf(fact_1578_le__diff__iff_H,axiom,
! [A3: nat,C2: nat,B2: nat] :
( ( ord_less_eq @ nat @ A3 @ C2 )
=> ( ( ord_less_eq @ nat @ B2 @ C2 )
=> ( ( ord_less_eq @ nat @ ( minus_minus @ nat @ C2 @ A3 ) @ ( minus_minus @ nat @ C2 @ B2 ) )
= ( ord_less_eq @ nat @ B2 @ A3 ) ) ) ) ).
% le_diff_iff'
thf(fact_1579_diff__le__self,axiom,
! [M: nat,N2: nat] : ( ord_less_eq @ nat @ ( minus_minus @ nat @ M @ N2 ) @ M ) ).
% diff_le_self
thf(fact_1580_diff__le__mono,axiom,
! [M: nat,N2: nat,L: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ord_less_eq @ nat @ ( minus_minus @ nat @ M @ L ) @ ( minus_minus @ nat @ N2 @ L ) ) ) ).
% diff_le_mono
thf(fact_1581_Nat_Odiff__diff__eq,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ M )
=> ( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( minus_minus @ nat @ ( minus_minus @ nat @ M @ K ) @ ( minus_minus @ nat @ N2 @ K ) )
= ( minus_minus @ nat @ M @ N2 ) ) ) ) ).
% Nat.diff_diff_eq
thf(fact_1582_le__diff__iff,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ M )
=> ( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( ord_less_eq @ nat @ ( minus_minus @ nat @ M @ K ) @ ( minus_minus @ nat @ N2 @ K ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ) ) ).
% le_diff_iff
thf(fact_1583_eq__diff__iff,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ M )
=> ( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( ( minus_minus @ nat @ M @ K )
= ( minus_minus @ nat @ N2 @ K ) )
= ( M = N2 ) ) ) ) ).
% eq_diff_iff
thf(fact_1584_less__eq__dvd__minus,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( dvd_dvd @ nat @ M @ N2 )
= ( dvd_dvd @ nat @ M @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ).
% less_eq_dvd_minus
thf(fact_1585_dvd__diffD1,axiom,
! [K: nat,M: nat,N2: nat] :
( ( dvd_dvd @ nat @ K @ ( minus_minus @ nat @ M @ N2 ) )
=> ( ( dvd_dvd @ nat @ K @ M )
=> ( ( ord_less_eq @ nat @ N2 @ M )
=> ( dvd_dvd @ nat @ K @ N2 ) ) ) ) ).
% dvd_diffD1
thf(fact_1586_dvd__diffD,axiom,
! [K: nat,M: nat,N2: nat] :
( ( dvd_dvd @ nat @ K @ ( minus_minus @ nat @ M @ N2 ) )
=> ( ( dvd_dvd @ nat @ K @ N2 )
=> ( ( ord_less_eq @ nat @ N2 @ M )
=> ( dvd_dvd @ nat @ K @ M ) ) ) ) ).
% dvd_diffD
thf(fact_1587_diff__add__inverse2,axiom,
! [M: nat,N2: nat] :
( ( minus_minus @ nat @ ( plus_plus @ nat @ M @ N2 ) @ N2 )
= M ) ).
% diff_add_inverse2
thf(fact_1588_diff__add__inverse,axiom,
! [N2: nat,M: nat] :
( ( minus_minus @ nat @ ( plus_plus @ nat @ N2 @ M ) @ N2 )
= M ) ).
% diff_add_inverse
thf(fact_1589_diff__cancel2,axiom,
! [M: nat,K: nat,N2: nat] :
( ( minus_minus @ nat @ ( plus_plus @ nat @ M @ K ) @ ( plus_plus @ nat @ N2 @ K ) )
= ( minus_minus @ nat @ M @ N2 ) ) ).
% diff_cancel2
thf(fact_1590_Nat_Odiff__cancel,axiom,
! [K: nat,M: nat,N2: nat] :
( ( minus_minus @ nat @ ( plus_plus @ nat @ K @ M ) @ ( plus_plus @ nat @ K @ N2 ) )
= ( minus_minus @ nat @ M @ N2 ) ) ).
% Nat.diff_cancel
thf(fact_1591_diff__mult__distrib,axiom,
! [M: nat,N2: nat,K: nat] :
( ( times_times @ nat @ ( minus_minus @ nat @ M @ N2 ) @ K )
= ( minus_minus @ nat @ ( times_times @ nat @ M @ K ) @ ( times_times @ nat @ N2 @ K ) ) ) ).
% diff_mult_distrib
thf(fact_1592_diff__mult__distrib2,axiom,
! [K: nat,M: nat,N2: nat] :
( ( times_times @ nat @ K @ ( minus_minus @ nat @ M @ N2 ) )
= ( minus_minus @ nat @ ( times_times @ nat @ K @ M ) @ ( times_times @ nat @ K @ N2 ) ) ) ).
% diff_mult_distrib2
thf(fact_1593_max__diff__distrib__left,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [X: A,Y: A,Z: A] :
( ( minus_minus @ A @ ( ord_max @ A @ X @ Y ) @ Z )
= ( ord_max @ A @ ( minus_minus @ A @ X @ Z ) @ ( minus_minus @ A @ Y @ Z ) ) ) ) ).
% max_diff_distrib_left
thf(fact_1594_numeral__code_I2_J,axiom,
! [A: $tType] :
( ( numeral @ A )
=> ! [N2: num] :
( ( numeral_numeral @ A @ ( bit0 @ N2 ) )
= ( plus_plus @ A @ ( numeral_numeral @ A @ N2 ) @ ( numeral_numeral @ A @ N2 ) ) ) ) ).
% numeral_code(2)
thf(fact_1595_set__vebt__def,axiom,
( vEBT_set_vebt
= ( ^ [T3: vEBT_VEBT] : ( collect @ nat @ ( vEBT_V8194947554948674370ptions @ T3 ) ) ) ) ).
% set_vebt_def
thf(fact_1596_finite__divisors__nat,axiom,
! [M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( finite_finite @ nat
@ ( collect @ nat
@ ^ [D5: nat] : ( dvd_dvd @ nat @ D5 @ M ) ) ) ) ).
% finite_divisors_nat
thf(fact_1597_signed__take__bit__int__less__eq,axiom,
! [N2: nat,K: int] :
( ( ord_less_eq @ int @ ( power_power @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ N2 ) @ K )
=> ( ord_less_eq @ int @ ( bit_ri4674362597316999326ke_bit @ int @ N2 @ K ) @ ( minus_minus @ int @ K @ ( power_power @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ ( suc @ N2 ) ) ) ) ) ).
% signed_take_bit_int_less_eq
thf(fact_1598_zero__less__eq__of__bool,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [P2: $o] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( zero_neq_one_of_bool @ A @ P2 ) ) ) ).
% zero_less_eq_of_bool
thf(fact_1599_of__bool__less__eq__one,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [P2: $o] : ( ord_less_eq @ A @ ( zero_neq_one_of_bool @ A @ P2 ) @ ( one_one @ A ) ) ) ).
% of_bool_less_eq_one
thf(fact_1600_of__bool__def,axiom,
! [A: $tType] :
( ( zero_neq_one @ A )
=> ( ( zero_neq_one_of_bool @ A )
= ( ^ [P6: $o] : ( if @ A @ P6 @ ( one_one @ A ) @ ( zero_zero @ A ) ) ) ) ) ).
% of_bool_def
thf(fact_1601_split__of__bool,axiom,
! [A: $tType] :
( ( zero_neq_one @ A )
=> ! [P2: A > $o,P4: $o] :
( ( P2 @ ( zero_neq_one_of_bool @ A @ P4 ) )
= ( ( P4
=> ( P2 @ ( one_one @ A ) ) )
& ( ~ P4
=> ( P2 @ ( zero_zero @ A ) ) ) ) ) ) ).
% split_of_bool
thf(fact_1602_split__of__bool__asm,axiom,
! [A: $tType] :
( ( zero_neq_one @ A )
=> ! [P2: A > $o,P4: $o] :
( ( P2 @ ( zero_neq_one_of_bool @ A @ P4 ) )
= ( ~ ( ( P4
& ~ ( P2 @ ( one_one @ A ) ) )
| ( ~ P4
& ~ ( P2 @ ( zero_zero @ A ) ) ) ) ) ) ) ).
% split_of_bool_asm
thf(fact_1603_le__iff__diff__le__0,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [A5: A,B4: A] : ( ord_less_eq @ A @ ( minus_minus @ A @ A5 @ B4 ) @ ( zero_zero @ A ) ) ) ) ) ).
% le_iff_diff_le_0
thf(fact_1604_less__iff__diff__less__0,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ( ( ord_less @ A )
= ( ^ [A5: A,B4: A] : ( ord_less @ A @ ( minus_minus @ A @ A5 @ B4 ) @ ( zero_zero @ A ) ) ) ) ) ).
% less_iff_diff_less_0
thf(fact_1605_diff__le__eq,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ ( minus_minus @ A @ A3 @ B2 ) @ C2 )
= ( ord_less_eq @ A @ A3 @ ( plus_plus @ A @ C2 @ B2 ) ) ) ) ).
% diff_le_eq
thf(fact_1606_le__diff__eq,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ ( minus_minus @ A @ C2 @ B2 ) )
= ( ord_less_eq @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% le_diff_eq
thf(fact_1607_diff__add,axiom,
! [A: $tType] :
( ( ordere1170586879665033532d_diff @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( plus_plus @ A @ ( minus_minus @ A @ B2 @ A3 ) @ A3 )
= B2 ) ) ) ).
% diff_add
thf(fact_1608_le__add__diff,axiom,
! [A: $tType] :
( ( ordere1170586879665033532d_diff @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ord_less_eq @ A @ C2 @ ( minus_minus @ A @ ( plus_plus @ A @ B2 @ C2 ) @ A3 ) ) ) ) ).
% le_add_diff
thf(fact_1609_ordered__cancel__comm__monoid__diff__class_Ole__diff__conv2,axiom,
! [A: $tType] :
( ( ordere1170586879665033532d_diff @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ ( minus_minus @ A @ B2 @ A3 ) )
= ( ord_less_eq @ A @ ( plus_plus @ A @ C2 @ A3 ) @ B2 ) ) ) ) ).
% ordered_cancel_comm_monoid_diff_class.le_diff_conv2
thf(fact_1610_ordered__cancel__comm__monoid__diff__class_Oadd__diff__assoc,axiom,
! [A: $tType] :
( ( ordere1170586879665033532d_diff @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( plus_plus @ A @ C2 @ ( minus_minus @ A @ B2 @ A3 ) )
= ( minus_minus @ A @ ( plus_plus @ A @ C2 @ B2 ) @ A3 ) ) ) ) ).
% ordered_cancel_comm_monoid_diff_class.add_diff_assoc
thf(fact_1611_ordered__cancel__comm__monoid__diff__class_Odiff__add__assoc,axiom,
! [A: $tType] :
( ( ordere1170586879665033532d_diff @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( minus_minus @ A @ ( plus_plus @ A @ C2 @ B2 ) @ A3 )
= ( plus_plus @ A @ C2 @ ( minus_minus @ A @ B2 @ A3 ) ) ) ) ) ).
% ordered_cancel_comm_monoid_diff_class.diff_add_assoc
thf(fact_1612_ordered__cancel__comm__monoid__diff__class_Oadd__diff__assoc2,axiom,
! [A: $tType] :
( ( ordere1170586879665033532d_diff @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( plus_plus @ A @ ( minus_minus @ A @ B2 @ A3 ) @ C2 )
= ( minus_minus @ A @ ( plus_plus @ A @ B2 @ C2 ) @ A3 ) ) ) ) ).
% ordered_cancel_comm_monoid_diff_class.add_diff_assoc2
thf(fact_1613_ordered__cancel__comm__monoid__diff__class_Odiff__add__assoc2,axiom,
! [A: $tType] :
( ( ordere1170586879665033532d_diff @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( minus_minus @ A @ ( plus_plus @ A @ B2 @ C2 ) @ A3 )
= ( plus_plus @ A @ ( minus_minus @ A @ B2 @ A3 ) @ C2 ) ) ) ) ).
% ordered_cancel_comm_monoid_diff_class.diff_add_assoc2
thf(fact_1614_ordered__cancel__comm__monoid__diff__class_Odiff__diff__right,axiom,
! [A: $tType] :
( ( ordere1170586879665033532d_diff @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( minus_minus @ A @ C2 @ ( minus_minus @ A @ B2 @ A3 ) )
= ( minus_minus @ A @ ( plus_plus @ A @ C2 @ A3 ) @ B2 ) ) ) ) ).
% ordered_cancel_comm_monoid_diff_class.diff_diff_right
thf(fact_1615_ordered__cancel__comm__monoid__diff__class_Oadd__diff__inverse,axiom,
! [A: $tType] :
( ( ordere1170586879665033532d_diff @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( plus_plus @ A @ A3 @ ( minus_minus @ A @ B2 @ A3 ) )
= B2 ) ) ) ).
% ordered_cancel_comm_monoid_diff_class.add_diff_inverse
thf(fact_1616_ordered__cancel__comm__monoid__diff__class_Ole__imp__diff__is__add,axiom,
! [A: $tType] :
( ( ordere1170586879665033532d_diff @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ( minus_minus @ A @ B2 @ A3 )
= C2 )
= ( B2
= ( plus_plus @ A @ C2 @ A3 ) ) ) ) ) ) ).
% ordered_cancel_comm_monoid_diff_class.le_imp_diff_is_add
thf(fact_1617_add__le__imp__le__diff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [I: A,K: A,N2: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ I @ K ) @ N2 )
=> ( ord_less_eq @ A @ I @ ( minus_minus @ A @ N2 @ K ) ) ) ) ).
% add_le_imp_le_diff
thf(fact_1618_add__le__add__imp__diff__le,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [I: A,K: A,N2: A,J: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ I @ K ) @ N2 )
=> ( ( ord_less_eq @ A @ N2 @ ( plus_plus @ A @ J @ K ) )
=> ( ( ord_less_eq @ A @ ( plus_plus @ A @ I @ K ) @ N2 )
=> ( ( ord_less_eq @ A @ N2 @ ( plus_plus @ A @ J @ K ) )
=> ( ord_less_eq @ A @ ( minus_minus @ A @ N2 @ K ) @ J ) ) ) ) ) ) ).
% add_le_add_imp_diff_le
thf(fact_1619_diff__less__eq,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ ( minus_minus @ A @ A3 @ B2 ) @ C2 )
= ( ord_less @ A @ A3 @ ( plus_plus @ A @ C2 @ B2 ) ) ) ) ).
% diff_less_eq
thf(fact_1620_less__diff__eq,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less @ A @ A3 @ ( minus_minus @ A @ C2 @ B2 ) )
= ( ord_less @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% less_diff_eq
thf(fact_1621_linordered__semidom__class_Oadd__diff__inverse,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [A3: A,B2: A] :
( ~ ( ord_less @ A @ A3 @ B2 )
=> ( ( plus_plus @ A @ B2 @ ( minus_minus @ A @ A3 @ B2 ) )
= A3 ) ) ) ).
% linordered_semidom_class.add_diff_inverse
thf(fact_1622_square__diff__square__factored,axiom,
! [A: $tType] :
( ( comm_ring @ A )
=> ! [X: A,Y: A] :
( ( minus_minus @ A @ ( times_times @ A @ X @ X ) @ ( times_times @ A @ Y @ Y ) )
= ( times_times @ A @ ( plus_plus @ A @ X @ Y ) @ ( minus_minus @ A @ X @ Y ) ) ) ) ).
% square_diff_square_factored
thf(fact_1623_eq__add__iff2,axiom,
! [A: $tType] :
( ( ring @ A )
=> ! [A3: A,E3: A,C2: A,B2: A,D2: A] :
( ( ( plus_plus @ A @ ( times_times @ A @ A3 @ E3 ) @ C2 )
= ( plus_plus @ A @ ( times_times @ A @ B2 @ E3 ) @ D2 ) )
= ( C2
= ( plus_plus @ A @ ( times_times @ A @ ( minus_minus @ A @ B2 @ A3 ) @ E3 ) @ D2 ) ) ) ) ).
% eq_add_iff2
thf(fact_1624_eq__add__iff1,axiom,
! [A: $tType] :
( ( ring @ A )
=> ! [A3: A,E3: A,C2: A,B2: A,D2: A] :
( ( ( plus_plus @ A @ ( times_times @ A @ A3 @ E3 ) @ C2 )
= ( plus_plus @ A @ ( times_times @ A @ B2 @ E3 ) @ D2 ) )
= ( ( plus_plus @ A @ ( times_times @ A @ ( minus_minus @ A @ A3 @ B2 ) @ E3 ) @ C2 )
= D2 ) ) ) ).
% eq_add_iff1
thf(fact_1625_mult__diff__mult,axiom,
! [A: $tType] :
( ( ring @ A )
=> ! [X: A,Y: A,A3: A,B2: A] :
( ( minus_minus @ A @ ( times_times @ A @ X @ Y ) @ ( times_times @ A @ A3 @ B2 ) )
= ( plus_plus @ A @ ( times_times @ A @ X @ ( minus_minus @ A @ Y @ B2 ) ) @ ( times_times @ A @ ( minus_minus @ A @ X @ A3 ) @ B2 ) ) ) ) ).
% mult_diff_mult
thf(fact_1626_dvd__minus__mod,axiom,
! [A: $tType] :
( ( semidom_modulo @ A )
=> ! [B2: A,A3: A] : ( dvd_dvd @ A @ B2 @ ( minus_minus @ A @ A3 @ ( modulo_modulo @ A @ A3 @ B2 ) ) ) ) ).
% dvd_minus_mod
thf(fact_1627_Suc__diff__Suc,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ N2 @ M )
=> ( ( suc @ ( minus_minus @ nat @ M @ ( suc @ N2 ) ) )
= ( minus_minus @ nat @ M @ N2 ) ) ) ).
% Suc_diff_Suc
thf(fact_1628_diff__less__Suc,axiom,
! [M: nat,N2: nat] : ( ord_less @ nat @ ( minus_minus @ nat @ M @ N2 ) @ ( suc @ M ) ) ).
% diff_less_Suc
thf(fact_1629_diff__less,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ord_less @ nat @ ( minus_minus @ nat @ M @ N2 ) @ M ) ) ) ).
% diff_less
thf(fact_1630_Suc__diff__le,axiom,
! [N2: nat,M: nat] :
( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( minus_minus @ nat @ ( suc @ M ) @ N2 )
= ( suc @ ( minus_minus @ nat @ M @ N2 ) ) ) ) ).
% Suc_diff_le
thf(fact_1631_diff__less__mono,axiom,
! [A3: nat,B2: nat,C2: nat] :
( ( ord_less @ nat @ A3 @ B2 )
=> ( ( ord_less_eq @ nat @ C2 @ A3 )
=> ( ord_less @ nat @ ( minus_minus @ nat @ A3 @ C2 ) @ ( minus_minus @ nat @ B2 @ C2 ) ) ) ) ).
% diff_less_mono
thf(fact_1632_less__diff__iff,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ M )
=> ( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( ord_less @ nat @ ( minus_minus @ nat @ M @ K ) @ ( minus_minus @ nat @ N2 @ K ) )
= ( ord_less @ nat @ M @ N2 ) ) ) ) ).
% less_diff_iff
thf(fact_1633_diff__add__0,axiom,
! [N2: nat,M: nat] :
( ( minus_minus @ nat @ N2 @ ( plus_plus @ nat @ N2 @ M ) )
= ( zero_zero @ nat ) ) ).
% diff_add_0
thf(fact_1634_less__diff__conv,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less @ nat @ I @ ( minus_minus @ nat @ J @ K ) )
= ( ord_less @ nat @ ( plus_plus @ nat @ I @ K ) @ J ) ) ).
% less_diff_conv
thf(fact_1635_add__diff__inverse__nat,axiom,
! [M: nat,N2: nat] :
( ~ ( ord_less @ nat @ M @ N2 )
=> ( ( plus_plus @ nat @ N2 @ ( minus_minus @ nat @ M @ N2 ) )
= M ) ) ).
% add_diff_inverse_nat
thf(fact_1636_le__diff__conv,axiom,
! [J: nat,K: nat,I: nat] :
( ( ord_less_eq @ nat @ ( minus_minus @ nat @ J @ K ) @ I )
= ( ord_less_eq @ nat @ J @ ( plus_plus @ nat @ I @ K ) ) ) ).
% le_diff_conv
thf(fact_1637_Nat_Ole__diff__conv2,axiom,
! [K: nat,J: nat,I: nat] :
( ( ord_less_eq @ nat @ K @ J )
=> ( ( ord_less_eq @ nat @ I @ ( minus_minus @ nat @ J @ K ) )
= ( ord_less_eq @ nat @ ( plus_plus @ nat @ I @ K ) @ J ) ) ) ).
% Nat.le_diff_conv2
thf(fact_1638_Nat_Odiff__add__assoc,axiom,
! [K: nat,J: nat,I: nat] :
( ( ord_less_eq @ nat @ K @ J )
=> ( ( minus_minus @ nat @ ( plus_plus @ nat @ I @ J ) @ K )
= ( plus_plus @ nat @ I @ ( minus_minus @ nat @ J @ K ) ) ) ) ).
% Nat.diff_add_assoc
thf(fact_1639_Nat_Odiff__add__assoc2,axiom,
! [K: nat,J: nat,I: nat] :
( ( ord_less_eq @ nat @ K @ J )
=> ( ( minus_minus @ nat @ ( plus_plus @ nat @ J @ I ) @ K )
= ( plus_plus @ nat @ ( minus_minus @ nat @ J @ K ) @ I ) ) ) ).
% Nat.diff_add_assoc2
thf(fact_1640_Nat_Ole__imp__diff__is__add,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( ( minus_minus @ nat @ J @ I )
= K )
= ( J
= ( plus_plus @ nat @ K @ I ) ) ) ) ).
% Nat.le_imp_diff_is_add
thf(fact_1641_diff__Suc__eq__diff__pred,axiom,
! [M: nat,N2: nat] :
( ( minus_minus @ nat @ M @ ( suc @ N2 ) )
= ( minus_minus @ nat @ ( minus_minus @ nat @ M @ ( one_one @ nat ) ) @ N2 ) ) ).
% diff_Suc_eq_diff_pred
thf(fact_1642_mod__geq,axiom,
! [M: nat,N2: nat] :
( ~ ( ord_less @ nat @ M @ N2 )
=> ( ( modulo_modulo @ nat @ M @ N2 )
= ( modulo_modulo @ nat @ ( minus_minus @ nat @ M @ N2 ) @ N2 ) ) ) ).
% mod_geq
thf(fact_1643_mod__if,axiom,
( ( modulo_modulo @ nat )
= ( ^ [M2: nat,N: nat] : ( if @ nat @ ( ord_less @ nat @ M2 @ N ) @ M2 @ ( modulo_modulo @ nat @ ( minus_minus @ nat @ M2 @ N ) @ N ) ) ) ) ).
% mod_if
thf(fact_1644_le__mod__geq,axiom,
! [N2: nat,M: nat] :
( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( modulo_modulo @ nat @ M @ N2 )
= ( modulo_modulo @ nat @ ( minus_minus @ nat @ M @ N2 ) @ N2 ) ) ) ).
% le_mod_geq
thf(fact_1645_mod__eq__dvd__iff__nat,axiom,
! [N2: nat,M: nat,Q2: nat] :
( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( ( modulo_modulo @ nat @ M @ Q2 )
= ( modulo_modulo @ nat @ N2 @ Q2 ) )
= ( dvd_dvd @ nat @ Q2 @ ( minus_minus @ nat @ M @ N2 ) ) ) ) ).
% mod_eq_dvd_iff_nat
thf(fact_1646_nat__minus__add__max,axiom,
! [N2: nat,M: nat] :
( ( plus_plus @ nat @ ( minus_minus @ nat @ N2 @ M ) @ M )
= ( ord_max @ nat @ N2 @ M ) ) ).
% nat_minus_add_max
thf(fact_1647_finite__lists__length__eq,axiom,
! [A: $tType,A4: set @ A,N2: nat] :
( ( finite_finite @ A @ A4 )
=> ( finite_finite @ ( list @ A )
@ ( collect @ ( list @ A )
@ ^ [Xs2: list @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs2 ) @ A4 )
& ( ( size_size @ ( list @ A ) @ Xs2 )
= N2 ) ) ) ) ) ).
% finite_lists_length_eq
thf(fact_1648_finite__lists__length__le,axiom,
! [A: $tType,A4: set @ A,N2: nat] :
( ( finite_finite @ A @ A4 )
=> ( finite_finite @ ( list @ A )
@ ( collect @ ( list @ A )
@ ^ [Xs2: list @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs2 ) @ A4 )
& ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs2 ) @ N2 ) ) ) ) ) ).
% finite_lists_length_le
thf(fact_1649_ordered__ring__class_Ole__add__iff1,axiom,
! [A: $tType] :
( ( ordered_ring @ A )
=> ! [A3: A,E3: A,C2: A,B2: A,D2: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ ( times_times @ A @ A3 @ E3 ) @ C2 ) @ ( plus_plus @ A @ ( times_times @ A @ B2 @ E3 ) @ D2 ) )
= ( ord_less_eq @ A @ ( plus_plus @ A @ ( times_times @ A @ ( minus_minus @ A @ A3 @ B2 ) @ E3 ) @ C2 ) @ D2 ) ) ) ).
% ordered_ring_class.le_add_iff1
thf(fact_1650_ordered__ring__class_Ole__add__iff2,axiom,
! [A: $tType] :
( ( ordered_ring @ A )
=> ! [A3: A,E3: A,C2: A,B2: A,D2: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ ( times_times @ A @ A3 @ E3 ) @ C2 ) @ ( plus_plus @ A @ ( times_times @ A @ B2 @ E3 ) @ D2 ) )
= ( ord_less_eq @ A @ C2 @ ( plus_plus @ A @ ( times_times @ A @ ( minus_minus @ A @ B2 @ A3 ) @ E3 ) @ D2 ) ) ) ) ).
% ordered_ring_class.le_add_iff2
thf(fact_1651_less__add__iff1,axiom,
! [A: $tType] :
( ( ordered_ring @ A )
=> ! [A3: A,E3: A,C2: A,B2: A,D2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ ( times_times @ A @ A3 @ E3 ) @ C2 ) @ ( plus_plus @ A @ ( times_times @ A @ B2 @ E3 ) @ D2 ) )
= ( ord_less @ A @ ( plus_plus @ A @ ( times_times @ A @ ( minus_minus @ A @ A3 @ B2 ) @ E3 ) @ C2 ) @ D2 ) ) ) ).
% less_add_iff1
thf(fact_1652_less__add__iff2,axiom,
! [A: $tType] :
( ( ordered_ring @ A )
=> ! [A3: A,E3: A,C2: A,B2: A,D2: A] :
( ( ord_less @ A @ ( plus_plus @ A @ ( times_times @ A @ A3 @ E3 ) @ C2 ) @ ( plus_plus @ A @ ( times_times @ A @ B2 @ E3 ) @ D2 ) )
= ( ord_less @ A @ C2 @ ( plus_plus @ A @ ( times_times @ A @ ( minus_minus @ A @ B2 @ A3 ) @ E3 ) @ D2 ) ) ) ) ).
% less_add_iff2
thf(fact_1653_add__divide__eq__if__simps_I4_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,A3: A,B2: A] :
( ( ( Z
= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ A3 @ ( divide_divide @ A @ B2 @ Z ) )
= A3 ) )
& ( ( Z
!= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ A3 @ ( divide_divide @ A @ B2 @ Z ) )
= ( divide_divide @ A @ ( minus_minus @ A @ ( times_times @ A @ A3 @ Z ) @ B2 ) @ Z ) ) ) ) ) ).
% add_divide_eq_if_simps(4)
thf(fact_1654_diff__frac__eq,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [Y: A,Z: A,X: A,W2: A] :
( ( Y
!= ( zero_zero @ A ) )
=> ( ( Z
!= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ ( divide_divide @ A @ X @ Y ) @ ( divide_divide @ A @ W2 @ Z ) )
= ( divide_divide @ A @ ( minus_minus @ A @ ( times_times @ A @ X @ Z ) @ ( times_times @ A @ W2 @ Y ) ) @ ( times_times @ A @ Y @ Z ) ) ) ) ) ) ).
% diff_frac_eq
thf(fact_1655_diff__divide__eq__iff,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,X: A,Y: A] :
( ( Z
!= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ X @ ( divide_divide @ A @ Y @ Z ) )
= ( divide_divide @ A @ ( minus_minus @ A @ ( times_times @ A @ X @ Z ) @ Y ) @ Z ) ) ) ) ).
% diff_divide_eq_iff
thf(fact_1656_divide__diff__eq__iff,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,X: A,Y: A] :
( ( Z
!= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ ( divide_divide @ A @ X @ Z ) @ Y )
= ( divide_divide @ A @ ( minus_minus @ A @ X @ ( times_times @ A @ Y @ Z ) ) @ Z ) ) ) ) ).
% divide_diff_eq_iff
thf(fact_1657_square__diff__one__factored,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [X: A] :
( ( minus_minus @ A @ ( times_times @ A @ X @ X ) @ ( one_one @ A ) )
= ( times_times @ A @ ( plus_plus @ A @ X @ ( one_one @ A ) ) @ ( minus_minus @ A @ X @ ( one_one @ A ) ) ) ) ) ).
% square_diff_one_factored
thf(fact_1658_inf__period_I3_J,axiom,
! [A: $tType] :
( ( ( comm_ring @ A )
& ( dvd @ A ) )
=> ! [D2: A,D6: A,T2: A] :
( ( dvd_dvd @ A @ D2 @ D6 )
=> ! [X3: A,K4: A] :
( ( dvd_dvd @ A @ D2 @ ( plus_plus @ A @ X3 @ T2 ) )
= ( dvd_dvd @ A @ D2 @ ( plus_plus @ A @ ( minus_minus @ A @ X3 @ ( times_times @ A @ K4 @ D6 ) ) @ T2 ) ) ) ) ) ).
% inf_period(3)
thf(fact_1659_inf__period_I4_J,axiom,
! [A: $tType] :
( ( ( comm_ring @ A )
& ( dvd @ A ) )
=> ! [D2: A,D6: A,T2: A] :
( ( dvd_dvd @ A @ D2 @ D6 )
=> ! [X3: A,K4: A] :
( ( ~ ( dvd_dvd @ A @ D2 @ ( plus_plus @ A @ X3 @ T2 ) ) )
= ( ~ ( dvd_dvd @ A @ D2 @ ( plus_plus @ A @ ( minus_minus @ A @ X3 @ ( times_times @ A @ K4 @ D6 ) ) @ T2 ) ) ) ) ) ) ).
% inf_period(4)
thf(fact_1660_minus__div__mult__eq__mod,axiom,
! [A: $tType] :
( ( semiring_modulo @ A )
=> ! [A3: A,B2: A] :
( ( minus_minus @ A @ A3 @ ( times_times @ A @ ( divide_divide @ A @ A3 @ B2 ) @ B2 ) )
= ( modulo_modulo @ A @ A3 @ B2 ) ) ) ).
% minus_div_mult_eq_mod
thf(fact_1661_minus__mod__eq__div__mult,axiom,
! [A: $tType] :
( ( semiring_modulo @ A )
=> ! [A3: A,B2: A] :
( ( minus_minus @ A @ A3 @ ( modulo_modulo @ A @ A3 @ B2 ) )
= ( times_times @ A @ ( divide_divide @ A @ A3 @ B2 ) @ B2 ) ) ) ).
% minus_mod_eq_div_mult
thf(fact_1662_minus__mod__eq__mult__div,axiom,
! [A: $tType] :
( ( semiring_modulo @ A )
=> ! [A3: A,B2: A] :
( ( minus_minus @ A @ A3 @ ( modulo_modulo @ A @ A3 @ B2 ) )
= ( times_times @ A @ B2 @ ( divide_divide @ A @ A3 @ B2 ) ) ) ) ).
% minus_mod_eq_mult_div
thf(fact_1663_minus__mult__div__eq__mod,axiom,
! [A: $tType] :
( ( semiring_modulo @ A )
=> ! [A3: A,B2: A] :
( ( minus_minus @ A @ A3 @ ( times_times @ A @ B2 @ ( divide_divide @ A @ A3 @ B2 ) ) )
= ( modulo_modulo @ A @ A3 @ B2 ) ) ) ).
% minus_mult_div_eq_mod
thf(fact_1664_diff__Suc__less,axiom,
! [N2: nat,I: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less @ nat @ ( minus_minus @ nat @ N2 @ ( suc @ I ) ) @ N2 ) ) ).
% diff_Suc_less
thf(fact_1665_int__power__div__base,axiom,
! [M: nat,K: int] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ( ord_less @ int @ ( zero_zero @ int ) @ K )
=> ( ( divide_divide @ int @ ( power_power @ int @ K @ M ) @ K )
= ( power_power @ int @ K @ ( minus_minus @ nat @ M @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ) ).
% int_power_div_base
thf(fact_1666_nat__diff__split__asm,axiom,
! [P2: nat > $o,A3: nat,B2: nat] :
( ( P2 @ ( minus_minus @ nat @ A3 @ B2 ) )
= ( ~ ( ( ( ord_less @ nat @ A3 @ B2 )
& ~ ( P2 @ ( zero_zero @ nat ) ) )
| ? [D5: nat] :
( ( A3
= ( plus_plus @ nat @ B2 @ D5 ) )
& ~ ( P2 @ D5 ) ) ) ) ) ).
% nat_diff_split_asm
thf(fact_1667_nat__diff__split,axiom,
! [P2: nat > $o,A3: nat,B2: nat] :
( ( P2 @ ( minus_minus @ nat @ A3 @ B2 ) )
= ( ( ( ord_less @ nat @ A3 @ B2 )
=> ( P2 @ ( zero_zero @ nat ) ) )
& ! [D5: nat] :
( ( A3
= ( plus_plus @ nat @ B2 @ D5 ) )
=> ( P2 @ D5 ) ) ) ) ).
% nat_diff_split
thf(fact_1668_less__diff__conv2,axiom,
! [K: nat,J: nat,I: nat] :
( ( ord_less_eq @ nat @ K @ J )
=> ( ( ord_less @ nat @ ( minus_minus @ nat @ J @ K ) @ I )
= ( ord_less @ nat @ J @ ( plus_plus @ nat @ I @ K ) ) ) ) ).
% less_diff_conv2
thf(fact_1669_nat__eq__add__iff1,axiom,
! [J: nat,I: nat,U: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ J @ I )
=> ( ( ( plus_plus @ nat @ ( times_times @ nat @ I @ U ) @ M )
= ( plus_plus @ nat @ ( times_times @ nat @ J @ U ) @ N2 ) )
= ( ( plus_plus @ nat @ ( times_times @ nat @ ( minus_minus @ nat @ I @ J ) @ U ) @ M )
= N2 ) ) ) ).
% nat_eq_add_iff1
thf(fact_1670_nat__eq__add__iff2,axiom,
! [I: nat,J: nat,U: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( ( plus_plus @ nat @ ( times_times @ nat @ I @ U ) @ M )
= ( plus_plus @ nat @ ( times_times @ nat @ J @ U ) @ N2 ) )
= ( M
= ( plus_plus @ nat @ ( times_times @ nat @ ( minus_minus @ nat @ J @ I ) @ U ) @ N2 ) ) ) ) ).
% nat_eq_add_iff2
thf(fact_1671_nat__le__add__iff1,axiom,
! [J: nat,I: nat,U: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ J @ I )
=> ( ( ord_less_eq @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ I @ U ) @ M ) @ ( plus_plus @ nat @ ( times_times @ nat @ J @ U ) @ N2 ) )
= ( ord_less_eq @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ ( minus_minus @ nat @ I @ J ) @ U ) @ M ) @ N2 ) ) ) ).
% nat_le_add_iff1
thf(fact_1672_nat__le__add__iff2,axiom,
! [I: nat,J: nat,U: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( ord_less_eq @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ I @ U ) @ M ) @ ( plus_plus @ nat @ ( times_times @ nat @ J @ U ) @ N2 ) )
= ( ord_less_eq @ nat @ M @ ( plus_plus @ nat @ ( times_times @ nat @ ( minus_minus @ nat @ J @ I ) @ U ) @ N2 ) ) ) ) ).
% nat_le_add_iff2
thf(fact_1673_nat__diff__add__eq1,axiom,
! [J: nat,I: nat,U: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ J @ I )
=> ( ( minus_minus @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ I @ U ) @ M ) @ ( plus_plus @ nat @ ( times_times @ nat @ J @ U ) @ N2 ) )
= ( minus_minus @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ ( minus_minus @ nat @ I @ J ) @ U ) @ M ) @ N2 ) ) ) ).
% nat_diff_add_eq1
thf(fact_1674_nat__diff__add__eq2,axiom,
! [I: nat,J: nat,U: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( minus_minus @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ I @ U ) @ M ) @ ( plus_plus @ nat @ ( times_times @ nat @ J @ U ) @ N2 ) )
= ( minus_minus @ nat @ M @ ( plus_plus @ nat @ ( times_times @ nat @ ( minus_minus @ nat @ J @ I ) @ U ) @ N2 ) ) ) ) ).
% nat_diff_add_eq2
thf(fact_1675_dvd__minus__add,axiom,
! [Q2: nat,N2: nat,R2: nat,M: nat] :
( ( ord_less_eq @ nat @ Q2 @ N2 )
=> ( ( ord_less_eq @ nat @ Q2 @ ( times_times @ nat @ R2 @ M ) )
=> ( ( dvd_dvd @ nat @ M @ ( minus_minus @ nat @ N2 @ Q2 ) )
= ( dvd_dvd @ nat @ M @ ( plus_plus @ nat @ N2 @ ( minus_minus @ nat @ ( times_times @ nat @ R2 @ M ) @ Q2 ) ) ) ) ) ) ).
% dvd_minus_add
thf(fact_1676_mod__nat__eqI,axiom,
! [R2: nat,N2: nat,M: nat] :
( ( ord_less @ nat @ R2 @ N2 )
=> ( ( ord_less_eq @ nat @ R2 @ M )
=> ( ( dvd_dvd @ nat @ N2 @ ( minus_minus @ nat @ M @ R2 ) )
=> ( ( modulo_modulo @ nat @ M @ N2 )
= R2 ) ) ) ) ).
% mod_nat_eqI
thf(fact_1677_exp__div__exp__eq,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [M: nat,N2: nat] :
( ( divide_divide @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( times_times @ A
@ ( zero_neq_one_of_bool @ A
@ ( ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M )
!= ( zero_zero @ A ) )
& ( ord_less_eq @ nat @ N2 @ M ) ) )
@ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ M @ N2 ) ) ) ) ) ).
% exp_div_exp_eq
thf(fact_1678_frac__le__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [Y: A,Z: A,X: A,W2: A] :
( ( Y
!= ( zero_zero @ A ) )
=> ( ( Z
!= ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ ( divide_divide @ A @ X @ Y ) @ ( divide_divide @ A @ W2 @ Z ) )
= ( ord_less_eq @ A @ ( divide_divide @ A @ ( minus_minus @ A @ ( times_times @ A @ X @ Z ) @ ( times_times @ A @ W2 @ Y ) ) @ ( times_times @ A @ Y @ Z ) ) @ ( zero_zero @ A ) ) ) ) ) ) ).
% frac_le_eq
thf(fact_1679_frac__less__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [Y: A,Z: A,X: A,W2: A] :
( ( Y
!= ( zero_zero @ A ) )
=> ( ( Z
!= ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( divide_divide @ A @ X @ Y ) @ ( divide_divide @ A @ W2 @ Z ) )
= ( ord_less @ A @ ( divide_divide @ A @ ( minus_minus @ A @ ( times_times @ A @ X @ Z ) @ ( times_times @ A @ W2 @ Y ) ) @ ( times_times @ A @ Y @ Z ) ) @ ( zero_zero @ A ) ) ) ) ) ) ).
% frac_less_eq
thf(fact_1680_power__diff,axiom,
! [A: $tType] :
( ( semidom_divide @ A )
=> ! [A3: A,N2: nat,M: nat] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( power_power @ A @ A3 @ ( minus_minus @ nat @ M @ N2 ) )
= ( divide_divide @ A @ ( power_power @ A @ A3 @ M ) @ ( power_power @ A @ A3 @ N2 ) ) ) ) ) ) ).
% power_diff
thf(fact_1681_Suc__diff__eq__diff__pred,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( minus_minus @ nat @ ( suc @ M ) @ N2 )
= ( minus_minus @ nat @ M @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) ) ) ) ).
% Suc_diff_eq_diff_pred
thf(fact_1682_Suc__pred_H,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( N2
= ( suc @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) ) ) ) ).
% Suc_pred'
thf(fact_1683_div__if,axiom,
( ( divide_divide @ nat )
= ( ^ [M2: nat,N: nat] :
( if @ nat
@ ( ( ord_less @ nat @ M2 @ N )
| ( N
= ( zero_zero @ nat ) ) )
@ ( zero_zero @ nat )
@ ( suc @ ( divide_divide @ nat @ ( minus_minus @ nat @ M2 @ N ) @ N ) ) ) ) ) ).
% div_if
thf(fact_1684_div__geq,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ~ ( ord_less @ nat @ M @ N2 )
=> ( ( divide_divide @ nat @ M @ N2 )
= ( suc @ ( divide_divide @ nat @ ( minus_minus @ nat @ M @ N2 ) @ N2 ) ) ) ) ) ).
% div_geq
thf(fact_1685_add__eq__if,axiom,
( ( plus_plus @ nat )
= ( ^ [M2: nat,N: nat] :
( if @ nat
@ ( M2
= ( zero_zero @ nat ) )
@ N
@ ( suc @ ( plus_plus @ nat @ ( minus_minus @ nat @ M2 @ ( one_one @ nat ) ) @ N ) ) ) ) ) ).
% add_eq_if
thf(fact_1686_vebt__buildup_Osimps_I3_J,axiom,
! [Va: nat] :
( ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ ( suc @ Va ) ) )
=> ( ( vEBT_vebt_buildup @ ( suc @ ( suc @ Va ) ) )
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ ( suc @ Va ) ) @ ( replicate @ vEBT_VEBT @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( vEBT_vebt_buildup @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_vebt_buildup @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) )
& ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ ( suc @ Va ) ) )
=> ( ( vEBT_vebt_buildup @ ( suc @ ( suc @ Va ) ) )
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ ( suc @ Va ) ) @ ( replicate @ vEBT_VEBT @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_vebt_buildup @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_vebt_buildup @ ( suc @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ).
% vebt_buildup.simps(3)
thf(fact_1687_nat__less__add__iff2,axiom,
! [I: nat,J: nat,U: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( ord_less @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ I @ U ) @ M ) @ ( plus_plus @ nat @ ( times_times @ nat @ J @ U ) @ N2 ) )
= ( ord_less @ nat @ M @ ( plus_plus @ nat @ ( times_times @ nat @ ( minus_minus @ nat @ J @ I ) @ U ) @ N2 ) ) ) ) ).
% nat_less_add_iff2
thf(fact_1688_nat__less__add__iff1,axiom,
! [J: nat,I: nat,U: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ J @ I )
=> ( ( ord_less @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ I @ U ) @ M ) @ ( plus_plus @ nat @ ( times_times @ nat @ J @ U ) @ N2 ) )
= ( ord_less @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ ( minus_minus @ nat @ I @ J ) @ U ) @ M ) @ N2 ) ) ) ).
% nat_less_add_iff1
thf(fact_1689_mult__eq__if,axiom,
( ( times_times @ nat )
= ( ^ [M2: nat,N: nat] :
( if @ nat
@ ( M2
= ( zero_zero @ nat ) )
@ ( zero_zero @ nat )
@ ( plus_plus @ nat @ N @ ( times_times @ nat @ ( minus_minus @ nat @ M2 @ ( one_one @ nat ) ) @ N ) ) ) ) ) ).
% mult_eq_if
thf(fact_1690_scaling__mono,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [U: A,V2: A,R2: A,S: A] :
( ( ord_less_eq @ A @ U @ V2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ R2 )
=> ( ( ord_less_eq @ A @ R2 @ S )
=> ( ord_less_eq @ A @ ( plus_plus @ A @ U @ ( divide_divide @ A @ ( times_times @ A @ R2 @ ( minus_minus @ A @ V2 @ U ) ) @ S ) ) @ V2 ) ) ) ) ) ).
% scaling_mono
thf(fact_1691_exp__not__zero__imp__exp__diff__not__zero,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [N2: nat,M: nat] :
( ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 )
!= ( zero_zero @ A ) )
=> ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ N2 @ M ) )
!= ( zero_zero @ A ) ) ) ) ).
% exp_not_zero_imp_exp_diff_not_zero
thf(fact_1692_power__diff__power__eq,axiom,
! [A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [A3: A,N2: nat,M: nat] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( divide_divide @ A @ ( power_power @ A @ A3 @ M ) @ ( power_power @ A @ A3 @ N2 ) )
= ( power_power @ A @ A3 @ ( minus_minus @ nat @ M @ N2 ) ) ) )
& ( ~ ( ord_less_eq @ nat @ N2 @ M )
=> ( ( divide_divide @ A @ ( power_power @ A @ A3 @ M ) @ ( power_power @ A @ A3 @ N2 ) )
= ( divide_divide @ A @ ( one_one @ A ) @ ( power_power @ A @ A3 @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ) ) ) ) ).
% power_diff_power_eq
thf(fact_1693_power__eq__if,axiom,
! [A: $tType] :
( ( power @ A )
=> ( ( power_power @ A )
= ( ^ [P6: A,M2: nat] :
( if @ A
@ ( M2
= ( zero_zero @ nat ) )
@ ( one_one @ A )
@ ( times_times @ A @ P6 @ ( power_power @ A @ P6 @ ( minus_minus @ nat @ M2 @ ( one_one @ nat ) ) ) ) ) ) ) ) ).
% power_eq_if
thf(fact_1694_vebt__buildup_Oelims,axiom,
! [X: nat,Y: vEBT_VEBT] :
( ( ( vEBT_vebt_buildup @ X )
= Y )
=> ( ( ( X
= ( zero_zero @ nat ) )
=> ( Y
!= ( vEBT_Leaf @ $false @ $false ) ) )
=> ( ( ( X
= ( suc @ ( zero_zero @ nat ) ) )
=> ( Y
!= ( vEBT_Leaf @ $false @ $false ) ) )
=> ~ ! [Va2: nat] :
( ( X
= ( suc @ ( suc @ Va2 ) ) )
=> ~ ( ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ ( suc @ Va2 ) ) )
=> ( Y
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ ( suc @ Va2 ) ) @ ( replicate @ vEBT_VEBT @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( vEBT_vebt_buildup @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_vebt_buildup @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) )
& ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ ( suc @ Va2 ) ) )
=> ( Y
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ ( suc @ Va2 ) ) @ ( replicate @ vEBT_VEBT @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_vebt_buildup @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_vebt_buildup @ ( suc @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ) ) ) ).
% vebt_buildup.elims
thf(fact_1695_power__minus__mult,axiom,
! [A: $tType] :
( ( monoid_mult @ A )
=> ! [N2: nat,A3: A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( times_times @ A @ ( power_power @ A @ A3 @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) ) @ A3 )
= ( power_power @ A @ A3 @ N2 ) ) ) ) ).
% power_minus_mult
thf(fact_1696_diff__le__diff__pow,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ K )
=> ( ord_less_eq @ nat @ ( minus_minus @ nat @ M @ N2 ) @ ( minus_minus @ nat @ ( power_power @ nat @ K @ M ) @ ( power_power @ nat @ K @ N2 ) ) ) ) ).
% diff_le_diff_pow
thf(fact_1697_le__div__geq,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( divide_divide @ nat @ M @ N2 )
= ( suc @ ( divide_divide @ nat @ ( minus_minus @ nat @ M @ N2 ) @ N2 ) ) ) ) ) ).
% le_div_geq
thf(fact_1698_divmod__def,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ( ( unique8689654367752047608divmod @ A )
= ( ^ [M2: num,N: num] : ( product_Pair @ A @ A @ ( divide_divide @ A @ ( numeral_numeral @ A @ M2 ) @ ( numeral_numeral @ A @ N ) ) @ ( modulo_modulo @ A @ ( numeral_numeral @ A @ M2 ) @ ( numeral_numeral @ A @ N ) ) ) ) ) ) ).
% divmod_def
thf(fact_1699_divmod_H__nat__def,axiom,
( ( unique8689654367752047608divmod @ nat )
= ( ^ [M2: num,N: num] : ( product_Pair @ nat @ nat @ ( divide_divide @ nat @ ( numeral_numeral @ nat @ M2 ) @ ( numeral_numeral @ nat @ N ) ) @ ( modulo_modulo @ nat @ ( numeral_numeral @ nat @ M2 ) @ ( numeral_numeral @ nat @ N ) ) ) ) ) ).
% divmod'_nat_def
thf(fact_1700_VEBT__internal_Onaive__member_Osimps_I3_J,axiom,
! [Uy: option @ ( product_prod @ nat @ nat ),V2: nat,TreeList2: list @ vEBT_VEBT,S: vEBT_VEBT,X: nat] :
( ( vEBT_V5719532721284313246member @ ( vEBT_Node @ Uy @ ( suc @ V2 ) @ TreeList2 @ S ) @ X )
= ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) )
=> ( vEBT_V5719532721284313246member @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) ) ) ) ).
% VEBT_internal.naive_member.simps(3)
thf(fact_1701_bits__induct,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [P2: A > $o,A3: A] :
( ! [A7: A] :
( ( ( divide_divide @ A @ A7 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= A7 )
=> ( P2 @ A7 ) )
=> ( ! [A7: A,B5: $o] :
( ( P2 @ A7 )
=> ( ( ( divide_divide @ A @ ( plus_plus @ A @ ( zero_neq_one_of_bool @ A @ B5 ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A7 ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= A7 )
=> ( P2 @ ( plus_plus @ A @ ( zero_neq_one_of_bool @ A @ B5 ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A7 ) ) ) ) )
=> ( P2 @ A3 ) ) ) ) ).
% bits_induct
thf(fact_1702_VEBT__internal_Omembermima_Osimps_I5_J,axiom,
! [V2: nat,TreeList2: list @ vEBT_VEBT,Vd2: vEBT_VEBT,X: nat] :
( ( vEBT_VEBT_membermima @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ V2 ) @ TreeList2 @ Vd2 ) @ X )
= ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) ) ) ) ).
% VEBT_internal.membermima.simps(5)
thf(fact_1703_vebt__member_Osimps_I5_J,axiom,
! [Mi: nat,Ma: nat,Va: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,X: nat] :
( ( vEBT_vebt_member @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ ( suc @ ( suc @ Va ) ) @ TreeList2 @ Summary ) @ X )
= ( ( X != Mi )
=> ( ( X != Ma )
=> ( ~ ( ord_less @ nat @ X @ Mi )
& ( ~ ( ord_less @ nat @ X @ Mi )
=> ( ~ ( ord_less @ nat @ Ma @ X )
& ( ~ ( ord_less @ nat @ Ma @ X )
=> ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) )
=> ( vEBT_vebt_member @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ X @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) ) ) ) ) ) ) ) ) ) ).
% vebt_member.simps(5)
thf(fact_1704_VEBT__internal_Omembermima_Osimps_I4_J,axiom,
! [Mi: nat,Ma: nat,V2: nat,TreeList2: list @ vEBT_VEBT,Vc: vEBT_VEBT,X: nat] :
( ( vEBT_VEBT_membermima @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ ( suc @ V2 ) @ TreeList2 @ Vc ) @ X )
= ( ( X = Mi )
| ( X = Ma )
| ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ X @ ( divide_divide @ nat @ ( suc @ V2 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) ) ) ) ) ).
% VEBT_internal.membermima.simps(4)
thf(fact_1705_exp__mod__exp,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [M: nat,N2: nat] :
( ( modulo_modulo @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( times_times @ A @ ( zero_neq_one_of_bool @ A @ ( ord_less @ nat @ M @ N2 ) ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) ) ) ) ).
% exp_mod_exp
thf(fact_1706_power2__diff,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [X: A,Y: A] :
( ( power_power @ A @ ( minus_minus @ A @ X @ Y ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( minus_minus @ A @ ( plus_plus @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( times_times @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ X ) @ Y ) ) ) ) ).
% power2_diff
thf(fact_1707_mult__exp__mod__exp__eq,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [M: nat,N2: nat,A3: A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( modulo_modulo @ A @ ( times_times @ A @ A3 @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( times_times @ A @ ( modulo_modulo @ A @ A3 @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ N2 @ M ) ) ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) ) ) ) ) ).
% mult_exp_mod_exp_eq
thf(fact_1708_VEBT__internal_Onaive__member_Oelims_I1_J,axiom,
! [X: vEBT_VEBT,Xa2: nat,Y: $o] :
( ( ( vEBT_V5719532721284313246member @ X @ Xa2 )
= Y )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( Y
= ( ~ ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) ) ) )
=> ( ( ? [Uu2: option @ ( product_prod @ nat @ nat ),Uv2: list @ vEBT_VEBT,Uw2: vEBT_VEBT] :
( X
= ( vEBT_Node @ Uu2 @ ( zero_zero @ nat ) @ Uv2 @ Uw2 ) )
=> Y )
=> ~ ! [Uy2: option @ ( product_prod @ nat @ nat ),V3: nat,TreeList3: list @ vEBT_VEBT] :
( ? [S2: vEBT_VEBT] :
( X
= ( vEBT_Node @ Uy2 @ ( suc @ V3 ) @ TreeList3 @ S2 ) )
=> ( Y
= ( ~ ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_V5719532721284313246member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) ).
% VEBT_internal.naive_member.elims(1)
thf(fact_1709_VEBT__internal_Onaive__member_Oelims_I2_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ( vEBT_V5719532721284313246member @ X @ Xa2 )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ~ ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) )
=> ~ ! [Uy2: option @ ( product_prod @ nat @ nat ),V3: nat,TreeList3: list @ vEBT_VEBT] :
( ? [S2: vEBT_VEBT] :
( X
= ( vEBT_Node @ Uy2 @ ( suc @ V3 ) @ TreeList3 @ S2 ) )
=> ~ ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_V5719532721284313246member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ).
% VEBT_internal.naive_member.elims(2)
thf(fact_1710_VEBT__internal_Onaive__member_Oelims_I3_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ~ ( vEBT_V5719532721284313246member @ X @ Xa2 )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) )
=> ( ! [Uu2: option @ ( product_prod @ nat @ nat ),Uv2: list @ vEBT_VEBT,Uw2: vEBT_VEBT] :
( X
!= ( vEBT_Node @ Uu2 @ ( zero_zero @ nat ) @ Uv2 @ Uw2 ) )
=> ~ ! [Uy2: option @ ( product_prod @ nat @ nat ),V3: nat,TreeList3: list @ vEBT_VEBT] :
( ? [S2: vEBT_VEBT] :
( X
= ( vEBT_Node @ Uy2 @ ( suc @ V3 ) @ TreeList3 @ S2 ) )
=> ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_V5719532721284313246member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ).
% VEBT_internal.naive_member.elims(3)
thf(fact_1711_even__mod__4__div__2,axiom,
! [N2: nat] :
( ( ( modulo_modulo @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ ( bit0 @ one2 ) ) ) )
= ( suc @ ( zero_zero @ nat ) ) )
=> ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ).
% even_mod_4_div_2
thf(fact_1712_VEBT__internal_Omembermima_Oelims_I2_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ( vEBT_VEBT_membermima @ X @ Xa2 )
=> ( ! [Mi2: nat,Ma2: nat] :
( ? [Va3: list @ vEBT_VEBT,Vb2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( zero_zero @ nat ) @ Va3 @ Vb2 ) )
=> ~ ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 ) ) )
=> ( ! [Mi2: nat,Ma2: nat,V3: nat,TreeList3: list @ vEBT_VEBT] :
( ? [Vc2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ V3 ) @ TreeList3 @ Vc2 ) )
=> ~ ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 )
| ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) )
=> ~ ! [V3: nat,TreeList3: list @ vEBT_VEBT] :
( ? [Vd: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ V3 ) @ TreeList3 @ Vd ) )
=> ~ ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ).
% VEBT_internal.membermima.elims(2)
thf(fact_1713_divmod__digit__1_I2_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less_eq @ A @ B2 @ ( modulo_modulo @ A @ A3 @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) ) )
=> ( ( minus_minus @ A @ ( modulo_modulo @ A @ A3 @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) ) @ B2 )
= ( modulo_modulo @ A @ A3 @ B2 ) ) ) ) ) ) ).
% divmod_digit_1(2)
thf(fact_1714_even__mask__div__iff_H,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [M: nat,N2: nat] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( divide_divide @ A @ ( minus_minus @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) @ ( one_one @ A ) ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ) ).
% even_mask_div_iff'
thf(fact_1715_vebt__member_Oelims_I2_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ( vEBT_vebt_member @ X @ Xa2 )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ~ ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) )
=> ~ ! [Mi2: nat,Ma2: nat,Va2: nat,TreeList3: list @ vEBT_VEBT] :
( ? [Summary2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) )
=> ~ ( ( Xa2 != Mi2 )
=> ( ( Xa2 != Ma2 )
=> ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
& ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
=> ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
& ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
=> ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_vebt_member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) ) ) ) ).
% vebt_member.elims(2)
thf(fact_1716_VEBT__internal_Omembermima_Oelims_I3_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ~ ( vEBT_VEBT_membermima @ X @ Xa2 )
=> ( ! [Uu2: $o,Uv2: $o] :
( X
!= ( vEBT_Leaf @ Uu2 @ Uv2 ) )
=> ( ! [Ux2: list @ vEBT_VEBT,Uy2: vEBT_VEBT] :
( X
!= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( zero_zero @ nat ) @ Ux2 @ Uy2 ) )
=> ( ! [Mi2: nat,Ma2: nat] :
( ? [Va3: list @ vEBT_VEBT,Vb2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( zero_zero @ nat ) @ Va3 @ Vb2 ) )
=> ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 ) ) )
=> ( ! [Mi2: nat,Ma2: nat,V3: nat,TreeList3: list @ vEBT_VEBT] :
( ? [Vc2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ V3 ) @ TreeList3 @ Vc2 ) )
=> ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 )
| ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) )
=> ~ ! [V3: nat,TreeList3: list @ vEBT_VEBT] :
( ? [Vd: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ V3 ) @ TreeList3 @ Vd ) )
=> ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) ).
% VEBT_internal.membermima.elims(3)
thf(fact_1717_VEBT__internal_Omembermima_Oelims_I1_J,axiom,
! [X: vEBT_VEBT,Xa2: nat,Y: $o] :
( ( ( vEBT_VEBT_membermima @ X @ Xa2 )
= Y )
=> ( ( ? [Uu2: $o,Uv2: $o] :
( X
= ( vEBT_Leaf @ Uu2 @ Uv2 ) )
=> Y )
=> ( ( ? [Ux2: list @ vEBT_VEBT,Uy2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( zero_zero @ nat ) @ Ux2 @ Uy2 ) )
=> Y )
=> ( ! [Mi2: nat,Ma2: nat] :
( ? [Va3: list @ vEBT_VEBT,Vb2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( zero_zero @ nat ) @ Va3 @ Vb2 ) )
=> ( Y
= ( ~ ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 ) ) ) ) )
=> ( ! [Mi2: nat,Ma2: nat,V3: nat,TreeList3: list @ vEBT_VEBT] :
( ? [Vc2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ V3 ) @ TreeList3 @ Vc2 ) )
=> ( Y
= ( ~ ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 )
| ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) )
=> ~ ! [V3: nat,TreeList3: list @ vEBT_VEBT] :
( ? [Vd: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ V3 ) @ TreeList3 @ Vd ) )
=> ( Y
= ( ~ ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) ) ) ).
% VEBT_internal.membermima.elims(1)
thf(fact_1718_vebt__insert_Osimps_I5_J,axiom,
! [Mi: nat,Ma: nat,Va: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,X: nat] :
( ( vEBT_vebt_insert @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ ( suc @ ( suc @ Va ) ) @ TreeList2 @ Summary ) @ X )
= ( if @ vEBT_VEBT
@ ( ( ord_less @ nat @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ X @ Mi ) @ Mi @ X ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 ) )
& ~ ( ( X = Mi )
| ( X = Ma ) ) )
@ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ ( if @ nat @ ( ord_less @ nat @ X @ Mi ) @ X @ Mi ) @ ( ord_max @ nat @ ( if @ nat @ ( ord_less @ nat @ X @ Mi ) @ Mi @ X ) @ Ma ) ) ) @ ( suc @ ( suc @ Va ) ) @ ( list_update @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ X @ Mi ) @ Mi @ X ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ X @ Mi ) @ Mi @ X ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ ( if @ nat @ ( ord_less @ nat @ X @ Mi ) @ Mi @ X ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) @ ( if @ vEBT_VEBT @ ( vEBT_VEBT_minNull @ ( nth @ vEBT_VEBT @ TreeList2 @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ X @ Mi ) @ Mi @ X ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) @ ( vEBT_vebt_insert @ Summary @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ X @ Mi ) @ Mi @ X ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ Summary ) )
@ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi @ Ma ) ) @ ( suc @ ( suc @ Va ) ) @ TreeList2 @ Summary ) ) ) ).
% vebt_insert.simps(5)
thf(fact_1719_vebt__member_Oelims_I3_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ~ ( vEBT_vebt_member @ X @ Xa2 )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) )
=> ( ! [Uu2: nat,Uv2: list @ vEBT_VEBT,Uw2: vEBT_VEBT] :
( X
!= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uu2 @ Uv2 @ Uw2 ) )
=> ( ! [V3: product_prod @ nat @ nat,Uy2: list @ vEBT_VEBT,Uz2: vEBT_VEBT] :
( X
!= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( zero_zero @ nat ) @ Uy2 @ Uz2 ) )
=> ( ! [V3: product_prod @ nat @ nat,Vb2: list @ vEBT_VEBT,Vc2: vEBT_VEBT] :
( X
!= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( suc @ ( zero_zero @ nat ) ) @ Vb2 @ Vc2 ) )
=> ~ ! [Mi2: nat,Ma2: nat,Va2: nat,TreeList3: list @ vEBT_VEBT] :
( ? [Summary2: vEBT_VEBT] :
( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) )
=> ( ( Xa2 != Mi2 )
=> ( ( Xa2 != Ma2 )
=> ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
& ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
=> ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
& ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
=> ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_vebt_member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ).
% vebt_member.elims(3)
thf(fact_1720_divmod__step__eq,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [L: num,R2: A,Q2: A] :
( ( ( ord_less_eq @ A @ ( numeral_numeral @ A @ L ) @ R2 )
=> ( ( unique1321980374590559556d_step @ A @ L @ ( product_Pair @ A @ A @ Q2 @ R2 ) )
= ( product_Pair @ A @ A @ ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ Q2 ) @ ( one_one @ A ) ) @ ( minus_minus @ A @ R2 @ ( numeral_numeral @ A @ L ) ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( numeral_numeral @ A @ L ) @ R2 )
=> ( ( unique1321980374590559556d_step @ A @ L @ ( product_Pair @ A @ A @ Q2 @ R2 ) )
= ( product_Pair @ A @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ Q2 ) @ R2 ) ) ) ) ) ).
% divmod_step_eq
thf(fact_1721_inrange,axiom,
! [T2: vEBT_VEBT,N2: nat] :
( ( vEBT_invar_vebt @ T2 @ N2 )
=> ( ord_less_eq @ ( set @ nat ) @ ( vEBT_VEBT_set_vebt @ T2 ) @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ ( minus_minus @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ ( one_one @ nat ) ) ) ) ) ).
% inrange
thf(fact_1722_finite__nth__roots,axiom,
! [N2: nat,C2: complex] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( finite_finite @ complex
@ ( collect @ complex
@ ^ [Z6: complex] :
( ( power_power @ complex @ Z6 @ N2 )
= C2 ) ) ) ) ).
% finite_nth_roots
thf(fact_1723_finite__roots__unity,axiom,
! [A: $tType] :
( ( ( real_V8999393235501362500lgebra @ A )
& ( idom @ A ) )
=> ! [N2: nat] :
( ( ord_less_eq @ nat @ ( one_one @ nat ) @ N2 )
=> ( finite_finite @ A
@ ( collect @ A
@ ^ [Z6: A] :
( ( power_power @ A @ Z6 @ N2 )
= ( one_one @ A ) ) ) ) ) ) ).
% finite_roots_unity
thf(fact_1724_vebt__insert_Opelims,axiom,
! [X: vEBT_VEBT,Xa2: nat,Y: vEBT_VEBT] :
( ( ( vEBT_vebt_insert @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_insert_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( ( ( ( Xa2
= ( zero_zero @ nat ) )
=> ( Y
= ( vEBT_Leaf @ $true @ B5 ) ) )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> ( Y
= ( vEBT_Leaf @ A7 @ $true ) ) )
& ( ( Xa2
!= ( one_one @ nat ) )
=> ( Y
= ( vEBT_Leaf @ A7 @ B5 ) ) ) ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_insert_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ A7 @ B5 ) @ Xa2 ) ) ) )
=> ( ! [Info2: option @ ( product_prod @ nat @ nat ),Ts2: list @ vEBT_VEBT,S2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Info2 @ ( zero_zero @ nat ) @ Ts2 @ S2 ) )
=> ( ( Y
= ( vEBT_Node @ Info2 @ ( zero_zero @ nat ) @ Ts2 @ S2 ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_insert_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Info2 @ ( zero_zero @ nat ) @ Ts2 @ S2 ) @ Xa2 ) ) ) )
=> ( ! [Info2: option @ ( product_prod @ nat @ nat ),Ts2: list @ vEBT_VEBT,S2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Info2 @ ( suc @ ( zero_zero @ nat ) ) @ Ts2 @ S2 ) )
=> ( ( Y
= ( vEBT_Node @ Info2 @ ( suc @ ( zero_zero @ nat ) ) @ Ts2 @ S2 ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_insert_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Info2 @ ( suc @ ( zero_zero @ nat ) ) @ Ts2 @ S2 ) @ Xa2 ) ) ) )
=> ( ! [V3: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ ( suc @ V3 ) ) @ TreeList3 @ Summary2 ) )
=> ( ( Y
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Xa2 @ Xa2 ) ) @ ( suc @ ( suc @ V3 ) ) @ TreeList3 @ Summary2 ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_insert_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ ( suc @ V3 ) ) @ TreeList3 @ Summary2 ) @ Xa2 ) ) ) )
=> ~ ! [Mi2: nat,Ma2: nat,Va2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) )
=> ( ( Y
= ( if @ vEBT_VEBT
@ ( ( ord_less @ nat @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
& ~ ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 ) ) )
@ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Xa2 @ Mi2 ) @ ( ord_max @ nat @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ Ma2 ) ) ) @ ( suc @ ( suc @ Va2 ) ) @ ( list_update @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) @ ( if @ vEBT_VEBT @ ( vEBT_VEBT_minNull @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) @ ( vEBT_vebt_insert @ Summary2 @ ( vEBT_VEBT_high @ ( if @ nat @ ( ord_less @ nat @ Xa2 @ Mi2 ) @ Mi2 @ Xa2 ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ Summary2 ) )
@ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_insert_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) @ Xa2 ) ) ) ) ) ) ) ) ) ) ).
% vebt_insert.pelims
thf(fact_1725_divmod__divmod__step,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ( ( unique8689654367752047608divmod @ A )
= ( ^ [M2: num,N: num] : ( if @ ( product_prod @ A @ A ) @ ( ord_less @ num @ M2 @ N ) @ ( product_Pair @ A @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ A @ M2 ) ) @ ( unique1321980374590559556d_step @ A @ N @ ( unique8689654367752047608divmod @ A @ M2 @ ( bit0 @ N ) ) ) ) ) ) ) ).
% divmod_divmod_step
thf(fact_1726_Suc__if__eq,axiom,
! [A: $tType,F2: nat > A,H2: nat > A,G: A,N2: nat] :
( ! [N3: nat] :
( ( F2 @ ( suc @ N3 ) )
= ( H2 @ N3 ) )
=> ( ( ( F2 @ ( zero_zero @ nat ) )
= G )
=> ( ( ( N2
= ( zero_zero @ nat ) )
=> ( ( F2 @ N2 )
= G ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( F2 @ N2 )
= ( H2 @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) ) ) ) ) ) ) ).
% Suc_if_eq
thf(fact_1727_sum_Ofinite__Collect__op,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [I6: set @ B,X: B > A,Y: B > A] :
( ( finite_finite @ B
@ ( collect @ B
@ ^ [I5: B] :
( ( member2 @ B @ I5 @ I6 )
& ( ( X @ I5 )
!= ( zero_zero @ A ) ) ) ) )
=> ( ( finite_finite @ B
@ ( collect @ B
@ ^ [I5: B] :
( ( member2 @ B @ I5 @ I6 )
& ( ( Y @ I5 )
!= ( zero_zero @ A ) ) ) ) )
=> ( finite_finite @ B
@ ( collect @ B
@ ^ [I5: B] :
( ( member2 @ B @ I5 @ I6 )
& ( ( plus_plus @ A @ ( X @ I5 ) @ ( Y @ I5 ) )
!= ( zero_zero @ A ) ) ) ) ) ) ) ) ).
% sum.finite_Collect_op
thf(fact_1728_finite__interval__int1,axiom,
! [A3: int,B2: int] :
( finite_finite @ int
@ ( collect @ int
@ ^ [I5: int] :
( ( ord_less_eq @ int @ A3 @ I5 )
& ( ord_less_eq @ int @ I5 @ B2 ) ) ) ) ).
% finite_interval_int1
thf(fact_1729_finite__interval__int4,axiom,
! [A3: int,B2: int] :
( finite_finite @ int
@ ( collect @ int
@ ^ [I5: int] :
( ( ord_less @ int @ A3 @ I5 )
& ( ord_less @ int @ I5 @ B2 ) ) ) ) ).
% finite_interval_int4
thf(fact_1730_Icc__eq__Icc,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,H2: A,L3: A,H3: A] :
( ( ( set_or1337092689740270186AtMost @ A @ L @ H2 )
= ( set_or1337092689740270186AtMost @ A @ L3 @ H3 ) )
= ( ( ( L = L3 )
& ( H2 = H3 ) )
| ( ~ ( ord_less_eq @ A @ L @ H2 )
& ~ ( ord_less_eq @ A @ L3 @ H3 ) ) ) ) ) ).
% Icc_eq_Icc
thf(fact_1731_atLeastAtMost__iff,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [I: A,L: A,U: A] :
( ( member2 @ A @ I @ ( set_or1337092689740270186AtMost @ A @ L @ U ) )
= ( ( ord_less_eq @ A @ L @ I )
& ( ord_less_eq @ A @ I @ U ) ) ) ) ).
% atLeastAtMost_iff
thf(fact_1732_zle__add1__eq__le,axiom,
! [W2: int,Z: int] :
( ( ord_less @ int @ W2 @ ( plus_plus @ int @ Z @ ( one_one @ int ) ) )
= ( ord_less_eq @ int @ W2 @ Z ) ) ).
% zle_add1_eq_le
thf(fact_1733_finite__interval__int2,axiom,
! [A3: int,B2: int] :
( finite_finite @ int
@ ( collect @ int
@ ^ [I5: int] :
( ( ord_less_eq @ int @ A3 @ I5 )
& ( ord_less @ int @ I5 @ B2 ) ) ) ) ).
% finite_interval_int2
thf(fact_1734_finite__interval__int3,axiom,
! [A3: int,B2: int] :
( finite_finite @ int
@ ( collect @ int
@ ^ [I5: int] :
( ( ord_less @ int @ A3 @ I5 )
& ( ord_less_eq @ int @ I5 @ B2 ) ) ) ) ).
% finite_interval_int3
thf(fact_1735_atLeastatMost__empty__iff2,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A] :
( ( ( bot_bot @ ( set @ A ) )
= ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( ~ ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ).
% atLeastatMost_empty_iff2
thf(fact_1736_atLeastatMost__empty__iff,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A] :
( ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
= ( bot_bot @ ( set @ A ) ) )
= ( ~ ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ).
% atLeastatMost_empty_iff
thf(fact_1737_atLeastatMost__subset__iff,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ ( set_or1337092689740270186AtMost @ A @ C2 @ D2 ) )
= ( ~ ( ord_less_eq @ A @ A3 @ B2 )
| ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less_eq @ A @ B2 @ D2 ) ) ) ) ) ).
% atLeastatMost_subset_iff
thf(fact_1738_atLeastatMost__empty,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% atLeastatMost_empty
thf(fact_1739_infinite__Icc__iff,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A] :
( ( ~ ( finite_finite @ A @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) ) )
= ( ord_less @ A @ A3 @ B2 ) ) ) ).
% infinite_Icc_iff
thf(fact_1740_zle__diff1__eq,axiom,
! [W2: int,Z: int] :
( ( ord_less_eq @ int @ W2 @ ( minus_minus @ int @ Z @ ( one_one @ int ) ) )
= ( ord_less @ int @ W2 @ Z ) ) ).
% zle_diff1_eq
thf(fact_1741_zdvd__mult__cancel,axiom,
! [K: int,M: int,N2: int] :
( ( dvd_dvd @ int @ ( times_times @ int @ K @ M ) @ ( times_times @ int @ K @ N2 ) )
=> ( ( K
!= ( zero_zero @ int ) )
=> ( dvd_dvd @ int @ M @ N2 ) ) ) ).
% zdvd_mult_cancel
thf(fact_1742_zdvd__antisym__nonneg,axiom,
! [M: int,N2: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ M )
=> ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ N2 )
=> ( ( dvd_dvd @ int @ M @ N2 )
=> ( ( dvd_dvd @ int @ N2 @ M )
=> ( M = N2 ) ) ) ) ) ).
% zdvd_antisym_nonneg
thf(fact_1743_zdvd__imp__le,axiom,
! [Z: int,N2: int] :
( ( dvd_dvd @ int @ Z @ N2 )
=> ( ( ord_less @ int @ ( zero_zero @ int ) @ N2 )
=> ( ord_less_eq @ int @ Z @ N2 ) ) ) ).
% zdvd_imp_le
thf(fact_1744_zdvd__period,axiom,
! [A3: int,D2: int,X: int,T2: int,C2: int] :
( ( dvd_dvd @ int @ A3 @ D2 )
=> ( ( dvd_dvd @ int @ A3 @ ( plus_plus @ int @ X @ T2 ) )
= ( dvd_dvd @ int @ A3 @ ( plus_plus @ int @ ( plus_plus @ int @ X @ ( times_times @ int @ C2 @ D2 ) ) @ T2 ) ) ) ) ).
% zdvd_period
thf(fact_1745_zdvd__reduce,axiom,
! [K: int,N2: int,M: int] :
( ( dvd_dvd @ int @ K @ ( plus_plus @ int @ N2 @ ( times_times @ int @ K @ M ) ) )
= ( dvd_dvd @ int @ K @ N2 ) ) ).
% zdvd_reduce
thf(fact_1746_zdvd__not__zless,axiom,
! [M: int,N2: int] :
( ( ord_less @ int @ ( zero_zero @ int ) @ M )
=> ( ( ord_less @ int @ M @ N2 )
=> ~ ( dvd_dvd @ int @ N2 @ M ) ) ) ).
% zdvd_not_zless
thf(fact_1747_zdvd__zdiffD,axiom,
! [K: int,M: int,N2: int] :
( ( dvd_dvd @ int @ K @ ( minus_minus @ int @ M @ N2 ) )
=> ( ( dvd_dvd @ int @ K @ N2 )
=> ( dvd_dvd @ int @ K @ M ) ) ) ).
% zdvd_zdiffD
thf(fact_1748_int__induct,axiom,
! [P2: int > $o,K: int,I: int] :
( ( P2 @ K )
=> ( ! [I3: int] :
( ( ord_less_eq @ int @ K @ I3 )
=> ( ( P2 @ I3 )
=> ( P2 @ ( plus_plus @ int @ I3 @ ( one_one @ int ) ) ) ) )
=> ( ! [I3: int] :
( ( ord_less_eq @ int @ I3 @ K )
=> ( ( P2 @ I3 )
=> ( P2 @ ( minus_minus @ int @ I3 @ ( one_one @ int ) ) ) ) )
=> ( P2 @ I ) ) ) ) ).
% int_induct
thf(fact_1749_int__ge__induct,axiom,
! [K: int,I: int,P2: int > $o] :
( ( ord_less_eq @ int @ K @ I )
=> ( ( P2 @ K )
=> ( ! [I3: int] :
( ( ord_less_eq @ int @ K @ I3 )
=> ( ( P2 @ I3 )
=> ( P2 @ ( plus_plus @ int @ I3 @ ( one_one @ int ) ) ) ) )
=> ( P2 @ I ) ) ) ) ).
% int_ge_induct
thf(fact_1750_int__le__induct,axiom,
! [I: int,K: int,P2: int > $o] :
( ( ord_less_eq @ int @ I @ K )
=> ( ( P2 @ K )
=> ( ! [I3: int] :
( ( ord_less_eq @ int @ I3 @ K )
=> ( ( P2 @ I3 )
=> ( P2 @ ( minus_minus @ int @ I3 @ ( one_one @ int ) ) ) ) )
=> ( P2 @ I ) ) ) ) ).
% int_le_induct
thf(fact_1751_minus__int__code_I1_J,axiom,
! [K: int] :
( ( minus_minus @ int @ K @ ( zero_zero @ int ) )
= K ) ).
% minus_int_code(1)
thf(fact_1752_less__eq__int__code_I1_J,axiom,
ord_less_eq @ int @ ( zero_zero @ int ) @ ( zero_zero @ int ) ).
% less_eq_int_code(1)
thf(fact_1753_int__distrib_I4_J,axiom,
! [W2: int,Z1: int,Z22: int] :
( ( times_times @ int @ W2 @ ( minus_minus @ int @ Z1 @ Z22 ) )
= ( minus_minus @ int @ ( times_times @ int @ W2 @ Z1 ) @ ( times_times @ int @ W2 @ Z22 ) ) ) ).
% int_distrib(4)
thf(fact_1754_int__distrib_I3_J,axiom,
! [Z1: int,Z22: int,W2: int] :
( ( times_times @ int @ ( minus_minus @ int @ Z1 @ Z22 ) @ W2 )
= ( minus_minus @ int @ ( times_times @ int @ Z1 @ W2 ) @ ( times_times @ int @ Z22 @ W2 ) ) ) ).
% int_distrib(3)
thf(fact_1755_add1__zle__eq,axiom,
! [W2: int,Z: int] :
( ( ord_less_eq @ int @ ( plus_plus @ int @ W2 @ ( one_one @ int ) ) @ Z )
= ( ord_less @ int @ W2 @ Z ) ) ).
% add1_zle_eq
thf(fact_1756_le__imp__0__less,axiom,
! [Z: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( ord_less @ int @ ( zero_zero @ int ) @ ( plus_plus @ int @ ( one_one @ int ) @ Z ) ) ) ).
% le_imp_0_less
thf(fact_1757_zless__imp__add1__zle,axiom,
! [W2: int,Z: int] :
( ( ord_less @ int @ W2 @ Z )
=> ( ord_less_eq @ int @ ( plus_plus @ int @ W2 @ ( one_one @ int ) ) @ Z ) ) ).
% zless_imp_add1_zle
thf(fact_1758_int__one__le__iff__zero__less,axiom,
! [Z: int] :
( ( ord_less_eq @ int @ ( one_one @ int ) @ Z )
= ( ord_less @ int @ ( zero_zero @ int ) @ Z ) ) ).
% int_one_le_iff_zero_less
thf(fact_1759_int__less__induct,axiom,
! [I: int,K: int,P2: int > $o] :
( ( ord_less @ int @ I @ K )
=> ( ( P2 @ ( minus_minus @ int @ K @ ( one_one @ int ) ) )
=> ( ! [I3: int] :
( ( ord_less @ int @ I3 @ K )
=> ( ( P2 @ I3 )
=> ( P2 @ ( minus_minus @ int @ I3 @ ( one_one @ int ) ) ) ) )
=> ( P2 @ I ) ) ) ) ).
% int_less_induct
thf(fact_1760_pos__zmult__eq__1__iff,axiom,
! [M: int,N2: int] :
( ( ord_less @ int @ ( zero_zero @ int ) @ M )
=> ( ( ( times_times @ int @ M @ N2 )
= ( one_one @ int ) )
= ( ( M
= ( one_one @ int ) )
& ( N2
= ( one_one @ int ) ) ) ) ) ).
% pos_zmult_eq_1_iff
thf(fact_1761_odd__less__0__iff,axiom,
! [Z: int] :
( ( ord_less @ int @ ( plus_plus @ int @ ( plus_plus @ int @ ( one_one @ int ) @ Z ) @ Z ) @ ( zero_zero @ int ) )
= ( ord_less @ int @ Z @ ( zero_zero @ int ) ) ) ).
% odd_less_0_iff
thf(fact_1762_zless__add1__eq,axiom,
! [W2: int,Z: int] :
( ( ord_less @ int @ W2 @ ( plus_plus @ int @ Z @ ( one_one @ int ) ) )
= ( ( ord_less @ int @ W2 @ Z )
| ( W2 = Z ) ) ) ).
% zless_add1_eq
thf(fact_1763_int__gr__induct,axiom,
! [K: int,I: int,P2: int > $o] :
( ( ord_less @ int @ K @ I )
=> ( ( P2 @ ( plus_plus @ int @ K @ ( one_one @ int ) ) )
=> ( ! [I3: int] :
( ( ord_less @ int @ K @ I3 )
=> ( ( P2 @ I3 )
=> ( P2 @ ( plus_plus @ int @ I3 @ ( one_one @ int ) ) ) ) )
=> ( P2 @ I ) ) ) ) ).
% int_gr_induct
thf(fact_1764_odd__nonzero,axiom,
! [Z: int] :
( ( plus_plus @ int @ ( plus_plus @ int @ ( one_one @ int ) @ Z ) @ Z )
!= ( zero_zero @ int ) ) ).
% odd_nonzero
thf(fact_1765_times__int__code_I1_J,axiom,
! [K: int] :
( ( times_times @ int @ K @ ( zero_zero @ int ) )
= ( zero_zero @ int ) ) ).
% times_int_code(1)
thf(fact_1766_times__int__code_I2_J,axiom,
! [L: int] :
( ( times_times @ int @ ( zero_zero @ int ) @ L )
= ( zero_zero @ int ) ) ).
% times_int_code(2)
thf(fact_1767_int__distrib_I2_J,axiom,
! [W2: int,Z1: int,Z22: int] :
( ( times_times @ int @ W2 @ ( plus_plus @ int @ Z1 @ Z22 ) )
= ( plus_plus @ int @ ( times_times @ int @ W2 @ Z1 ) @ ( times_times @ int @ W2 @ Z22 ) ) ) ).
% int_distrib(2)
thf(fact_1768_int__distrib_I1_J,axiom,
! [Z1: int,Z22: int,W2: int] :
( ( times_times @ int @ ( plus_plus @ int @ Z1 @ Z22 ) @ W2 )
= ( plus_plus @ int @ ( times_times @ int @ Z1 @ W2 ) @ ( times_times @ int @ Z22 @ W2 ) ) ) ).
% int_distrib(1)
thf(fact_1769_less__int__code_I1_J,axiom,
~ ( ord_less @ int @ ( zero_zero @ int ) @ ( zero_zero @ int ) ) ).
% less_int_code(1)
thf(fact_1770_zmult__zless__mono2,axiom,
! [I: int,J: int,K: int] :
( ( ord_less @ int @ I @ J )
=> ( ( ord_less @ int @ ( zero_zero @ int ) @ K )
=> ( ord_less @ int @ ( times_times @ int @ K @ I ) @ ( times_times @ int @ K @ J ) ) ) ) ).
% zmult_zless_mono2
thf(fact_1771_plus__int__code_I2_J,axiom,
! [L: int] :
( ( plus_plus @ int @ ( zero_zero @ int ) @ L )
= L ) ).
% plus_int_code(2)
thf(fact_1772_plus__int__code_I1_J,axiom,
! [K: int] :
( ( plus_plus @ int @ K @ ( zero_zero @ int ) )
= K ) ).
% plus_int_code(1)
thf(fact_1773_bot2E,axiom,
! [A: $tType,B: $tType,X: A,Y: B] :
~ ( bot_bot @ ( A > B > $o ) @ X @ Y ) ).
% bot2E
thf(fact_1774_infinite__Icc,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ~ ( finite_finite @ A @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) ) ) ) ).
% infinite_Icc
thf(fact_1775_all__nat__less,axiom,
! [N2: nat,P2: nat > $o] :
( ( ! [M2: nat] :
( ( ord_less_eq @ nat @ M2 @ N2 )
=> ( P2 @ M2 ) ) )
= ( ! [X2: nat] :
( ( member2 @ nat @ X2 @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) )
=> ( P2 @ X2 ) ) ) ) ).
% all_nat_less
thf(fact_1776_ex__nat__less,axiom,
! [N2: nat,P2: nat > $o] :
( ( ? [M2: nat] :
( ( ord_less_eq @ nat @ M2 @ N2 )
& ( P2 @ M2 ) ) )
= ( ? [X2: nat] :
( ( member2 @ nat @ X2 @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) )
& ( P2 @ X2 ) ) ) ) ).
% ex_nat_less
thf(fact_1777_atLeastatMost__psubset__iff,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ ( set_or1337092689740270186AtMost @ A @ C2 @ D2 ) )
= ( ( ~ ( ord_less_eq @ A @ A3 @ B2 )
| ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less_eq @ A @ B2 @ D2 )
& ( ( ord_less @ A @ C2 @ A3 )
| ( ord_less @ A @ B2 @ D2 ) ) ) )
& ( ord_less_eq @ A @ C2 @ D2 ) ) ) ) ).
% atLeastatMost_psubset_iff
thf(fact_1778_subset__eq__atLeast0__atMost__finite,axiom,
! [N7: set @ nat,N2: nat] :
( ( ord_less_eq @ ( set @ nat ) @ N7 @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) )
=> ( finite_finite @ nat @ N7 ) ) ).
% subset_eq_atLeast0_atMost_finite
thf(fact_1779_vebt__member_Opelims_I1_J,axiom,
! [X: vEBT_VEBT,Xa2: nat,Y: $o] :
( ( ( vEBT_vebt_member @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( ( Y
= ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ A7 @ B5 ) @ Xa2 ) ) ) )
=> ( ! [Uu2: nat,Uv2: list @ vEBT_VEBT,Uw2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uu2 @ Uv2 @ Uw2 ) )
=> ( ~ Y
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uu2 @ Uv2 @ Uw2 ) @ Xa2 ) ) ) )
=> ( ! [V3: product_prod @ nat @ nat,Uy2: list @ vEBT_VEBT,Uz2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( zero_zero @ nat ) @ Uy2 @ Uz2 ) )
=> ( ~ Y
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( zero_zero @ nat ) @ Uy2 @ Uz2 ) @ Xa2 ) ) ) )
=> ( ! [V3: product_prod @ nat @ nat,Vb2: list @ vEBT_VEBT,Vc2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( suc @ ( zero_zero @ nat ) ) @ Vb2 @ Vc2 ) )
=> ( ~ Y
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( suc @ ( zero_zero @ nat ) ) @ Vb2 @ Vc2 ) @ Xa2 ) ) ) )
=> ~ ! [Mi2: nat,Ma2: nat,Va2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) )
=> ( ( Y
= ( ( Xa2 != Mi2 )
=> ( ( Xa2 != Ma2 )
=> ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
& ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
=> ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
& ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
=> ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_vebt_member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) @ Xa2 ) ) ) ) ) ) ) ) ) ) ).
% vebt_member.pelims(1)
thf(fact_1780_vebt__member_Opelims_I3_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ~ ( vEBT_vebt_member @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ A7 @ B5 ) @ Xa2 ) )
=> ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) ) )
=> ( ! [Uu2: nat,Uv2: list @ vEBT_VEBT,Uw2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uu2 @ Uv2 @ Uw2 ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ Uu2 @ Uv2 @ Uw2 ) @ Xa2 ) ) )
=> ( ! [V3: product_prod @ nat @ nat,Uy2: list @ vEBT_VEBT,Uz2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( zero_zero @ nat ) @ Uy2 @ Uz2 ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( zero_zero @ nat ) @ Uy2 @ Uz2 ) @ Xa2 ) ) )
=> ( ! [V3: product_prod @ nat @ nat,Vb2: list @ vEBT_VEBT,Vc2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( suc @ ( zero_zero @ nat ) ) @ Vb2 @ Vc2 ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ V3 ) @ ( suc @ ( zero_zero @ nat ) ) @ Vb2 @ Vc2 ) @ Xa2 ) ) )
=> ~ ! [Mi2: nat,Ma2: nat,Va2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) @ Xa2 ) )
=> ( ( Xa2 != Mi2 )
=> ( ( Xa2 != Ma2 )
=> ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
& ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
=> ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
& ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
=> ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_vebt_member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ).
% vebt_member.pelims(3)
thf(fact_1781_VEBT__internal_Onaive__member_Opelims_I3_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ~ ( vEBT_V5719532721284313246member @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V5765760719290551771er_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V5765760719290551771er_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ A7 @ B5 ) @ Xa2 ) )
=> ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) ) )
=> ( ! [Uu2: option @ ( product_prod @ nat @ nat ),Uv2: list @ vEBT_VEBT,Uw2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Uu2 @ ( zero_zero @ nat ) @ Uv2 @ Uw2 ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V5765760719290551771er_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Uu2 @ ( zero_zero @ nat ) @ Uv2 @ Uw2 ) @ Xa2 ) ) )
=> ~ ! [Uy2: option @ ( product_prod @ nat @ nat ),V3: nat,TreeList3: list @ vEBT_VEBT,S2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Uy2 @ ( suc @ V3 ) @ TreeList3 @ S2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V5765760719290551771er_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Uy2 @ ( suc @ V3 ) @ TreeList3 @ S2 ) @ Xa2 ) )
=> ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_V5719532721284313246member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) ).
% VEBT_internal.naive_member.pelims(3)
thf(fact_1782_VEBT__internal_Onaive__member_Opelims_I2_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ( vEBT_V5719532721284313246member @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V5765760719290551771er_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V5765760719290551771er_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ A7 @ B5 ) @ Xa2 ) )
=> ~ ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) ) )
=> ~ ! [Uy2: option @ ( product_prod @ nat @ nat ),V3: nat,TreeList3: list @ vEBT_VEBT,S2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Uy2 @ ( suc @ V3 ) @ TreeList3 @ S2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V5765760719290551771er_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Uy2 @ ( suc @ V3 ) @ TreeList3 @ S2 ) @ Xa2 ) )
=> ~ ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_V5719532721284313246member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ).
% VEBT_internal.naive_member.pelims(2)
thf(fact_1783_VEBT__internal_Onaive__member_Opelims_I1_J,axiom,
! [X: vEBT_VEBT,Xa2: nat,Y: $o] :
( ( ( vEBT_V5719532721284313246member @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V5765760719290551771er_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( ( Y
= ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V5765760719290551771er_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ A7 @ B5 ) @ Xa2 ) ) ) )
=> ( ! [Uu2: option @ ( product_prod @ nat @ nat ),Uv2: list @ vEBT_VEBT,Uw2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Uu2 @ ( zero_zero @ nat ) @ Uv2 @ Uw2 ) )
=> ( ~ Y
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V5765760719290551771er_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Uu2 @ ( zero_zero @ nat ) @ Uv2 @ Uw2 ) @ Xa2 ) ) ) )
=> ~ ! [Uy2: option @ ( product_prod @ nat @ nat ),V3: nat,TreeList3: list @ vEBT_VEBT,S2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Uy2 @ ( suc @ V3 ) @ TreeList3 @ S2 ) )
=> ( ( Y
= ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_V5719532721284313246member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V5765760719290551771er_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Uy2 @ ( suc @ V3 ) @ TreeList3 @ S2 ) @ Xa2 ) ) ) ) ) ) ) ) ).
% VEBT_internal.naive_member.pelims(1)
thf(fact_1784_vebt__member_Opelims_I2_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ( vEBT_vebt_member @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ A7 @ B5 ) @ Xa2 ) )
=> ~ ( ( ( Xa2
= ( zero_zero @ nat ) )
=> A7 )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( ( ( Xa2
= ( one_one @ nat ) )
=> B5 )
& ( Xa2
= ( one_one @ nat ) ) ) ) ) ) )
=> ~ ! [Mi2: nat,Ma2: nat,Va2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_vebt_member_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ ( suc @ Va2 ) ) @ TreeList3 @ Summary2 ) @ Xa2 ) )
=> ~ ( ( Xa2 != Mi2 )
=> ( ( Xa2 != Ma2 )
=> ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
& ( ~ ( ord_less @ nat @ Xa2 @ Mi2 )
=> ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
& ( ~ ( ord_less @ nat @ Ma2 @ Xa2 )
=> ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_vebt_member @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) ) ) ) ) ) ).
% vebt_member.pelims(2)
thf(fact_1785_VEBT__internal_Omembermima_Opelims_I1_J,axiom,
! [X: vEBT_VEBT,Xa2: nat,Y: $o] :
( ( ( vEBT_VEBT_membermima @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [Uu2: $o,Uv2: $o] :
( ( X
= ( vEBT_Leaf @ Uu2 @ Uv2 ) )
=> ( ~ Y
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ Uu2 @ Uv2 ) @ Xa2 ) ) ) )
=> ( ! [Ux2: list @ vEBT_VEBT,Uy2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( zero_zero @ nat ) @ Ux2 @ Uy2 ) )
=> ( ~ Y
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( zero_zero @ nat ) @ Ux2 @ Uy2 ) @ Xa2 ) ) ) )
=> ( ! [Mi2: nat,Ma2: nat,Va3: list @ vEBT_VEBT,Vb2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( zero_zero @ nat ) @ Va3 @ Vb2 ) )
=> ( ( Y
= ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( zero_zero @ nat ) @ Va3 @ Vb2 ) @ Xa2 ) ) ) )
=> ( ! [Mi2: nat,Ma2: nat,V3: nat,TreeList3: list @ vEBT_VEBT,Vc2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ V3 ) @ TreeList3 @ Vc2 ) )
=> ( ( Y
= ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 )
| ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ V3 ) @ TreeList3 @ Vc2 ) @ Xa2 ) ) ) )
=> ~ ! [V3: nat,TreeList3: list @ vEBT_VEBT,Vd: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ V3 ) @ TreeList3 @ Vd ) )
=> ( ( Y
= ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ V3 ) @ TreeList3 @ Vd ) @ Xa2 ) ) ) ) ) ) ) ) ) ) ).
% VEBT_internal.membermima.pelims(1)
thf(fact_1786_VEBT__internal_Omembermima_Opelims_I2_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ( vEBT_VEBT_membermima @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [Mi2: nat,Ma2: nat,Va3: list @ vEBT_VEBT,Vb2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( zero_zero @ nat ) @ Va3 @ Vb2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( zero_zero @ nat ) @ Va3 @ Vb2 ) @ Xa2 ) )
=> ~ ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 ) ) ) )
=> ( ! [Mi2: nat,Ma2: nat,V3: nat,TreeList3: list @ vEBT_VEBT,Vc2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ V3 ) @ TreeList3 @ Vc2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ V3 ) @ TreeList3 @ Vc2 ) @ Xa2 ) )
=> ~ ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 )
| ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) )
=> ~ ! [V3: nat,TreeList3: list @ vEBT_VEBT,Vd: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ V3 ) @ TreeList3 @ Vd ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ V3 ) @ TreeList3 @ Vd ) @ Xa2 ) )
=> ~ ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) ).
% VEBT_internal.membermima.pelims(2)
thf(fact_1787_VEBT__internal_Omembermima_Opelims_I3_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ~ ( vEBT_VEBT_membermima @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [Uu2: $o,Uv2: $o] :
( ( X
= ( vEBT_Leaf @ Uu2 @ Uv2 ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ Uu2 @ Uv2 ) @ Xa2 ) ) )
=> ( ! [Ux2: list @ vEBT_VEBT,Uy2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( zero_zero @ nat ) @ Ux2 @ Uy2 ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( zero_zero @ nat ) @ Ux2 @ Uy2 ) @ Xa2 ) ) )
=> ( ! [Mi2: nat,Ma2: nat,Va3: list @ vEBT_VEBT,Vb2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( zero_zero @ nat ) @ Va3 @ Vb2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( zero_zero @ nat ) @ Va3 @ Vb2 ) @ Xa2 ) )
=> ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 ) ) ) )
=> ( ! [Mi2: nat,Ma2: nat,V3: nat,TreeList3: list @ vEBT_VEBT,Vc2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ V3 ) @ TreeList3 @ Vc2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( some @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ Mi2 @ Ma2 ) ) @ ( suc @ V3 ) @ TreeList3 @ Vc2 ) @ Xa2 ) )
=> ( ( Xa2 = Mi2 )
| ( Xa2 = Ma2 )
| ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) )
=> ~ ! [V3: nat,TreeList3: list @ vEBT_VEBT,Vd: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ V3 ) @ TreeList3 @ Vd ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_V4351362008482014158ma_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ V3 ) @ TreeList3 @ Vd ) @ Xa2 ) )
=> ( ( ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) )
=> ( vEBT_VEBT_membermima @ ( nth @ vEBT_VEBT @ TreeList3 @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_VEBT_low @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( ord_less @ nat @ ( vEBT_VEBT_high @ Xa2 @ ( divide_divide @ nat @ ( suc @ V3 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 ) ) ) ) ) ) ) ) ) ) ) ).
% VEBT_internal.membermima.pelims(3)
thf(fact_1788_arcosh__1,axiom,
! [A: $tType] :
( ( ln @ A )
=> ( ( arcosh @ A @ ( one_one @ A ) )
= ( zero_zero @ A ) ) ) ).
% arcosh_1
thf(fact_1789_artanh__0,axiom,
! [A: $tType] :
( ( ( real_V3459762299906320749_field @ A )
& ( ln @ A ) )
=> ( ( artanh @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% artanh_0
thf(fact_1790_arsinh__0,axiom,
! [A: $tType] :
( ( ln @ A )
=> ( ( arsinh @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% arsinh_0
thf(fact_1791_signed__take__bit__rec,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ( ( bit_ri4674362597316999326ke_bit @ A )
= ( ^ [N: nat,A5: A] :
( if @ A
@ ( N
= ( zero_zero @ nat ) )
@ ( uminus_uminus @ A @ ( modulo_modulo @ A @ A5 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) )
@ ( plus_plus @ A @ ( modulo_modulo @ A @ A5 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_ri4674362597316999326ke_bit @ A @ ( minus_minus @ nat @ N @ ( one_one @ nat ) ) @ ( divide_divide @ A @ A5 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ).
% signed_take_bit_rec
thf(fact_1792_vebt__buildup_Opelims,axiom,
! [X: nat,Y: vEBT_VEBT] :
( ( ( vEBT_vebt_buildup @ X )
= Y )
=> ( ( accp @ nat @ vEBT_v4011308405150292612up_rel @ X )
=> ( ( ( X
= ( zero_zero @ nat ) )
=> ( ( Y
= ( vEBT_Leaf @ $false @ $false ) )
=> ~ ( accp @ nat @ vEBT_v4011308405150292612up_rel @ ( zero_zero @ nat ) ) ) )
=> ( ( ( X
= ( suc @ ( zero_zero @ nat ) ) )
=> ( ( Y
= ( vEBT_Leaf @ $false @ $false ) )
=> ~ ( accp @ nat @ vEBT_v4011308405150292612up_rel @ ( suc @ ( zero_zero @ nat ) ) ) ) )
=> ~ ! [Va2: nat] :
( ( X
= ( suc @ ( suc @ Va2 ) ) )
=> ( ( ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ ( suc @ Va2 ) ) )
=> ( Y
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ ( suc @ Va2 ) ) @ ( replicate @ vEBT_VEBT @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( vEBT_vebt_buildup @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_vebt_buildup @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) )
& ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ ( suc @ Va2 ) ) )
=> ( Y
= ( vEBT_Node @ ( none @ ( product_prod @ nat @ nat ) ) @ ( suc @ ( suc @ Va2 ) ) @ ( replicate @ vEBT_VEBT @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( suc @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_vebt_buildup @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( vEBT_vebt_buildup @ ( suc @ ( divide_divide @ nat @ ( suc @ ( suc @ Va2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) )
=> ~ ( accp @ nat @ vEBT_v4011308405150292612up_rel @ ( suc @ ( suc @ Va2 ) ) ) ) ) ) ) ) ) ).
% vebt_buildup.pelims
thf(fact_1793_diff__shunt__var,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A] :
( ( ( minus_minus @ A @ X @ Y )
= ( bot_bot @ A ) )
= ( ord_less_eq @ A @ X @ Y ) ) ) ).
% diff_shunt_var
thf(fact_1794_artanh__def,axiom,
! [A: $tType] :
( ( ( real_V3459762299906320749_field @ A )
& ( ln @ A ) )
=> ( ( artanh @ A )
= ( ^ [X2: A] : ( divide_divide @ A @ ( ln_ln @ A @ ( divide_divide @ A @ ( plus_plus @ A @ ( one_one @ A ) @ X2 ) @ ( minus_minus @ A @ ( one_one @ A ) @ X2 ) ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% artanh_def
thf(fact_1795_neg__equal__iff__equal,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( ( uminus_uminus @ A @ A3 )
= ( uminus_uminus @ A @ B2 ) )
= ( A3 = B2 ) ) ) ).
% neg_equal_iff_equal
thf(fact_1796_add_Oinverse__inverse,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A] :
( ( uminus_uminus @ A @ ( uminus_uminus @ A @ A3 ) )
= A3 ) ) ).
% add.inverse_inverse
thf(fact_1797_uminus__apply,axiom,
! [B: $tType,A: $tType] :
( ( uminus @ B )
=> ( ( uminus_uminus @ ( A > B ) )
= ( ^ [A6: A > B,X2: A] : ( uminus_uminus @ B @ ( A6 @ X2 ) ) ) ) ) ).
% uminus_apply
thf(fact_1798_Compl__anti__mono,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ ( set @ A ) @ ( uminus_uminus @ ( set @ A ) @ B3 ) @ ( uminus_uminus @ ( set @ A ) @ A4 ) ) ) ).
% Compl_anti_mono
thf(fact_1799_Compl__subset__Compl__iff,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( uminus_uminus @ ( set @ A ) @ A4 ) @ ( uminus_uminus @ ( set @ A ) @ B3 ) )
= ( ord_less_eq @ ( set @ A ) @ B3 @ A4 ) ) ).
% Compl_subset_Compl_iff
thf(fact_1800_compl__le__compl__iff,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( uminus_uminus @ A @ X ) @ ( uminus_uminus @ A @ Y ) )
= ( ord_less_eq @ A @ Y @ X ) ) ) ).
% compl_le_compl_iff
thf(fact_1801_neg__le__iff__le,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ ( uminus_uminus @ A @ B2 ) @ ( uminus_uminus @ A @ A3 ) )
= ( ord_less_eq @ A @ A3 @ B2 ) ) ) ).
% neg_le_iff_le
thf(fact_1802_add_Oinverse__neutral,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ( ( uminus_uminus @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% add.inverse_neutral
thf(fact_1803_neg__0__equal__iff__equal,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A] :
( ( ( zero_zero @ A )
= ( uminus_uminus @ A @ A3 ) )
= ( ( zero_zero @ A )
= A3 ) ) ) ).
% neg_0_equal_iff_equal
thf(fact_1804_neg__equal__0__iff__equal,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A] :
( ( ( uminus_uminus @ A @ A3 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% neg_equal_0_iff_equal
thf(fact_1805_equal__neg__zero,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( A3
= ( uminus_uminus @ A @ A3 ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% equal_neg_zero
thf(fact_1806_neg__equal__zero,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( ( uminus_uminus @ A @ A3 )
= A3 )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% neg_equal_zero
thf(fact_1807_compl__less__compl__iff,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ ( uminus_uminus @ A @ X ) @ ( uminus_uminus @ A @ Y ) )
= ( ord_less @ A @ Y @ X ) ) ) ).
% compl_less_compl_iff
thf(fact_1808_neg__less__iff__less,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ ( uminus_uminus @ A @ B2 ) @ ( uminus_uminus @ A @ A3 ) )
= ( ord_less @ A @ A3 @ B2 ) ) ) ).
% neg_less_iff_less
thf(fact_1809_mult__minus__right,axiom,
! [A: $tType] :
( ( ring @ A )
=> ! [A3: A,B2: A] :
( ( times_times @ A @ A3 @ ( uminus_uminus @ A @ B2 ) )
= ( uminus_uminus @ A @ ( times_times @ A @ A3 @ B2 ) ) ) ) ).
% mult_minus_right
thf(fact_1810_minus__mult__minus,axiom,
! [A: $tType] :
( ( ring @ A )
=> ! [A3: A,B2: A] :
( ( times_times @ A @ ( uminus_uminus @ A @ A3 ) @ ( uminus_uminus @ A @ B2 ) )
= ( times_times @ A @ A3 @ B2 ) ) ) ).
% minus_mult_minus
thf(fact_1811_mult__minus__left,axiom,
! [A: $tType] :
( ( ring @ A )
=> ! [A3: A,B2: A] :
( ( times_times @ A @ ( uminus_uminus @ A @ A3 ) @ B2 )
= ( uminus_uminus @ A @ ( times_times @ A @ A3 @ B2 ) ) ) ) ).
% mult_minus_left
thf(fact_1812_add__minus__cancel,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( plus_plus @ A @ A3 @ ( plus_plus @ A @ ( uminus_uminus @ A @ A3 ) @ B2 ) )
= B2 ) ) ).
% add_minus_cancel
thf(fact_1813_minus__add__cancel,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ A3 ) @ ( plus_plus @ A @ A3 @ B2 ) )
= B2 ) ) ).
% minus_add_cancel
thf(fact_1814_minus__add__distrib,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [A3: A,B2: A] :
( ( uminus_uminus @ A @ ( plus_plus @ A @ A3 @ B2 ) )
= ( plus_plus @ A @ ( uminus_uminus @ A @ A3 ) @ ( uminus_uminus @ A @ B2 ) ) ) ) ).
% minus_add_distrib
thf(fact_1815_minus__diff__eq,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( uminus_uminus @ A @ ( minus_minus @ A @ A3 @ B2 ) )
= ( minus_minus @ A @ B2 @ A3 ) ) ) ).
% minus_diff_eq
thf(fact_1816_minus__dvd__iff,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [X: A,Y: A] :
( ( dvd_dvd @ A @ ( uminus_uminus @ A @ X ) @ Y )
= ( dvd_dvd @ A @ X @ Y ) ) ) ).
% minus_dvd_iff
thf(fact_1817_dvd__minus__iff,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [X: A,Y: A] :
( ( dvd_dvd @ A @ X @ ( uminus_uminus @ A @ Y ) )
= ( dvd_dvd @ A @ X @ Y ) ) ) ).
% dvd_minus_iff
thf(fact_1818_neg__0__le__iff__le,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( uminus_uminus @ A @ A3 ) )
= ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% neg_0_le_iff_le
thf(fact_1819_neg__le__0__iff__le,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( uminus_uminus @ A @ A3 ) @ ( zero_zero @ A ) )
= ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% neg_le_0_iff_le
thf(fact_1820_less__eq__neg__nonpos,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ A3 @ ( uminus_uminus @ A @ A3 ) )
= ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% less_eq_neg_nonpos
thf(fact_1821_neg__less__eq__nonneg,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( uminus_uminus @ A @ A3 ) @ A3 )
= ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% neg_less_eq_nonneg
thf(fact_1822_less__neg__neg,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( ord_less @ A @ A3 @ ( uminus_uminus @ A @ A3 ) )
= ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% less_neg_neg
thf(fact_1823_neg__less__pos,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( uminus_uminus @ A @ A3 ) @ A3 )
= ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% neg_less_pos
thf(fact_1824_neg__0__less__iff__less,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( uminus_uminus @ A @ A3 ) )
= ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% neg_0_less_iff_less
thf(fact_1825_neg__less__0__iff__less,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( uminus_uminus @ A @ A3 ) @ ( zero_zero @ A ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% neg_less_0_iff_less
thf(fact_1826_ab__left__minus,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ A3 ) @ A3 )
= ( zero_zero @ A ) ) ) ).
% ab_left_minus
thf(fact_1827_add_Oright__inverse,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A] :
( ( plus_plus @ A @ A3 @ ( uminus_uminus @ A @ A3 ) )
= ( zero_zero @ A ) ) ) ).
% add.right_inverse
thf(fact_1828_verit__minus__simplify_I3_J,axiom,
! [B: $tType] :
( ( group_add @ B )
=> ! [B2: B] :
( ( minus_minus @ B @ ( zero_zero @ B ) @ B2 )
= ( uminus_uminus @ B @ B2 ) ) ) ).
% verit_minus_simplify(3)
thf(fact_1829_diff__0,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A] :
( ( minus_minus @ A @ ( zero_zero @ A ) @ A3 )
= ( uminus_uminus @ A @ A3 ) ) ) ).
% diff_0
thf(fact_1830_add__neg__numeral__simps_I3_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [M: num,N2: num] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) )
= ( uminus_uminus @ A @ ( plus_plus @ A @ ( numeral_numeral @ A @ M ) @ ( numeral_numeral @ A @ N2 ) ) ) ) ) ).
% add_neg_numeral_simps(3)
thf(fact_1831_diff__minus__eq__add,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( minus_minus @ A @ A3 @ ( uminus_uminus @ A @ B2 ) )
= ( plus_plus @ A @ A3 @ B2 ) ) ) ).
% diff_minus_eq_add
thf(fact_1832_uminus__add__conv__diff,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [A3: A,B2: A] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ A3 ) @ B2 )
= ( minus_minus @ A @ B2 @ A3 ) ) ) ).
% uminus_add_conv_diff
thf(fact_1833_divide__minus1,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [X: A] :
( ( divide_divide @ A @ X @ ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( uminus_uminus @ A @ X ) ) ) ).
% divide_minus1
thf(fact_1834_ln__one,axiom,
! [A: $tType] :
( ( ln @ A )
=> ( ( ln_ln @ A @ ( one_one @ A ) )
= ( zero_zero @ A ) ) ) ).
% ln_one
thf(fact_1835_add__neg__numeral__special_I7_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ( ( plus_plus @ A @ ( one_one @ A ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( zero_zero @ A ) ) ) ).
% add_neg_numeral_special(7)
thf(fact_1836_add__neg__numeral__special_I8_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ( ( plus_plus @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( one_one @ A ) )
= ( zero_zero @ A ) ) ) ).
% add_neg_numeral_special(8)
thf(fact_1837_diff__numeral__special_I12_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ( ( minus_minus @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( zero_zero @ A ) ) ) ).
% diff_numeral_special(12)
thf(fact_1838_mod__minus1__right,axiom,
! [A: $tType] :
( ( euclid8851590272496341667cancel @ A )
=> ! [A3: A] :
( ( modulo_modulo @ A @ A3 @ ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( zero_zero @ A ) ) ) ).
% mod_minus1_right
thf(fact_1839_max__number__of_I4_J,axiom,
! [A: $tType] :
( ( ( uminus @ A )
& ( numeral @ A )
& ( ord @ A ) )
=> ! [U: num,V2: num] :
( ( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
=> ( ( ord_max @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
=> ( ( ord_max @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) ) ) ) ) ).
% max_number_of(4)
thf(fact_1840_max__number__of_I3_J,axiom,
! [A: $tType] :
( ( ( uminus @ A )
& ( numeral @ A )
& ( ord @ A ) )
=> ! [U: num,V2: num] :
( ( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( numeral_numeral @ A @ V2 ) )
=> ( ( ord_max @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( numeral_numeral @ A @ V2 ) )
= ( numeral_numeral @ A @ V2 ) ) )
& ( ~ ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( numeral_numeral @ A @ V2 ) )
=> ( ( ord_max @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( numeral_numeral @ A @ V2 ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) ) ) ) ) ).
% max_number_of(3)
thf(fact_1841_max__number__of_I2_J,axiom,
! [A: $tType] :
( ( ( uminus @ A )
& ( numeral @ A )
& ( ord @ A ) )
=> ! [U: num,V2: num] :
( ( ( ord_less_eq @ A @ ( numeral_numeral @ A @ U ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
=> ( ( ord_max @ A @ ( numeral_numeral @ A @ U ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( numeral_numeral @ A @ U ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
=> ( ( ord_max @ A @ ( numeral_numeral @ A @ U ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
= ( numeral_numeral @ A @ U ) ) ) ) ) ).
% max_number_of(2)
thf(fact_1842_semiring__norm_I168_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [V2: num,W2: num,Y: A] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) @ ( plus_plus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ Y ) )
= ( plus_plus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ ( plus_plus @ num @ V2 @ W2 ) ) ) @ Y ) ) ) ).
% semiring_norm(168)
thf(fact_1843_neg__numeral__le__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num,N2: num] :
( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) )
= ( ord_less_eq @ num @ N2 @ M ) ) ) ).
% neg_numeral_le_iff
thf(fact_1844_neg__numeral__less__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num,N2: num] :
( ( ord_less @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) )
= ( ord_less @ num @ N2 @ M ) ) ) ).
% neg_numeral_less_iff
thf(fact_1845_not__neg__one__le__neg__numeral__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] :
( ( ~ ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) ) )
= ( M != one2 ) ) ) ).
% not_neg_one_le_neg_numeral_iff
thf(fact_1846_le__divide__eq__numeral1_I2_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,W2: num] :
( ( ord_less_eq @ A @ A3 @ ( divide_divide @ A @ B2 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) )
= ( ord_less_eq @ A @ B2 @ ( times_times @ A @ A3 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) ) ) ) ).
% le_divide_eq_numeral1(2)
thf(fact_1847_divide__le__eq__numeral1_I2_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,W2: num,A3: A] :
( ( ord_less_eq @ A @ ( divide_divide @ A @ B2 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) @ A3 )
= ( ord_less_eq @ A @ ( times_times @ A @ A3 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) @ B2 ) ) ) ).
% divide_le_eq_numeral1(2)
thf(fact_1848_eq__divide__eq__numeral1_I2_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A,W2: num] :
( ( A3
= ( divide_divide @ A @ B2 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) )
= ( ( ( ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) )
!= ( zero_zero @ A ) )
=> ( ( times_times @ A @ A3 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) )
= B2 ) )
& ( ( ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) )
= ( zero_zero @ A ) )
=> ( A3
= ( zero_zero @ A ) ) ) ) ) ) ).
% eq_divide_eq_numeral1(2)
thf(fact_1849_divide__eq__eq__numeral1_I2_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [B2: A,W2: num,A3: A] :
( ( ( divide_divide @ A @ B2 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) )
= A3 )
= ( ( ( ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) )
!= ( zero_zero @ A ) )
=> ( B2
= ( times_times @ A @ A3 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) ) )
& ( ( ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) )
= ( zero_zero @ A ) )
=> ( A3
= ( zero_zero @ A ) ) ) ) ) ) ).
% divide_eq_eq_numeral1(2)
thf(fact_1850_neg__numeral__less__neg__one__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] :
( ( ord_less @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( M != one2 ) ) ) ).
% neg_numeral_less_neg_one_iff
thf(fact_1851_divide__less__eq__numeral1_I2_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,W2: num,A3: A] :
( ( ord_less @ A @ ( divide_divide @ A @ B2 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) @ A3 )
= ( ord_less @ A @ ( times_times @ A @ A3 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) @ B2 ) ) ) ).
% divide_less_eq_numeral1(2)
thf(fact_1852_less__divide__eq__numeral1_I2_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,W2: num] :
( ( ord_less @ A @ A3 @ ( divide_divide @ A @ B2 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) )
= ( ord_less @ A @ B2 @ ( times_times @ A @ A3 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) ) ) ) ).
% less_divide_eq_numeral1(2)
thf(fact_1853_add__neg__numeral__special_I9_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ( ( plus_plus @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% add_neg_numeral_special(9)
thf(fact_1854_signed__take__bit__Suc__minus__bit0,axiom,
! [N2: nat,K: num] :
( ( bit_ri4674362597316999326ke_bit @ int @ ( suc @ N2 ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ ( bit0 @ K ) ) ) )
= ( times_times @ int @ ( bit_ri4674362597316999326ke_bit @ int @ N2 @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ K ) ) ) @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) ) ).
% signed_take_bit_Suc_minus_bit0
thf(fact_1855_signed__take__bit__0,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [A3: A] :
( ( bit_ri4674362597316999326ke_bit @ A @ ( zero_zero @ nat ) @ A3 )
= ( uminus_uminus @ A @ ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% signed_take_bit_0
thf(fact_1856_minus__equation__iff,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( ( uminus_uminus @ A @ A3 )
= B2 )
= ( ( uminus_uminus @ A @ B2 )
= A3 ) ) ) ).
% minus_equation_iff
thf(fact_1857_equation__minus__iff,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( A3
= ( uminus_uminus @ A @ B2 ) )
= ( B2
= ( uminus_uminus @ A @ A3 ) ) ) ) ).
% equation_minus_iff
thf(fact_1858_fun__Compl__def,axiom,
! [B: $tType,A: $tType] :
( ( uminus @ B )
=> ( ( uminus_uminus @ ( A > B ) )
= ( ^ [A6: A > B,X2: A] : ( uminus_uminus @ B @ ( A6 @ X2 ) ) ) ) ) ).
% fun_Compl_def
thf(fact_1859_compl__less__swap2,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [Y: A,X: A] :
( ( ord_less @ A @ ( uminus_uminus @ A @ Y ) @ X )
=> ( ord_less @ A @ ( uminus_uminus @ A @ X ) @ Y ) ) ) ).
% compl_less_swap2
thf(fact_1860_compl__less__swap1,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [Y: A,X: A] :
( ( ord_less @ A @ Y @ ( uminus_uminus @ A @ X ) )
=> ( ord_less @ A @ X @ ( uminus_uminus @ A @ Y ) ) ) ) ).
% compl_less_swap1
thf(fact_1861_compl__le__swap2,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ ( uminus_uminus @ A @ Y ) @ X )
=> ( ord_less_eq @ A @ ( uminus_uminus @ A @ X ) @ Y ) ) ) ).
% compl_le_swap2
thf(fact_1862_compl__le__swap1,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ Y @ ( uminus_uminus @ A @ X ) )
=> ( ord_less_eq @ A @ X @ ( uminus_uminus @ A @ Y ) ) ) ) ).
% compl_le_swap1
thf(fact_1863_compl__mono,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ord_less_eq @ A @ ( uminus_uminus @ A @ Y ) @ ( uminus_uminus @ A @ X ) ) ) ) ).
% compl_mono
thf(fact_1864_le__minus__iff,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ ( uminus_uminus @ A @ B2 ) )
= ( ord_less_eq @ A @ B2 @ ( uminus_uminus @ A @ A3 ) ) ) ) ).
% le_minus_iff
thf(fact_1865_minus__le__iff,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( uminus_uminus @ A @ A3 ) @ B2 )
= ( ord_less_eq @ A @ ( uminus_uminus @ A @ B2 ) @ A3 ) ) ) ).
% minus_le_iff
thf(fact_1866_le__imp__neg__le,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ord_less_eq @ A @ ( uminus_uminus @ A @ B2 ) @ ( uminus_uminus @ A @ A3 ) ) ) ) ).
% le_imp_neg_le
thf(fact_1867_verit__negate__coefficient_I2_J,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ord_less @ A @ ( uminus_uminus @ A @ B2 ) @ ( uminus_uminus @ A @ A3 ) ) ) ) ).
% verit_negate_coefficient(2)
thf(fact_1868_less__minus__iff,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( uminus_uminus @ A @ B2 ) )
= ( ord_less @ A @ B2 @ ( uminus_uminus @ A @ A3 ) ) ) ) ).
% less_minus_iff
thf(fact_1869_minus__less__iff,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( uminus_uminus @ A @ A3 ) @ B2 )
= ( ord_less @ A @ ( uminus_uminus @ A @ B2 ) @ A3 ) ) ) ).
% minus_less_iff
thf(fact_1870_minus__mult__commute,axiom,
! [A: $tType] :
( ( ring @ A )
=> ! [A3: A,B2: A] :
( ( times_times @ A @ ( uminus_uminus @ A @ A3 ) @ B2 )
= ( times_times @ A @ A3 @ ( uminus_uminus @ A @ B2 ) ) ) ) ).
% minus_mult_commute
thf(fact_1871_square__eq__iff,axiom,
! [A: $tType] :
( ( idom @ A )
=> ! [A3: A,B2: A] :
( ( ( times_times @ A @ A3 @ A3 )
= ( times_times @ A @ B2 @ B2 ) )
= ( ( A3 = B2 )
| ( A3
= ( uminus_uminus @ A @ B2 ) ) ) ) ) ).
% square_eq_iff
thf(fact_1872_is__num__normalize_I8_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [A3: A,B2: A] :
( ( uminus_uminus @ A @ ( plus_plus @ A @ A3 @ B2 ) )
= ( plus_plus @ A @ ( uminus_uminus @ A @ B2 ) @ ( uminus_uminus @ A @ A3 ) ) ) ) ).
% is_num_normalize(8)
thf(fact_1873_group__cancel_Oneg1,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [A4: A,K: A,A3: A] :
( ( A4
= ( plus_plus @ A @ K @ A3 ) )
=> ( ( uminus_uminus @ A @ A4 )
= ( plus_plus @ A @ ( uminus_uminus @ A @ K ) @ ( uminus_uminus @ A @ A3 ) ) ) ) ) ).
% group_cancel.neg1
thf(fact_1874_add_Oinverse__distrib__swap,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( uminus_uminus @ A @ ( plus_plus @ A @ A3 @ B2 ) )
= ( plus_plus @ A @ ( uminus_uminus @ A @ B2 ) @ ( uminus_uminus @ A @ A3 ) ) ) ) ).
% add.inverse_distrib_swap
thf(fact_1875_minus__diff__commute,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [B2: A,A3: A] :
( ( minus_minus @ A @ ( uminus_uminus @ A @ B2 ) @ A3 )
= ( minus_minus @ A @ ( uminus_uminus @ A @ A3 ) @ B2 ) ) ) ).
% minus_diff_commute
thf(fact_1876_minus__divide__left,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A] :
( ( uminus_uminus @ A @ ( divide_divide @ A @ A3 @ B2 ) )
= ( divide_divide @ A @ ( uminus_uminus @ A @ A3 ) @ B2 ) ) ) ).
% minus_divide_left
thf(fact_1877_minus__divide__divide,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A] :
( ( divide_divide @ A @ ( uminus_uminus @ A @ A3 ) @ ( uminus_uminus @ A @ B2 ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ).
% minus_divide_divide
thf(fact_1878_minus__divide__right,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A] :
( ( uminus_uminus @ A @ ( divide_divide @ A @ A3 @ B2 ) )
= ( divide_divide @ A @ A3 @ ( uminus_uminus @ A @ B2 ) ) ) ) ).
% minus_divide_right
thf(fact_1879_uminus__int__code_I1_J,axiom,
( ( uminus_uminus @ int @ ( zero_zero @ int ) )
= ( zero_zero @ int ) ) ).
% uminus_int_code(1)
thf(fact_1880_not__numeral__le__neg__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num,N2: num] :
~ ( ord_less_eq @ A @ ( numeral_numeral @ A @ M ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) ) ) ).
% not_numeral_le_neg_numeral
thf(fact_1881_neg__numeral__le__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num,N2: num] : ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( numeral_numeral @ A @ N2 ) ) ) ).
% neg_numeral_le_numeral
thf(fact_1882_zero__neq__neg__numeral,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [N2: num] :
( ( zero_zero @ A )
!= ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) ) ) ).
% zero_neq_neg_numeral
thf(fact_1883_neg__numeral__less__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num,N2: num] : ( ord_less @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( numeral_numeral @ A @ N2 ) ) ) ).
% neg_numeral_less_numeral
thf(fact_1884_not__numeral__less__neg__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num,N2: num] :
~ ( ord_less @ A @ ( numeral_numeral @ A @ M ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) ) ) ).
% not_numeral_less_neg_numeral
thf(fact_1885_le__minus__one__simps_I4_J,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ~ ( ord_less_eq @ A @ ( one_one @ A ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% le_minus_one_simps(4)
thf(fact_1886_le__minus__one__simps_I2_J,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( one_one @ A ) ) ) ).
% le_minus_one_simps(2)
thf(fact_1887_zero__neq__neg__one,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ( ( zero_zero @ A )
!= ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% zero_neq_neg_one
thf(fact_1888_neg__eq__iff__add__eq__0,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( ( uminus_uminus @ A @ A3 )
= B2 )
= ( ( plus_plus @ A @ A3 @ B2 )
= ( zero_zero @ A ) ) ) ) ).
% neg_eq_iff_add_eq_0
thf(fact_1889_eq__neg__iff__add__eq__0,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( A3
= ( uminus_uminus @ A @ B2 ) )
= ( ( plus_plus @ A @ A3 @ B2 )
= ( zero_zero @ A ) ) ) ) ).
% eq_neg_iff_add_eq_0
thf(fact_1890_add_Oinverse__unique,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( ( plus_plus @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
=> ( ( uminus_uminus @ A @ A3 )
= B2 ) ) ) ).
% add.inverse_unique
thf(fact_1891_ab__group__add__class_Oab__left__minus,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [A3: A] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ A3 ) @ A3 )
= ( zero_zero @ A ) ) ) ).
% ab_group_add_class.ab_left_minus
thf(fact_1892_add__eq__0__iff,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A,B2: A] :
( ( ( plus_plus @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
= ( B2
= ( uminus_uminus @ A @ A3 ) ) ) ) ).
% add_eq_0_iff
thf(fact_1893_less__minus__one__simps_I2_J,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ( ord_less @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( one_one @ A ) ) ) ).
% less_minus_one_simps(2)
thf(fact_1894_less__minus__one__simps_I4_J,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ~ ( ord_less @ A @ ( one_one @ A ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% less_minus_one_simps(4)
thf(fact_1895_nonzero__minus__divide__divide,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( uminus_uminus @ A @ A3 ) @ ( uminus_uminus @ A @ B2 ) )
= ( divide_divide @ A @ A3 @ B2 ) ) ) ) ).
% nonzero_minus_divide_divide
thf(fact_1896_nonzero__minus__divide__right,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( uminus_uminus @ A @ ( divide_divide @ A @ A3 @ B2 ) )
= ( divide_divide @ A @ A3 @ ( uminus_uminus @ A @ B2 ) ) ) ) ) ).
% nonzero_minus_divide_right
thf(fact_1897_square__eq__1__iff,axiom,
! [A: $tType] :
( ( ring_15535105094025558882visors @ A )
=> ! [X: A] :
( ( ( times_times @ A @ X @ X )
= ( one_one @ A ) )
= ( ( X
= ( one_one @ A ) )
| ( X
= ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ) ) ).
% square_eq_1_iff
thf(fact_1898_ab__group__add__class_Oab__diff__conv__add__uminus,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ( ( minus_minus @ A )
= ( ^ [A5: A,B4: A] : ( plus_plus @ A @ A5 @ ( uminus_uminus @ A @ B4 ) ) ) ) ) ).
% ab_group_add_class.ab_diff_conv_add_uminus
thf(fact_1899_diff__conv__add__uminus,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ( ( minus_minus @ A )
= ( ^ [A5: A,B4: A] : ( plus_plus @ A @ A5 @ ( uminus_uminus @ A @ B4 ) ) ) ) ) ).
% diff_conv_add_uminus
thf(fact_1900_group__cancel_Osub2,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [B3: A,K: A,B2: A,A3: A] :
( ( B3
= ( plus_plus @ A @ K @ B2 ) )
=> ( ( minus_minus @ A @ A3 @ B3 )
= ( plus_plus @ A @ ( uminus_uminus @ A @ K ) @ ( minus_minus @ A @ A3 @ B2 ) ) ) ) ) ).
% group_cancel.sub2
thf(fact_1901_dvd__neg__div,axiom,
! [A: $tType] :
( ( idom_divide @ A )
=> ! [B2: A,A3: A] :
( ( dvd_dvd @ A @ B2 @ A3 )
=> ( ( divide_divide @ A @ ( uminus_uminus @ A @ A3 ) @ B2 )
= ( uminus_uminus @ A @ ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ).
% dvd_neg_div
thf(fact_1902_dvd__div__neg,axiom,
! [A: $tType] :
( ( idom_divide @ A )
=> ! [B2: A,A3: A] :
( ( dvd_dvd @ A @ B2 @ A3 )
=> ( ( divide_divide @ A @ A3 @ ( uminus_uminus @ A @ B2 ) )
= ( uminus_uminus @ A @ ( divide_divide @ A @ A3 @ B2 ) ) ) ) ) ).
% dvd_div_neg
thf(fact_1903_subset__Compl__self__eq,axiom,
! [A: $tType,A4: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ ( uminus_uminus @ ( set @ A ) @ A4 ) )
= ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ).
% subset_Compl_self_eq
thf(fact_1904_zmult__eq__1__iff,axiom,
! [M: int,N2: int] :
( ( ( times_times @ int @ M @ N2 )
= ( one_one @ int ) )
= ( ( ( M
= ( one_one @ int ) )
& ( N2
= ( one_one @ int ) ) )
| ( ( M
= ( uminus_uminus @ int @ ( one_one @ int ) ) )
& ( N2
= ( uminus_uminus @ int @ ( one_one @ int ) ) ) ) ) ) ).
% zmult_eq_1_iff
thf(fact_1905_pos__zmult__eq__1__iff__lemma,axiom,
! [M: int,N2: int] :
( ( ( times_times @ int @ M @ N2 )
= ( one_one @ int ) )
=> ( ( M
= ( one_one @ int ) )
| ( M
= ( uminus_uminus @ int @ ( one_one @ int ) ) ) ) ) ).
% pos_zmult_eq_1_iff_lemma
thf(fact_1906_minus__int__code_I2_J,axiom,
! [L: int] :
( ( minus_minus @ int @ ( zero_zero @ int ) @ L )
= ( uminus_uminus @ int @ L ) ) ).
% minus_int_code(2)
thf(fact_1907_neg__numeral__le__zero,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: num] : ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) @ ( zero_zero @ A ) ) ) ).
% neg_numeral_le_zero
thf(fact_1908_not__zero__le__neg__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: num] :
~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) ) ) ).
% not_zero_le_neg_numeral
thf(fact_1909_neg__numeral__less__zero,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: num] : ( ord_less @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) @ ( zero_zero @ A ) ) ) ).
% neg_numeral_less_zero
thf(fact_1910_not__zero__less__neg__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: num] :
~ ( ord_less @ A @ ( zero_zero @ A ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) ) ) ).
% not_zero_less_neg_numeral
thf(fact_1911_le__minus__one__simps_I3_J,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% le_minus_one_simps(3)
thf(fact_1912_le__minus__one__simps_I1_J,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( zero_zero @ A ) ) ) ).
% le_minus_one_simps(1)
thf(fact_1913_less__minus__one__simps_I3_J,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ~ ( ord_less @ A @ ( zero_zero @ A ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% less_minus_one_simps(3)
thf(fact_1914_less__minus__one__simps_I1_J,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ( ord_less @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( zero_zero @ A ) ) ) ).
% less_minus_one_simps(1)
thf(fact_1915_not__one__le__neg__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] :
~ ( ord_less_eq @ A @ ( one_one @ A ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) ) ) ).
% not_one_le_neg_numeral
thf(fact_1916_not__numeral__le__neg__one,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] :
~ ( ord_less_eq @ A @ ( numeral_numeral @ A @ M ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% not_numeral_le_neg_one
thf(fact_1917_neg__numeral__le__neg__one,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] : ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% neg_numeral_le_neg_one
thf(fact_1918_neg__one__le__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] : ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( numeral_numeral @ A @ M ) ) ) ).
% neg_one_le_numeral
thf(fact_1919_neg__numeral__le__one,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] : ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( one_one @ A ) ) ) ).
% neg_numeral_le_one
thf(fact_1920_neg__numeral__less__one,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] : ( ord_less @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( one_one @ A ) ) ) ).
% neg_numeral_less_one
thf(fact_1921_neg__one__less__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] : ( ord_less @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( numeral_numeral @ A @ M ) ) ) ).
% neg_one_less_numeral
thf(fact_1922_not__numeral__less__neg__one,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] :
~ ( ord_less @ A @ ( numeral_numeral @ A @ M ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% not_numeral_less_neg_one
thf(fact_1923_not__one__less__neg__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] :
~ ( ord_less @ A @ ( one_one @ A ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) ) ) ).
% not_one_less_neg_numeral
thf(fact_1924_not__neg__one__less__neg__numeral,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: num] :
~ ( ord_less @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) ) ) ).
% not_neg_one_less_neg_numeral
thf(fact_1925_nonzero__neg__divide__eq__eq2,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( C2
= ( uminus_uminus @ A @ ( divide_divide @ A @ A3 @ B2 ) ) )
= ( ( times_times @ A @ C2 @ B2 )
= ( uminus_uminus @ A @ A3 ) ) ) ) ) ).
% nonzero_neg_divide_eq_eq2
thf(fact_1926_nonzero__neg__divide__eq__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( ( uminus_uminus @ A @ ( divide_divide @ A @ A3 @ B2 ) )
= C2 )
= ( ( uminus_uminus @ A @ A3 )
= ( times_times @ A @ C2 @ B2 ) ) ) ) ) ).
% nonzero_neg_divide_eq_eq
thf(fact_1927_minus__divide__eq__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) )
= A3 )
= ( ( ( C2
!= ( zero_zero @ A ) )
=> ( ( uminus_uminus @ A @ B2 )
= ( times_times @ A @ A3 @ C2 ) ) )
& ( ( C2
= ( zero_zero @ A ) )
=> ( A3
= ( zero_zero @ A ) ) ) ) ) ) ).
% minus_divide_eq_eq
thf(fact_1928_eq__minus__divide__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( A3
= ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) )
= ( ( ( C2
!= ( zero_zero @ A ) )
=> ( ( times_times @ A @ A3 @ C2 )
= ( uminus_uminus @ A @ B2 ) ) )
& ( ( C2
= ( zero_zero @ A ) )
=> ( A3
= ( zero_zero @ A ) ) ) ) ) ) ).
% eq_minus_divide_eq
thf(fact_1929_divide__eq__minus__1__iff,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A] :
( ( ( divide_divide @ A @ A3 @ B2 )
= ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( ( B2
!= ( zero_zero @ A ) )
& ( A3
= ( uminus_uminus @ A @ B2 ) ) ) ) ) ).
% divide_eq_minus_1_iff
thf(fact_1930_pos__minus__divide__less__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) @ A3 )
= ( ord_less @ A @ ( uminus_uminus @ A @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) ) ) ) ).
% pos_minus_divide_less_eq
thf(fact_1931_pos__less__minus__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less @ A @ A3 @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) )
= ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( uminus_uminus @ A @ B2 ) ) ) ) ) ).
% pos_less_minus_divide_eq
thf(fact_1932_neg__minus__divide__less__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) @ A3 )
= ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( uminus_uminus @ A @ B2 ) ) ) ) ) ).
% neg_minus_divide_less_eq
thf(fact_1933_neg__less__minus__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ A3 @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) )
= ( ord_less @ A @ ( uminus_uminus @ A @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) ) ) ) ).
% neg_less_minus_divide_eq
thf(fact_1934_minus__divide__less__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) @ A3 )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( uminus_uminus @ A @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( uminus_uminus @ A @ B2 ) ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ) ) ) ) ).
% minus_divide_less_eq
thf(fact_1935_less__minus__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( times_times @ A @ A3 @ C2 ) @ ( uminus_uminus @ A @ B2 ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( uminus_uminus @ A @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ) ) ) ) ).
% less_minus_divide_eq
thf(fact_1936_eq__divide__eq__numeral_I2_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [W2: num,B2: A,C2: A] :
( ( ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) )
= ( divide_divide @ A @ B2 @ C2 ) )
= ( ( ( C2
!= ( zero_zero @ A ) )
=> ( ( times_times @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ C2 )
= B2 ) )
& ( ( C2
= ( zero_zero @ A ) )
=> ( ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) )
= ( zero_zero @ A ) ) ) ) ) ) ).
% eq_divide_eq_numeral(2)
thf(fact_1937_divide__eq__eq__numeral_I2_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [B2: A,C2: A,W2: num] :
( ( ( divide_divide @ A @ B2 @ C2 )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) )
= ( ( ( C2
!= ( zero_zero @ A ) )
=> ( B2
= ( times_times @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ C2 ) ) )
& ( ( C2
= ( zero_zero @ A ) )
=> ( ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) )
= ( zero_zero @ A ) ) ) ) ) ) ).
% divide_eq_eq_numeral(2)
thf(fact_1938_add__divide__eq__if__simps_I3_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,A3: A,B2: A] :
( ( ( Z
= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ A3 @ Z ) ) @ B2 )
= B2 ) )
& ( ( Z
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ A3 @ Z ) ) @ B2 )
= ( divide_divide @ A @ ( plus_plus @ A @ ( uminus_uminus @ A @ A3 ) @ ( times_times @ A @ B2 @ Z ) ) @ Z ) ) ) ) ) ).
% add_divide_eq_if_simps(3)
thf(fact_1939_minus__divide__add__eq__iff,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,X: A,Y: A] :
( ( Z
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ X @ Z ) ) @ Y )
= ( divide_divide @ A @ ( plus_plus @ A @ ( uminus_uminus @ A @ X ) @ ( times_times @ A @ Y @ Z ) ) @ Z ) ) ) ) ).
% minus_divide_add_eq_iff
thf(fact_1940_minus__divide__diff__eq__iff,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,X: A,Y: A] :
( ( Z
!= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ X @ Z ) ) @ Y )
= ( divide_divide @ A @ ( minus_minus @ A @ ( uminus_uminus @ A @ X ) @ ( times_times @ A @ Y @ Z ) ) @ Z ) ) ) ) ).
% minus_divide_diff_eq_iff
thf(fact_1941_add__divide__eq__if__simps_I5_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,A3: A,B2: A] :
( ( ( Z
= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ ( divide_divide @ A @ A3 @ Z ) @ B2 )
= ( uminus_uminus @ A @ B2 ) ) )
& ( ( Z
!= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ ( divide_divide @ A @ A3 @ Z ) @ B2 )
= ( divide_divide @ A @ ( minus_minus @ A @ A3 @ ( times_times @ A @ B2 @ Z ) ) @ Z ) ) ) ) ) ).
% add_divide_eq_if_simps(5)
thf(fact_1942_add__divide__eq__if__simps_I6_J,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Z: A,A3: A,B2: A] :
( ( ( Z
= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ A3 @ Z ) ) @ B2 )
= ( uminus_uminus @ A @ B2 ) ) )
& ( ( Z
!= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ A3 @ Z ) ) @ B2 )
= ( divide_divide @ A @ ( minus_minus @ A @ ( uminus_uminus @ A @ A3 ) @ ( times_times @ A @ B2 @ Z ) ) @ Z ) ) ) ) ) ).
% add_divide_eq_if_simps(6)
thf(fact_1943_le__minus__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ ( uminus_uminus @ A @ B2 ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( uminus_uminus @ A @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) ) ) ) ) ) ) ).
% le_minus_divide_eq
thf(fact_1944_minus__divide__le__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) @ A3 )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( uminus_uminus @ A @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ ( uminus_uminus @ A @ B2 ) ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ) ) ) ) ).
% minus_divide_le_eq
thf(fact_1945_neg__le__minus__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ A3 @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) )
= ( ord_less_eq @ A @ ( uminus_uminus @ A @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) ) ) ) ).
% neg_le_minus_divide_eq
thf(fact_1946_neg__minus__divide__le__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) @ A3 )
= ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ ( uminus_uminus @ A @ B2 ) ) ) ) ) ).
% neg_minus_divide_le_eq
thf(fact_1947_pos__le__minus__divide__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less_eq @ A @ A3 @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) )
= ( ord_less_eq @ A @ ( times_times @ A @ A3 @ C2 ) @ ( uminus_uminus @ A @ B2 ) ) ) ) ) ).
% pos_le_minus_divide_eq
thf(fact_1948_pos__minus__divide__le__eq,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( divide_divide @ A @ B2 @ C2 ) ) @ A3 )
= ( ord_less_eq @ A @ ( uminus_uminus @ A @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) ) ) ) ).
% pos_minus_divide_le_eq
thf(fact_1949_less__divide__eq__numeral_I2_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [W2: num,B2: A,C2: A] :
( ( ord_less @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ ( times_times @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ B2 @ ( times_times @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ C2 ) ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ ( zero_zero @ A ) ) ) ) ) ) ) ) ).
% less_divide_eq_numeral(2)
thf(fact_1950_divide__less__eq__numeral_I2_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,C2: A,W2: num] :
( ( ord_less @ A @ ( divide_divide @ A @ B2 @ C2 ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less @ A @ B2 @ ( times_times @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ C2 ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( times_times @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) ) ) ) ) ) ) ).
% divide_less_eq_numeral(2)
thf(fact_1951_neg__one__power__add__eq__neg__one__power__diff,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( power_power @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( plus_plus @ nat @ N2 @ K ) )
= ( power_power @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( minus_minus @ nat @ N2 @ K ) ) ) ) ) ).
% neg_one_power_add_eq_neg_one_power_diff
thf(fact_1952_le__divide__eq__numeral_I2_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [W2: num,B2: A,C2: A] :
( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ ( divide_divide @ A @ B2 @ C2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( times_times @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ B2 @ ( times_times @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ C2 ) ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ ( zero_zero @ A ) ) ) ) ) ) ) ) ).
% le_divide_eq_numeral(2)
thf(fact_1953_divide__le__eq__numeral_I2_J,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,C2: A,W2: num] :
( ( ord_less_eq @ A @ ( divide_divide @ A @ B2 @ C2 ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ B2 @ ( times_times @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ C2 ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ C2 ) @ B2 ) )
& ( ~ ( ord_less @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) ) ) ) ) ) ) ) ).
% divide_le_eq_numeral(2)
thf(fact_1954_square__le__1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A] :
( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ X )
=> ( ( ord_less_eq @ A @ X @ ( one_one @ A ) )
=> ( ord_less_eq @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ A ) ) ) ) ) ).
% square_le_1
thf(fact_1955_power__minus1__odd,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [N2: nat] :
( ( power_power @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) )
= ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% power_minus1_odd
thf(fact_1956_signed__take__bit__int__greater__eq,axiom,
! [K: int,N2: nat] :
( ( ord_less @ int @ K @ ( uminus_uminus @ int @ ( power_power @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ N2 ) ) )
=> ( ord_less_eq @ int @ ( plus_plus @ int @ K @ ( power_power @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ ( suc @ N2 ) ) ) @ ( bit_ri4674362597316999326ke_bit @ int @ N2 @ K ) ) ) ).
% signed_take_bit_int_greater_eq
thf(fact_1957_signed__take__bit__Suc__minus__bit1,axiom,
! [N2: nat,K: num] :
( ( bit_ri4674362597316999326ke_bit @ int @ ( suc @ N2 ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ ( bit1 @ K ) ) ) )
= ( plus_plus @ int @ ( times_times @ int @ ( bit_ri4674362597316999326ke_bit @ int @ N2 @ ( minus_minus @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ K ) ) @ ( one_one @ int ) ) ) @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) @ ( one_one @ int ) ) ) ).
% signed_take_bit_Suc_minus_bit1
thf(fact_1958_divmod__step__def,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ( ( unique1321980374590559556d_step @ A )
= ( ^ [L2: num] :
( product_case_prod @ A @ A @ ( product_prod @ A @ A )
@ ^ [Q5: A,R4: A] : ( if @ ( product_prod @ A @ A ) @ ( ord_less_eq @ A @ ( numeral_numeral @ A @ L2 ) @ R4 ) @ ( product_Pair @ A @ A @ ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ Q5 ) @ ( one_one @ A ) ) @ ( minus_minus @ A @ R4 @ ( numeral_numeral @ A @ L2 ) ) ) @ ( product_Pair @ A @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ Q5 ) @ R4 ) ) ) ) ) ) ).
% divmod_step_def
thf(fact_1959_even__set__encode__iff,axiom,
! [A4: set @ nat] :
( ( finite_finite @ nat @ A4 )
=> ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( nat_set_encode @ A4 ) )
= ( ~ ( member2 @ nat @ ( zero_zero @ nat ) @ A4 ) ) ) ) ).
% even_set_encode_iff
thf(fact_1960_signed__take__bit__Suc__bit1,axiom,
! [N2: nat,K: num] :
( ( bit_ri4674362597316999326ke_bit @ int @ ( suc @ N2 ) @ ( numeral_numeral @ int @ ( bit1 @ K ) ) )
= ( plus_plus @ int @ ( times_times @ int @ ( bit_ri4674362597316999326ke_bit @ int @ N2 @ ( numeral_numeral @ int @ K ) ) @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) @ ( one_one @ int ) ) ) ).
% signed_take_bit_Suc_bit1
thf(fact_1961_take__bit__rec,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ( ( bit_se2584673776208193580ke_bit @ A )
= ( ^ [N: nat,A5: A] :
( if @ A
@ ( N
= ( zero_zero @ nat ) )
@ ( zero_zero @ A )
@ ( plus_plus @ A @ ( times_times @ A @ ( bit_se2584673776208193580ke_bit @ A @ ( minus_minus @ nat @ N @ ( one_one @ nat ) ) @ ( divide_divide @ A @ A5 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( modulo_modulo @ A @ A5 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% take_bit_rec
thf(fact_1962_divmod__algorithm__code_I7_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [M: num,N2: num] :
( ( ( ord_less_eq @ num @ M @ N2 )
=> ( ( unique8689654367752047608divmod @ A @ ( bit0 @ M ) @ ( bit1 @ N2 ) )
= ( product_Pair @ A @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ A @ ( bit0 @ M ) ) ) ) )
& ( ~ ( ord_less_eq @ num @ M @ N2 )
=> ( ( unique8689654367752047608divmod @ A @ ( bit0 @ M ) @ ( bit1 @ N2 ) )
= ( unique1321980374590559556d_step @ A @ ( bit1 @ N2 ) @ ( unique8689654367752047608divmod @ A @ ( bit0 @ M ) @ ( bit0 @ ( bit1 @ N2 ) ) ) ) ) ) ) ) ).
% divmod_algorithm_code(7)
thf(fact_1963_divmod__algorithm__code_I8_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [M: num,N2: num] :
( ( ( ord_less @ num @ M @ N2 )
=> ( ( unique8689654367752047608divmod @ A @ ( bit1 @ M ) @ ( bit1 @ N2 ) )
= ( product_Pair @ A @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ A @ ( bit1 @ M ) ) ) ) )
& ( ~ ( ord_less @ num @ M @ N2 )
=> ( ( unique8689654367752047608divmod @ A @ ( bit1 @ M ) @ ( bit1 @ N2 ) )
= ( unique1321980374590559556d_step @ A @ ( bit1 @ N2 ) @ ( unique8689654367752047608divmod @ A @ ( bit1 @ M ) @ ( bit0 @ ( bit1 @ N2 ) ) ) ) ) ) ) ) ).
% divmod_algorithm_code(8)
thf(fact_1964_take__bit__of__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat] :
( ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% take_bit_of_0
thf(fact_1965_case__prod__conv,axiom,
! [B: $tType,A: $tType,C: $tType,F2: B > C > A,A3: B,B2: C] :
( ( product_case_prod @ B @ C @ A @ F2 @ ( product_Pair @ B @ C @ A3 @ B2 ) )
= ( F2 @ A3 @ B2 ) ) ).
% case_prod_conv
thf(fact_1966_take__bit__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se2584673776208193580ke_bit @ A @ ( zero_zero @ nat ) @ A3 )
= ( zero_zero @ A ) ) ) ).
% take_bit_0
thf(fact_1967_take__bit__Suc__1,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [N2: nat] :
( ( bit_se2584673776208193580ke_bit @ A @ ( suc @ N2 ) @ ( one_one @ A ) )
= ( one_one @ A ) ) ) ).
% take_bit_Suc_1
thf(fact_1968_set__encode__empty,axiom,
( ( nat_set_encode @ ( bot_bot @ ( set @ nat ) ) )
= ( zero_zero @ nat ) ) ).
% set_encode_empty
thf(fact_1969_take__bit__of__1__eq__0__iff,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [N2: nat] :
( ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( one_one @ A ) )
= ( zero_zero @ A ) )
= ( N2
= ( zero_zero @ nat ) ) ) ) ).
% take_bit_of_1_eq_0_iff
thf(fact_1970_take__bit__of__Suc__0,axiom,
! [N2: nat] :
( ( bit_se2584673776208193580ke_bit @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) )
= ( zero_neq_one_of_bool @ nat @ ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ).
% take_bit_of_Suc_0
thf(fact_1971_take__bit__of__1,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat] :
( ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( one_one @ A ) )
= ( zero_neq_one_of_bool @ A @ ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% take_bit_of_1
thf(fact_1972_even__take__bit__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) )
= ( ( N2
= ( zero_zero @ nat ) )
| ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) ) ) ).
% even_take_bit_eq
thf(fact_1973_div__Suc__eq__div__add3,axiom,
! [M: nat,N2: nat] :
( ( divide_divide @ nat @ M @ ( suc @ ( suc @ ( suc @ N2 ) ) ) )
= ( divide_divide @ nat @ M @ ( plus_plus @ nat @ ( numeral_numeral @ nat @ ( bit1 @ one2 ) ) @ N2 ) ) ) ).
% div_Suc_eq_div_add3
thf(fact_1974_Suc__div__eq__add3__div__numeral,axiom,
! [M: nat,V2: num] :
( ( divide_divide @ nat @ ( suc @ ( suc @ ( suc @ M ) ) ) @ ( numeral_numeral @ nat @ V2 ) )
= ( divide_divide @ nat @ ( plus_plus @ nat @ ( numeral_numeral @ nat @ ( bit1 @ one2 ) ) @ M ) @ ( numeral_numeral @ nat @ V2 ) ) ) ).
% Suc_div_eq_add3_div_numeral
thf(fact_1975_mod__Suc__eq__mod__add3,axiom,
! [M: nat,N2: nat] :
( ( modulo_modulo @ nat @ M @ ( suc @ ( suc @ ( suc @ N2 ) ) ) )
= ( modulo_modulo @ nat @ M @ ( plus_plus @ nat @ ( numeral_numeral @ nat @ ( bit1 @ one2 ) ) @ N2 ) ) ) ).
% mod_Suc_eq_mod_add3
thf(fact_1976_Suc__mod__eq__add3__mod__numeral,axiom,
! [M: nat,V2: num] :
( ( modulo_modulo @ nat @ ( suc @ ( suc @ ( suc @ M ) ) ) @ ( numeral_numeral @ nat @ V2 ) )
= ( modulo_modulo @ nat @ ( plus_plus @ nat @ ( numeral_numeral @ nat @ ( bit1 @ one2 ) ) @ M ) @ ( numeral_numeral @ nat @ V2 ) ) ) ).
% Suc_mod_eq_add3_mod_numeral
thf(fact_1977_divmod__algorithm__code_I4_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [N2: num] :
( ( unique8689654367752047608divmod @ A @ one2 @ ( bit1 @ N2 ) )
= ( product_Pair @ A @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ A @ one2 ) ) ) ) ).
% divmod_algorithm_code(4)
thf(fact_1978_take__bit__Suc__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se2584673776208193580ke_bit @ A @ ( suc @ ( zero_zero @ nat ) ) @ A3 )
= ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% take_bit_Suc_0
thf(fact_1979_divmod__algorithm__code_I5_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [M: num,N2: num] :
( ( unique8689654367752047608divmod @ A @ ( bit0 @ M ) @ ( bit0 @ N2 ) )
= ( product_case_prod @ A @ A @ ( product_prod @ A @ A )
@ ^ [Q5: A,R4: A] : ( product_Pair @ A @ A @ Q5 @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ R4 ) )
@ ( unique8689654367752047608divmod @ A @ M @ N2 ) ) ) ) ).
% divmod_algorithm_code(5)
thf(fact_1980_take__bit__of__exp,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [M: nat,N2: nat] :
( ( bit_se2584673776208193580ke_bit @ A @ M @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( times_times @ A @ ( zero_neq_one_of_bool @ A @ ( ord_less @ nat @ N2 @ M ) ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ).
% take_bit_of_exp
thf(fact_1981_take__bit__of__2,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [N2: nat] :
( ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= ( times_times @ A @ ( zero_neq_one_of_bool @ A @ ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% take_bit_of_2
thf(fact_1982_divmod__algorithm__code_I6_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [M: num,N2: num] :
( ( unique8689654367752047608divmod @ A @ ( bit1 @ M ) @ ( bit0 @ N2 ) )
= ( product_case_prod @ A @ A @ ( product_prod @ A @ A )
@ ^ [Q5: A,R4: A] : ( product_Pair @ A @ A @ Q5 @ ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ R4 ) @ ( one_one @ A ) ) )
@ ( unique8689654367752047608divmod @ A @ M @ N2 ) ) ) ) ).
% divmod_algorithm_code(6)
thf(fact_1983_take__bit__add,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [N2: nat,A3: A,B2: A] :
( ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( plus_plus @ A @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ B2 ) ) )
= ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( plus_plus @ A @ A3 @ B2 ) ) ) ) ).
% take_bit_add
thf(fact_1984_take__bit__tightened,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A,B2: A,M: nat] :
( ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 )
= ( bit_se2584673776208193580ke_bit @ A @ N2 @ B2 ) )
=> ( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( bit_se2584673776208193580ke_bit @ A @ M @ A3 )
= ( bit_se2584673776208193580ke_bit @ A @ M @ B2 ) ) ) ) ) ).
% take_bit_tightened
thf(fact_1985_take__bit__tightened__less__eq__nat,axiom,
! [M: nat,N2: nat,Q2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ord_less_eq @ nat @ ( bit_se2584673776208193580ke_bit @ nat @ M @ Q2 ) @ ( bit_se2584673776208193580ke_bit @ nat @ N2 @ Q2 ) ) ) ).
% take_bit_tightened_less_eq_nat
thf(fact_1986_take__bit__nat__less__eq__self,axiom,
! [N2: nat,M: nat] : ( ord_less_eq @ nat @ ( bit_se2584673776208193580ke_bit @ nat @ N2 @ M ) @ M ) ).
% take_bit_nat_less_eq_self
thf(fact_1987_split__cong,axiom,
! [C: $tType,B: $tType,A: $tType,Q2: product_prod @ A @ B,F2: A > B > C,G: A > B > C,P4: product_prod @ A @ B] :
( ! [X5: A,Y4: B] :
( ( ( product_Pair @ A @ B @ X5 @ Y4 )
= Q2 )
=> ( ( F2 @ X5 @ Y4 )
= ( G @ X5 @ Y4 ) ) )
=> ( ( P4 = Q2 )
=> ( ( product_case_prod @ A @ B @ C @ F2 @ P4 )
= ( product_case_prod @ A @ B @ C @ G @ Q2 ) ) ) ) ).
% split_cong
thf(fact_1988_old_Oprod_Ocase,axiom,
! [A: $tType,C: $tType,B: $tType,F2: A > B > C,X1: A,X22: B] :
( ( product_case_prod @ A @ B @ C @ F2 @ ( product_Pair @ A @ B @ X1 @ X22 ) )
= ( F2 @ X1 @ X22 ) ) ).
% old.prod.case
thf(fact_1989_case__prodE2,axiom,
! [B: $tType,A: $tType,C: $tType,Q: A > $o,P2: B > C > A,Z: product_prod @ B @ C] :
( ( Q @ ( product_case_prod @ B @ C @ A @ P2 @ Z ) )
=> ~ ! [X5: B,Y4: C] :
( ( Z
= ( product_Pair @ B @ C @ X5 @ Y4 ) )
=> ~ ( Q @ ( P2 @ X5 @ Y4 ) ) ) ) ).
% case_prodE2
thf(fact_1990_case__prod__eta,axiom,
! [C: $tType,B: $tType,A: $tType,F2: ( product_prod @ A @ B ) > C] :
( ( product_case_prod @ A @ B @ C
@ ^ [X2: A,Y2: B] : ( F2 @ ( product_Pair @ A @ B @ X2 @ Y2 ) ) )
= F2 ) ).
% case_prod_eta
thf(fact_1991_cond__case__prod__eta,axiom,
! [C: $tType,B: $tType,A: $tType,F2: A > B > C,G: ( product_prod @ A @ B ) > C] :
( ! [X5: A,Y4: B] :
( ( F2 @ X5 @ Y4 )
= ( G @ ( product_Pair @ A @ B @ X5 @ Y4 ) ) )
=> ( ( product_case_prod @ A @ B @ C @ F2 )
= G ) ) ).
% cond_case_prod_eta
thf(fact_1992_take__bit__tightened__less__eq__int,axiom,
! [M: nat,N2: nat,K: int] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ord_less_eq @ int @ ( bit_se2584673776208193580ke_bit @ int @ M @ K ) @ ( bit_se2584673776208193580ke_bit @ int @ N2 @ K ) ) ) ).
% take_bit_tightened_less_eq_int
thf(fact_1993_signed__take__bit__eq__iff__take__bit__eq,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [N2: nat,A3: A,B2: A] :
( ( ( bit_ri4674362597316999326ke_bit @ A @ N2 @ A3 )
= ( bit_ri4674362597316999326ke_bit @ A @ N2 @ B2 ) )
= ( ( bit_se2584673776208193580ke_bit @ A @ ( suc @ N2 ) @ A3 )
= ( bit_se2584673776208193580ke_bit @ A @ ( suc @ N2 ) @ B2 ) ) ) ) ).
% signed_take_bit_eq_iff_take_bit_eq
thf(fact_1994_signed__take__bit__take__bit,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [M: nat,N2: nat,A3: A] :
( ( bit_ri4674362597316999326ke_bit @ A @ M @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) )
= ( if @ ( A > A ) @ ( ord_less_eq @ nat @ N2 @ M ) @ ( bit_se2584673776208193580ke_bit @ A @ N2 ) @ ( bit_ri4674362597316999326ke_bit @ A @ M ) @ A3 ) ) ) ).
% signed_take_bit_take_bit
thf(fact_1995_take__bit__unset__bit__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,M: nat,A3: A] :
( ( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( bit_se2638667681897837118et_bit @ A @ M @ A3 ) )
= ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) ) )
& ( ~ ( ord_less_eq @ nat @ N2 @ M )
=> ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( bit_se2638667681897837118et_bit @ A @ M @ A3 ) )
= ( bit_se2638667681897837118et_bit @ A @ M @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) ) ) ) ) ) ).
% take_bit_unset_bit_eq
thf(fact_1996_take__bit__set__bit__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,M: nat,A3: A] :
( ( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( bit_se5668285175392031749et_bit @ A @ M @ A3 ) )
= ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) ) )
& ( ~ ( ord_less_eq @ nat @ N2 @ M )
=> ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( bit_se5668285175392031749et_bit @ A @ M @ A3 ) )
= ( bit_se5668285175392031749et_bit @ A @ M @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) ) ) ) ) ) ).
% take_bit_set_bit_eq
thf(fact_1997_take__bit__flip__bit__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,M: nat,A3: A] :
( ( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( bit_se8732182000553998342ip_bit @ A @ M @ A3 ) )
= ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) ) )
& ( ~ ( ord_less_eq @ nat @ N2 @ M )
=> ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( bit_se8732182000553998342ip_bit @ A @ M @ A3 ) )
= ( bit_se8732182000553998342ip_bit @ A @ M @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) ) ) ) ) ) ).
% take_bit_flip_bit_eq
thf(fact_1998_take__bit__signed__take__bit,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [M: nat,N2: nat,A3: A] :
( ( ord_less_eq @ nat @ M @ ( suc @ N2 ) )
=> ( ( bit_se2584673776208193580ke_bit @ A @ M @ ( bit_ri4674362597316999326ke_bit @ A @ N2 @ A3 ) )
= ( bit_se2584673776208193580ke_bit @ A @ M @ A3 ) ) ) ) ).
% take_bit_signed_take_bit
thf(fact_1999_numeral__Bit1,axiom,
! [A: $tType] :
( ( numeral @ A )
=> ! [N2: num] :
( ( numeral_numeral @ A @ ( bit1 @ N2 ) )
= ( plus_plus @ A @ ( plus_plus @ A @ ( numeral_numeral @ A @ N2 ) @ ( numeral_numeral @ A @ N2 ) ) @ ( one_one @ A ) ) ) ) ).
% numeral_Bit1
thf(fact_2000_eval__nat__numeral_I3_J,axiom,
! [N2: num] :
( ( numeral_numeral @ nat @ ( bit1 @ N2 ) )
= ( suc @ ( numeral_numeral @ nat @ ( bit0 @ N2 ) ) ) ) ).
% eval_nat_numeral(3)
thf(fact_2001_take__bit__Suc__bit1,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [N2: nat,K: num] :
( ( bit_se2584673776208193580ke_bit @ A @ ( suc @ N2 ) @ ( numeral_numeral @ A @ ( bit1 @ K ) ) )
= ( plus_plus @ A @ ( times_times @ A @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( numeral_numeral @ A @ K ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( one_one @ A ) ) ) ) ).
% take_bit_Suc_bit1
thf(fact_2002_numeral__code_I3_J,axiom,
! [A: $tType] :
( ( numeral @ A )
=> ! [N2: num] :
( ( numeral_numeral @ A @ ( bit1 @ N2 ) )
= ( plus_plus @ A @ ( plus_plus @ A @ ( numeral_numeral @ A @ N2 ) @ ( numeral_numeral @ A @ N2 ) ) @ ( one_one @ A ) ) ) ) ).
% numeral_code(3)
thf(fact_2003_set__encode__inf,axiom,
! [A4: set @ nat] :
( ~ ( finite_finite @ nat @ A4 )
=> ( ( nat_set_encode @ A4 )
= ( zero_zero @ nat ) ) ) ).
% set_encode_inf
thf(fact_2004_cong__exp__iff__simps_I3_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [N2: num,Q2: num] :
( ( modulo_modulo @ A @ ( numeral_numeral @ A @ ( bit1 @ N2 ) ) @ ( numeral_numeral @ A @ ( bit0 @ Q2 ) ) )
!= ( zero_zero @ A ) ) ) ).
% cong_exp_iff_simps(3)
thf(fact_2005_numeral__3__eq__3,axiom,
( ( numeral_numeral @ nat @ ( bit1 @ one2 ) )
= ( suc @ ( suc @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ).
% numeral_3_eq_3
thf(fact_2006_Suc3__eq__add__3,axiom,
! [N2: nat] :
( ( suc @ ( suc @ ( suc @ N2 ) ) )
= ( plus_plus @ nat @ ( numeral_numeral @ nat @ ( bit1 @ one2 ) ) @ N2 ) ) ).
% Suc3_eq_add_3
thf(fact_2007_take__bit__Suc__bit0,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [N2: nat,K: num] :
( ( bit_se2584673776208193580ke_bit @ A @ ( suc @ N2 ) @ ( numeral_numeral @ A @ ( bit0 @ K ) ) )
= ( times_times @ A @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( numeral_numeral @ A @ K ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% take_bit_Suc_bit0
thf(fact_2008_take__bit__nat__eq__self,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) )
=> ( ( bit_se2584673776208193580ke_bit @ nat @ N2 @ M )
= M ) ) ).
% take_bit_nat_eq_self
thf(fact_2009_take__bit__nat__less__exp,axiom,
! [N2: nat,M: nat] : ( ord_less @ nat @ ( bit_se2584673776208193580ke_bit @ nat @ N2 @ M ) @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ).
% take_bit_nat_less_exp
thf(fact_2010_take__bit__nat__eq__self__iff,axiom,
! [N2: nat,M: nat] :
( ( ( bit_se2584673776208193580ke_bit @ nat @ N2 @ M )
= M )
= ( ord_less @ nat @ M @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) ).
% take_bit_nat_eq_self_iff
thf(fact_2011_num_Osize_I6_J,axiom,
! [X32: num] :
( ( size_size @ num @ ( bit1 @ X32 ) )
= ( plus_plus @ nat @ ( size_size @ num @ X32 ) @ ( suc @ ( zero_zero @ nat ) ) ) ) ).
% num.size(6)
thf(fact_2012_num_Osize__gen_I3_J,axiom,
! [X32: num] :
( ( size_num @ ( bit1 @ X32 ) )
= ( plus_plus @ nat @ ( size_num @ X32 ) @ ( suc @ ( zero_zero @ nat ) ) ) ) ).
% num.size_gen(3)
thf(fact_2013_take__bit__Suc__minus__bit0,axiom,
! [N2: nat,K: num] :
( ( bit_se2584673776208193580ke_bit @ int @ ( suc @ N2 ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ ( bit0 @ K ) ) ) )
= ( times_times @ int @ ( bit_se2584673776208193580ke_bit @ int @ N2 @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ K ) ) ) @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) ) ).
% take_bit_Suc_minus_bit0
thf(fact_2014_cong__exp__iff__simps_I7_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [Q2: num,N2: num] :
( ( ( modulo_modulo @ A @ ( numeral_numeral @ A @ one2 ) @ ( numeral_numeral @ A @ ( bit0 @ Q2 ) ) )
= ( modulo_modulo @ A @ ( numeral_numeral @ A @ ( bit1 @ N2 ) ) @ ( numeral_numeral @ A @ ( bit0 @ Q2 ) ) ) )
= ( ( modulo_modulo @ A @ ( numeral_numeral @ A @ N2 ) @ ( numeral_numeral @ A @ Q2 ) )
= ( zero_zero @ A ) ) ) ) ).
% cong_exp_iff_simps(7)
thf(fact_2015_cong__exp__iff__simps_I11_J,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ! [M: num,Q2: num] :
( ( ( modulo_modulo @ A @ ( numeral_numeral @ A @ ( bit1 @ M ) ) @ ( numeral_numeral @ A @ ( bit0 @ Q2 ) ) )
= ( modulo_modulo @ A @ ( numeral_numeral @ A @ one2 ) @ ( numeral_numeral @ A @ ( bit0 @ Q2 ) ) ) )
= ( ( modulo_modulo @ A @ ( numeral_numeral @ A @ M ) @ ( numeral_numeral @ A @ Q2 ) )
= ( zero_zero @ A ) ) ) ) ).
% cong_exp_iff_simps(11)
thf(fact_2016_Suc__div__eq__add3__div,axiom,
! [M: nat,N2: nat] :
( ( divide_divide @ nat @ ( suc @ ( suc @ ( suc @ M ) ) ) @ N2 )
= ( divide_divide @ nat @ ( plus_plus @ nat @ ( numeral_numeral @ nat @ ( bit1 @ one2 ) ) @ M ) @ N2 ) ) ).
% Suc_div_eq_add3_div
thf(fact_2017_Suc__mod__eq__add3__mod,axiom,
! [M: nat,N2: nat] :
( ( modulo_modulo @ nat @ ( suc @ ( suc @ ( suc @ M ) ) ) @ N2 )
= ( modulo_modulo @ nat @ ( plus_plus @ nat @ ( numeral_numeral @ nat @ ( bit1 @ one2 ) ) @ M ) @ N2 ) ) ).
% Suc_mod_eq_add3_mod
thf(fact_2018_take__bit__eq__0__iff,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 )
= ( zero_zero @ A ) )
= ( dvd_dvd @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) @ A3 ) ) ) ).
% take_bit_eq_0_iff
thf(fact_2019_take__bit__nat__less__self__iff,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( bit_se2584673776208193580ke_bit @ nat @ N2 @ M ) @ M )
= ( ord_less_eq @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ M ) ) ).
% take_bit_nat_less_self_iff
thf(fact_2020_take__bit__Suc__minus__1__eq,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [N2: nat] :
( ( bit_se2584673776208193580ke_bit @ A @ ( suc @ N2 ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( minus_minus @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( suc @ N2 ) ) @ ( one_one @ A ) ) ) ) ).
% take_bit_Suc_minus_1_eq
thf(fact_2021_take__bit__Suc,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( bit_se2584673776208193580ke_bit @ A @ ( suc @ N2 ) @ A3 )
= ( plus_plus @ A @ ( times_times @ A @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% take_bit_Suc
thf(fact_2022_take__bit__int__less__eq,axiom,
! [N2: nat,K: int] :
( ( ord_less_eq @ int @ ( power_power @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ N2 ) @ K )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less_eq @ int @ ( bit_se2584673776208193580ke_bit @ int @ N2 @ K ) @ ( minus_minus @ int @ K @ ( power_power @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ) ).
% take_bit_int_less_eq
thf(fact_2023_signed__take__bit__eq__take__bit__shift,axiom,
( ( bit_ri4674362597316999326ke_bit @ int )
= ( ^ [N: nat,K2: int] : ( minus_minus @ int @ ( bit_se2584673776208193580ke_bit @ int @ ( suc @ N ) @ ( plus_plus @ int @ K2 @ ( power_power @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ N ) ) ) @ ( power_power @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ N ) ) ) ) ).
% signed_take_bit_eq_take_bit_shift
thf(fact_2024_stable__imp__take__bit__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A,N2: nat] :
( ( ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
= A3 )
=> ( ( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 )
= ( zero_zero @ A ) ) )
& ( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 )
= ( minus_minus @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) @ ( one_one @ A ) ) ) ) ) ) ) ).
% stable_imp_take_bit_eq
thf(fact_2025_divmod__step__nat__def,axiom,
( ( unique1321980374590559556d_step @ nat )
= ( ^ [L2: num] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [Q5: nat,R4: nat] : ( if @ ( product_prod @ nat @ nat ) @ ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ L2 ) @ R4 ) @ ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Q5 ) @ ( one_one @ nat ) ) @ ( minus_minus @ nat @ R4 @ ( numeral_numeral @ nat @ L2 ) ) ) @ ( product_Pair @ nat @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Q5 ) @ R4 ) ) ) ) ) ).
% divmod_step_nat_def
thf(fact_2026_odd__mod__4__div__2,axiom,
! [N2: nat] :
( ( ( modulo_modulo @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ ( bit0 @ one2 ) ) ) )
= ( numeral_numeral @ nat @ ( bit1 @ one2 ) ) )
=> ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ).
% odd_mod_4_div_2
thf(fact_2027_mod__exhaust__less__4,axiom,
! [M: nat] :
( ( ( modulo_modulo @ nat @ M @ ( numeral_numeral @ nat @ ( bit0 @ ( bit0 @ one2 ) ) ) )
= ( zero_zero @ nat ) )
| ( ( modulo_modulo @ nat @ M @ ( numeral_numeral @ nat @ ( bit0 @ ( bit0 @ one2 ) ) ) )
= ( one_one @ nat ) )
| ( ( modulo_modulo @ nat @ M @ ( numeral_numeral @ nat @ ( bit0 @ ( bit0 @ one2 ) ) ) )
= ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
| ( ( modulo_modulo @ nat @ M @ ( numeral_numeral @ nat @ ( bit0 @ ( bit0 @ one2 ) ) ) )
= ( numeral_numeral @ nat @ ( bit1 @ one2 ) ) ) ) ).
% mod_exhaust_less_4
thf(fact_2028_take__bit__Suc__minus__bit1,axiom,
! [N2: nat,K: num] :
( ( bit_se2584673776208193580ke_bit @ int @ ( suc @ N2 ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ ( bit1 @ K ) ) ) )
= ( plus_plus @ int @ ( times_times @ int @ ( bit_se2584673776208193580ke_bit @ int @ N2 @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ ( inc @ K ) ) ) ) @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) @ ( one_one @ int ) ) ) ).
% take_bit_Suc_minus_bit1
thf(fact_2029_divmod__nat__if,axiom,
( divmod_nat
= ( ^ [M2: nat,N: nat] :
( if @ ( product_prod @ nat @ nat )
@ ( ( N
= ( zero_zero @ nat ) )
| ( ord_less @ nat @ M2 @ N ) )
@ ( product_Pair @ nat @ nat @ ( zero_zero @ nat ) @ M2 )
@ ( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [Q5: nat] : ( product_Pair @ nat @ nat @ ( suc @ Q5 ) )
@ ( divmod_nat @ ( minus_minus @ nat @ M2 @ N ) @ N ) ) ) ) ) ).
% divmod_nat_if
thf(fact_2030_of__int__code__if,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( ( ring_1_of_int @ A )
= ( ^ [K2: int] :
( if @ A
@ ( K2
= ( zero_zero @ int ) )
@ ( zero_zero @ A )
@ ( if @ A @ ( ord_less @ int @ K2 @ ( zero_zero @ int ) ) @ ( uminus_uminus @ A @ ( ring_1_of_int @ A @ ( uminus_uminus @ int @ K2 ) ) )
@ ( if @ A
@ ( ( modulo_modulo @ int @ K2 @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) )
= ( zero_zero @ int ) )
@ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( ring_1_of_int @ A @ ( divide_divide @ int @ K2 @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) ) )
@ ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( ring_1_of_int @ A @ ( divide_divide @ int @ K2 @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) ) ) @ ( one_one @ A ) ) ) ) ) ) ) ) ).
% of_int_code_if
thf(fact_2031_take__bit__numeral__bit1,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [L: num,K: num] :
( ( bit_se2584673776208193580ke_bit @ A @ ( numeral_numeral @ nat @ L ) @ ( numeral_numeral @ A @ ( bit1 @ K ) ) )
= ( plus_plus @ A @ ( times_times @ A @ ( bit_se2584673776208193580ke_bit @ A @ ( pred_numeral @ L ) @ ( numeral_numeral @ A @ K ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( one_one @ A ) ) ) ) ).
% take_bit_numeral_bit1
thf(fact_2032_concat__bit__Suc,axiom,
! [N2: nat,K: int,L: int] :
( ( bit_concat_bit @ ( suc @ N2 ) @ K @ L )
= ( plus_plus @ int @ ( modulo_modulo @ int @ K @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) @ ( times_times @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ ( bit_concat_bit @ N2 @ ( divide_divide @ int @ K @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) @ L ) ) ) ) ).
% concat_bit_Suc
thf(fact_2033_of__int__less__neg__numeral__power__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: int,X: num,N2: nat] :
( ( ord_less @ A @ ( ring_1_of_int @ A @ A3 ) @ ( power_power @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ X ) ) @ N2 ) )
= ( ord_less @ int @ A3 @ ( power_power @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ X ) ) @ N2 ) ) ) ) ).
% of_int_less_neg_numeral_power_cancel_iff
thf(fact_2034_of__int__eq__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [W2: int,Z: int] :
( ( ( ring_1_of_int @ A @ W2 )
= ( ring_1_of_int @ A @ Z ) )
= ( W2 = Z ) ) ) ).
% of_int_eq_iff
thf(fact_2035_case__prodI2,axiom,
! [B: $tType,A: $tType,P4: product_prod @ A @ B,C2: A > B > $o] :
( ! [A7: A,B5: B] :
( ( P4
= ( product_Pair @ A @ B @ A7 @ B5 ) )
=> ( C2 @ A7 @ B5 ) )
=> ( product_case_prod @ A @ B @ $o @ C2 @ P4 ) ) ).
% case_prodI2
thf(fact_2036_case__prodI,axiom,
! [A: $tType,B: $tType,F2: A > B > $o,A3: A,B2: B] :
( ( F2 @ A3 @ B2 )
=> ( product_case_prod @ A @ B @ $o @ F2 @ ( product_Pair @ A @ B @ A3 @ B2 ) ) ) ).
% case_prodI
thf(fact_2037_mem__case__prodI2,axiom,
! [C: $tType,B: $tType,A: $tType,P4: product_prod @ A @ B,Z: C,C2: A > B > ( set @ C )] :
( ! [A7: A,B5: B] :
( ( P4
= ( product_Pair @ A @ B @ A7 @ B5 ) )
=> ( member2 @ C @ Z @ ( C2 @ A7 @ B5 ) ) )
=> ( member2 @ C @ Z @ ( product_case_prod @ A @ B @ ( set @ C ) @ C2 @ P4 ) ) ) ).
% mem_case_prodI2
thf(fact_2038_mem__case__prodI,axiom,
! [A: $tType,B: $tType,C: $tType,Z: A,C2: B > C > ( set @ A ),A3: B,B2: C] :
( ( member2 @ A @ Z @ ( C2 @ A3 @ B2 ) )
=> ( member2 @ A @ Z @ ( product_case_prod @ B @ C @ ( set @ A ) @ C2 @ ( product_Pair @ B @ C @ A3 @ B2 ) ) ) ) ).
% mem_case_prodI
thf(fact_2039_case__prodI2_H,axiom,
! [A: $tType,B: $tType,C: $tType,P4: product_prod @ A @ B,C2: A > B > C > $o,X: C] :
( ! [A7: A,B5: B] :
( ( ( product_Pair @ A @ B @ A7 @ B5 )
= P4 )
=> ( C2 @ A7 @ B5 @ X ) )
=> ( product_case_prod @ A @ B @ ( C > $o ) @ C2 @ P4 @ X ) ) ).
% case_prodI2'
thf(fact_2040_of__int__of__bool,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [P2: $o] :
( ( ring_1_of_int @ A @ ( zero_neq_one_of_bool @ int @ P2 ) )
= ( zero_neq_one_of_bool @ A @ P2 ) ) ) ).
% of_int_of_bool
thf(fact_2041_concat__bit__0,axiom,
! [K: int,L: int] :
( ( bit_concat_bit @ ( zero_zero @ nat ) @ K @ L )
= L ) ).
% concat_bit_0
thf(fact_2042_of__int__0,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( ( ring_1_of_int @ A @ ( zero_zero @ int ) )
= ( zero_zero @ A ) ) ) ).
% of_int_0
thf(fact_2043_of__int__0__eq__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [Z: int] :
( ( ( zero_zero @ A )
= ( ring_1_of_int @ A @ Z ) )
= ( Z
= ( zero_zero @ int ) ) ) ) ).
% of_int_0_eq_iff
thf(fact_2044_of__int__eq__0__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [Z: int] :
( ( ( ring_1_of_int @ A @ Z )
= ( zero_zero @ A ) )
= ( Z
= ( zero_zero @ int ) ) ) ) ).
% of_int_eq_0_iff
thf(fact_2045_of__int__le__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [W2: int,Z: int] :
( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ W2 ) @ ( ring_1_of_int @ A @ Z ) )
= ( ord_less_eq @ int @ W2 @ Z ) ) ) ).
% of_int_le_iff
thf(fact_2046_of__int__eq__numeral__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [Z: int,N2: num] :
( ( ( ring_1_of_int @ A @ Z )
= ( numeral_numeral @ A @ N2 ) )
= ( Z
= ( numeral_numeral @ int @ N2 ) ) ) ) ).
% of_int_eq_numeral_iff
thf(fact_2047_of__int__numeral,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [K: num] :
( ( ring_1_of_int @ A @ ( numeral_numeral @ int @ K ) )
= ( numeral_numeral @ A @ K ) ) ) ).
% of_int_numeral
thf(fact_2048_of__int__less__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [W2: int,Z: int] :
( ( ord_less @ A @ ( ring_1_of_int @ A @ W2 ) @ ( ring_1_of_int @ A @ Z ) )
= ( ord_less @ int @ W2 @ Z ) ) ) ).
% of_int_less_iff
thf(fact_2049_of__int__eq__1__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [Z: int] :
( ( ( ring_1_of_int @ A @ Z )
= ( one_one @ A ) )
= ( Z
= ( one_one @ int ) ) ) ) ).
% of_int_eq_1_iff
thf(fact_2050_of__int__1,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( ( ring_1_of_int @ A @ ( one_one @ int ) )
= ( one_one @ A ) ) ) ).
% of_int_1
thf(fact_2051_of__int__mult,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [W2: int,Z: int] :
( ( ring_1_of_int @ A @ ( times_times @ int @ W2 @ Z ) )
= ( times_times @ A @ ( ring_1_of_int @ A @ W2 ) @ ( ring_1_of_int @ A @ Z ) ) ) ) ).
% of_int_mult
thf(fact_2052_of__int__add,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [W2: int,Z: int] :
( ( ring_1_of_int @ A @ ( plus_plus @ int @ W2 @ Z ) )
= ( plus_plus @ A @ ( ring_1_of_int @ A @ W2 ) @ ( ring_1_of_int @ A @ Z ) ) ) ) ).
% of_int_add
thf(fact_2053_of__int__minus,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [Z: int] :
( ( ring_1_of_int @ A @ ( uminus_uminus @ int @ Z ) )
= ( uminus_uminus @ A @ ( ring_1_of_int @ A @ Z ) ) ) ) ).
% of_int_minus
thf(fact_2054_of__int__diff,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [W2: int,Z: int] :
( ( ring_1_of_int @ A @ ( minus_minus @ int @ W2 @ Z ) )
= ( minus_minus @ A @ ( ring_1_of_int @ A @ W2 ) @ ( ring_1_of_int @ A @ Z ) ) ) ) ).
% of_int_diff
thf(fact_2055_pred__numeral__simps_I1_J,axiom,
( ( pred_numeral @ one2 )
= ( zero_zero @ nat ) ) ).
% pred_numeral_simps(1)
thf(fact_2056_eq__numeral__Suc,axiom,
! [K: num,N2: nat] :
( ( ( numeral_numeral @ nat @ K )
= ( suc @ N2 ) )
= ( ( pred_numeral @ K )
= N2 ) ) ).
% eq_numeral_Suc
thf(fact_2057_Suc__eq__numeral,axiom,
! [N2: nat,K: num] :
( ( ( suc @ N2 )
= ( numeral_numeral @ nat @ K ) )
= ( N2
= ( pred_numeral @ K ) ) ) ).
% Suc_eq_numeral
thf(fact_2058_of__int__power__eq__of__int__cancel__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [X: int,B2: int,W2: nat] :
( ( ( ring_1_of_int @ A @ X )
= ( power_power @ A @ ( ring_1_of_int @ A @ B2 ) @ W2 ) )
= ( X
= ( power_power @ int @ B2 @ W2 ) ) ) ) ).
% of_int_power_eq_of_int_cancel_iff
thf(fact_2059_of__int__eq__of__int__power__cancel__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [B2: int,W2: nat,X: int] :
( ( ( power_power @ A @ ( ring_1_of_int @ A @ B2 ) @ W2 )
= ( ring_1_of_int @ A @ X ) )
= ( ( power_power @ int @ B2 @ W2 )
= X ) ) ) ).
% of_int_eq_of_int_power_cancel_iff
thf(fact_2060_of__int__power,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [Z: int,N2: nat] :
( ( ring_1_of_int @ A @ ( power_power @ int @ Z @ N2 ) )
= ( power_power @ A @ ( ring_1_of_int @ A @ Z ) @ N2 ) ) ) ).
% of_int_power
thf(fact_2061_less__Suc__numeral,axiom,
! [N2: nat,K: num] :
( ( ord_less @ nat @ ( suc @ N2 ) @ ( numeral_numeral @ nat @ K ) )
= ( ord_less @ nat @ N2 @ ( pred_numeral @ K ) ) ) ).
% less_Suc_numeral
thf(fact_2062_less__numeral__Suc,axiom,
! [K: num,N2: nat] :
( ( ord_less @ nat @ ( numeral_numeral @ nat @ K ) @ ( suc @ N2 ) )
= ( ord_less @ nat @ ( pred_numeral @ K ) @ N2 ) ) ).
% less_numeral_Suc
thf(fact_2063_le__numeral__Suc,axiom,
! [K: num,N2: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ K ) @ ( suc @ N2 ) )
= ( ord_less_eq @ nat @ ( pred_numeral @ K ) @ N2 ) ) ).
% le_numeral_Suc
thf(fact_2064_le__Suc__numeral,axiom,
! [N2: nat,K: num] :
( ( ord_less_eq @ nat @ ( suc @ N2 ) @ ( numeral_numeral @ nat @ K ) )
= ( ord_less_eq @ nat @ N2 @ ( pred_numeral @ K ) ) ) ).
% le_Suc_numeral
thf(fact_2065_diff__Suc__numeral,axiom,
! [N2: nat,K: num] :
( ( minus_minus @ nat @ ( suc @ N2 ) @ ( numeral_numeral @ nat @ K ) )
= ( minus_minus @ nat @ N2 @ ( pred_numeral @ K ) ) ) ).
% diff_Suc_numeral
thf(fact_2066_diff__numeral__Suc,axiom,
! [K: num,N2: nat] :
( ( minus_minus @ nat @ ( numeral_numeral @ nat @ K ) @ ( suc @ N2 ) )
= ( minus_minus @ nat @ ( pred_numeral @ K ) @ N2 ) ) ).
% diff_numeral_Suc
thf(fact_2067_max__Suc__numeral,axiom,
! [N2: nat,K: num] :
( ( ord_max @ nat @ ( suc @ N2 ) @ ( numeral_numeral @ nat @ K ) )
= ( suc @ ( ord_max @ nat @ N2 @ ( pred_numeral @ K ) ) ) ) ).
% max_Suc_numeral
thf(fact_2068_max__numeral__Suc,axiom,
! [K: num,N2: nat] :
( ( ord_max @ nat @ ( numeral_numeral @ nat @ K ) @ ( suc @ N2 ) )
= ( suc @ ( ord_max @ nat @ ( pred_numeral @ K ) @ N2 ) ) ) ).
% max_numeral_Suc
thf(fact_2069_of__int__0__le__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( ring_1_of_int @ A @ Z ) )
= ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z ) ) ) ).
% of_int_0_le_iff
thf(fact_2070_of__int__le__0__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int] :
( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ Z ) @ ( zero_zero @ A ) )
= ( ord_less_eq @ int @ Z @ ( zero_zero @ int ) ) ) ) ).
% of_int_le_0_iff
thf(fact_2071_of__int__0__less__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( ring_1_of_int @ A @ Z ) )
= ( ord_less @ int @ ( zero_zero @ int ) @ Z ) ) ) ).
% of_int_0_less_iff
thf(fact_2072_of__int__less__0__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int] :
( ( ord_less @ A @ ( ring_1_of_int @ A @ Z ) @ ( zero_zero @ A ) )
= ( ord_less @ int @ Z @ ( zero_zero @ int ) ) ) ) ).
% of_int_less_0_iff
thf(fact_2073_of__int__le__numeral__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int,N2: num] :
( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ Z ) @ ( numeral_numeral @ A @ N2 ) )
= ( ord_less_eq @ int @ Z @ ( numeral_numeral @ int @ N2 ) ) ) ) ).
% of_int_le_numeral_iff
thf(fact_2074_of__int__numeral__le__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: num,Z: int] :
( ( ord_less_eq @ A @ ( numeral_numeral @ A @ N2 ) @ ( ring_1_of_int @ A @ Z ) )
= ( ord_less_eq @ int @ ( numeral_numeral @ int @ N2 ) @ Z ) ) ) ).
% of_int_numeral_le_iff
thf(fact_2075_of__int__less__numeral__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int,N2: num] :
( ( ord_less @ A @ ( ring_1_of_int @ A @ Z ) @ ( numeral_numeral @ A @ N2 ) )
= ( ord_less @ int @ Z @ ( numeral_numeral @ int @ N2 ) ) ) ) ).
% of_int_less_numeral_iff
thf(fact_2076_of__int__numeral__less__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: num,Z: int] :
( ( ord_less @ A @ ( numeral_numeral @ A @ N2 ) @ ( ring_1_of_int @ A @ Z ) )
= ( ord_less @ int @ ( numeral_numeral @ int @ N2 ) @ Z ) ) ) ).
% of_int_numeral_less_iff
thf(fact_2077_of__int__le__1__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int] :
( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ Z ) @ ( one_one @ A ) )
= ( ord_less_eq @ int @ Z @ ( one_one @ int ) ) ) ) ).
% of_int_le_1_iff
thf(fact_2078_of__int__1__le__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int] :
( ( ord_less_eq @ A @ ( one_one @ A ) @ ( ring_1_of_int @ A @ Z ) )
= ( ord_less_eq @ int @ ( one_one @ int ) @ Z ) ) ) ).
% of_int_1_le_iff
thf(fact_2079_of__int__less__1__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int] :
( ( ord_less @ A @ ( ring_1_of_int @ A @ Z ) @ ( one_one @ A ) )
= ( ord_less @ int @ Z @ ( one_one @ int ) ) ) ) ).
% of_int_less_1_iff
thf(fact_2080_of__int__1__less__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int] :
( ( ord_less @ A @ ( one_one @ A ) @ ( ring_1_of_int @ A @ Z ) )
= ( ord_less @ int @ ( one_one @ int ) @ Z ) ) ) ).
% of_int_1_less_iff
thf(fact_2081_of__int__le__of__int__power__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [B2: int,W2: nat,X: int] :
( ( ord_less_eq @ A @ ( power_power @ A @ ( ring_1_of_int @ A @ B2 ) @ W2 ) @ ( ring_1_of_int @ A @ X ) )
= ( ord_less_eq @ int @ ( power_power @ int @ B2 @ W2 ) @ X ) ) ) ).
% of_int_le_of_int_power_cancel_iff
thf(fact_2082_of__int__power__le__of__int__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: int,B2: int,W2: nat] :
( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ X ) @ ( power_power @ A @ ( ring_1_of_int @ A @ B2 ) @ W2 ) )
= ( ord_less_eq @ int @ X @ ( power_power @ int @ B2 @ W2 ) ) ) ) ).
% of_int_power_le_of_int_cancel_iff
thf(fact_2083_of__int__eq__numeral__power__cancel__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [Y: int,X: num,N2: nat] :
( ( ( ring_1_of_int @ A @ Y )
= ( power_power @ A @ ( numeral_numeral @ A @ X ) @ N2 ) )
= ( Y
= ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 ) ) ) ) ).
% of_int_eq_numeral_power_cancel_iff
thf(fact_2084_numeral__power__eq__of__int__cancel__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [X: num,N2: nat,Y: int] :
( ( ( power_power @ A @ ( numeral_numeral @ A @ X ) @ N2 )
= ( ring_1_of_int @ A @ Y ) )
= ( ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 )
= Y ) ) ) ).
% numeral_power_eq_of_int_cancel_iff
thf(fact_2085_add__neg__numeral__special_I5_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [N2: num] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ ( inc @ N2 ) ) ) ) ) ).
% add_neg_numeral_special(5)
thf(fact_2086_add__neg__numeral__special_I6_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [M: num] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ ( inc @ M ) ) ) ) ) ).
% add_neg_numeral_special(6)
thf(fact_2087_of__int__less__of__int__power__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [B2: int,W2: nat,X: int] :
( ( ord_less @ A @ ( power_power @ A @ ( ring_1_of_int @ A @ B2 ) @ W2 ) @ ( ring_1_of_int @ A @ X ) )
= ( ord_less @ int @ ( power_power @ int @ B2 @ W2 ) @ X ) ) ) ).
% of_int_less_of_int_power_cancel_iff
thf(fact_2088_of__int__power__less__of__int__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: int,B2: int,W2: nat] :
( ( ord_less @ A @ ( ring_1_of_int @ A @ X ) @ ( power_power @ A @ ( ring_1_of_int @ A @ B2 ) @ W2 ) )
= ( ord_less @ int @ X @ ( power_power @ int @ B2 @ W2 ) ) ) ) ).
% of_int_power_less_of_int_cancel_iff
thf(fact_2089_numeral__power__le__of__int__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: num,N2: nat,A3: int] :
( ( ord_less_eq @ A @ ( power_power @ A @ ( numeral_numeral @ A @ X ) @ N2 ) @ ( ring_1_of_int @ A @ A3 ) )
= ( ord_less_eq @ int @ ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 ) @ A3 ) ) ) ).
% numeral_power_le_of_int_cancel_iff
thf(fact_2090_of__int__le__numeral__power__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: int,X: num,N2: nat] :
( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ A3 ) @ ( power_power @ A @ ( numeral_numeral @ A @ X ) @ N2 ) )
= ( ord_less_eq @ int @ A3 @ ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 ) ) ) ) ).
% of_int_le_numeral_power_cancel_iff
thf(fact_2091_numeral__power__less__of__int__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: num,N2: nat,A3: int] :
( ( ord_less @ A @ ( power_power @ A @ ( numeral_numeral @ A @ X ) @ N2 ) @ ( ring_1_of_int @ A @ A3 ) )
= ( ord_less @ int @ ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 ) @ A3 ) ) ) ).
% numeral_power_less_of_int_cancel_iff
thf(fact_2092_of__int__less__numeral__power__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: int,X: num,N2: nat] :
( ( ord_less @ A @ ( ring_1_of_int @ A @ A3 ) @ ( power_power @ A @ ( numeral_numeral @ A @ X ) @ N2 ) )
= ( ord_less @ int @ A3 @ ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 ) ) ) ) ).
% of_int_less_numeral_power_cancel_iff
thf(fact_2093_neg__numeral__power__eq__of__int__cancel__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [X: num,N2: nat,Y: int] :
( ( ( power_power @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ X ) ) @ N2 )
= ( ring_1_of_int @ A @ Y ) )
= ( ( power_power @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ X ) ) @ N2 )
= Y ) ) ) ).
% neg_numeral_power_eq_of_int_cancel_iff
thf(fact_2094_of__int__eq__neg__numeral__power__cancel__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [Y: int,X: num,N2: nat] :
( ( ( ring_1_of_int @ A @ Y )
= ( power_power @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ X ) ) @ N2 ) )
= ( Y
= ( power_power @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ X ) ) @ N2 ) ) ) ) ).
% of_int_eq_neg_numeral_power_cancel_iff
thf(fact_2095_neg__numeral__power__le__of__int__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: num,N2: nat,A3: int] :
( ( ord_less_eq @ A @ ( power_power @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ X ) ) @ N2 ) @ ( ring_1_of_int @ A @ A3 ) )
= ( ord_less_eq @ int @ ( power_power @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ X ) ) @ N2 ) @ A3 ) ) ) ).
% neg_numeral_power_le_of_int_cancel_iff
thf(fact_2096_of__int__le__neg__numeral__power__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: int,X: num,N2: nat] :
( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ A3 ) @ ( power_power @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ X ) ) @ N2 ) )
= ( ord_less_eq @ int @ A3 @ ( power_power @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ X ) ) @ N2 ) ) ) ) ).
% of_int_le_neg_numeral_power_cancel_iff
thf(fact_2097_neg__numeral__power__less__of__int__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: num,N2: nat,A3: int] :
( ( ord_less @ A @ ( power_power @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ X ) ) @ N2 ) @ ( ring_1_of_int @ A @ A3 ) )
= ( ord_less @ int @ ( power_power @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ X ) ) @ N2 ) @ A3 ) ) ) ).
% neg_numeral_power_less_of_int_cancel_iff
thf(fact_2098_ex__le__of__int,axiom,
! [A: $tType] :
( ( archim462609752435547400_field @ A )
=> ! [X: A] :
? [Z2: int] : ( ord_less_eq @ A @ X @ ( ring_1_of_int @ A @ Z2 ) ) ) ).
% ex_le_of_int
thf(fact_2099_ex__less__of__int,axiom,
! [A: $tType] :
( ( archim462609752435547400_field @ A )
=> ! [X: A] :
? [Z2: int] : ( ord_less @ A @ X @ ( ring_1_of_int @ A @ Z2 ) ) ) ).
% ex_less_of_int
thf(fact_2100_ex__of__int__less,axiom,
! [A: $tType] :
( ( archim462609752435547400_field @ A )
=> ! [X: A] :
? [Z2: int] : ( ord_less @ A @ ( ring_1_of_int @ A @ Z2 ) @ X ) ) ).
% ex_of_int_less
thf(fact_2101_mult__of__int__commute,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [X: int,Y: A] :
( ( times_times @ A @ ( ring_1_of_int @ A @ X ) @ Y )
= ( times_times @ A @ Y @ ( ring_1_of_int @ A @ X ) ) ) ) ).
% mult_of_int_commute
thf(fact_2102_mem__case__prodE,axiom,
! [B: $tType,A: $tType,C: $tType,Z: A,C2: B > C > ( set @ A ),P4: product_prod @ B @ C] :
( ( member2 @ A @ Z @ ( product_case_prod @ B @ C @ ( set @ A ) @ C2 @ P4 ) )
=> ~ ! [X5: B,Y4: C] :
( ( P4
= ( product_Pair @ B @ C @ X5 @ Y4 ) )
=> ~ ( member2 @ A @ Z @ ( C2 @ X5 @ Y4 ) ) ) ) ).
% mem_case_prodE
thf(fact_2103_of__int__max,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: int,Y: int] :
( ( ring_1_of_int @ A @ ( ord_max @ int @ X @ Y ) )
= ( ord_max @ A @ ( ring_1_of_int @ A @ X ) @ ( ring_1_of_int @ A @ Y ) ) ) ) ).
% of_int_max
thf(fact_2104_case__prodE,axiom,
! [A: $tType,B: $tType,C2: A > B > $o,P4: product_prod @ A @ B] :
( ( product_case_prod @ A @ B @ $o @ C2 @ P4 )
=> ~ ! [X5: A,Y4: B] :
( ( P4
= ( product_Pair @ A @ B @ X5 @ Y4 ) )
=> ~ ( C2 @ X5 @ Y4 ) ) ) ).
% case_prodE
thf(fact_2105_case__prodD,axiom,
! [A: $tType,B: $tType,F2: A > B > $o,A3: A,B2: B] :
( ( product_case_prod @ A @ B @ $o @ F2 @ ( product_Pair @ A @ B @ A3 @ B2 ) )
=> ( F2 @ A3 @ B2 ) ) ).
% case_prodD
thf(fact_2106_case__prodE_H,axiom,
! [B: $tType,A: $tType,C: $tType,C2: A > B > C > $o,P4: product_prod @ A @ B,Z: C] :
( ( product_case_prod @ A @ B @ ( C > $o ) @ C2 @ P4 @ Z )
=> ~ ! [X5: A,Y4: B] :
( ( P4
= ( product_Pair @ A @ B @ X5 @ Y4 ) )
=> ~ ( C2 @ X5 @ Y4 @ Z ) ) ) ).
% case_prodE'
thf(fact_2107_case__prodD_H,axiom,
! [B: $tType,A: $tType,C: $tType,R: A > B > C > $o,A3: A,B2: B,C2: C] :
( ( product_case_prod @ A @ B @ ( C > $o ) @ R @ ( product_Pair @ A @ B @ A3 @ B2 ) @ C2 )
=> ( R @ A3 @ B2 @ C2 ) ) ).
% case_prodD'
thf(fact_2108_concat__bit__assoc,axiom,
! [N2: nat,K: int,M: nat,L: int,R2: int] :
( ( bit_concat_bit @ N2 @ K @ ( bit_concat_bit @ M @ L @ R2 ) )
= ( bit_concat_bit @ ( plus_plus @ nat @ M @ N2 ) @ ( bit_concat_bit @ N2 @ K @ L ) @ R2 ) ) ).
% concat_bit_assoc
thf(fact_2109_numeral__eq__Suc,axiom,
( ( numeral_numeral @ nat )
= ( ^ [K2: num] : ( suc @ ( pred_numeral @ K2 ) ) ) ) ).
% numeral_eq_Suc
thf(fact_2110_of__int__nonneg,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( ring_1_of_int @ A @ Z ) ) ) ) ).
% of_int_nonneg
thf(fact_2111_of__int__pos,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Z: int] :
( ( ord_less @ int @ ( zero_zero @ int ) @ Z )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( ring_1_of_int @ A @ Z ) ) ) ) ).
% of_int_pos
thf(fact_2112_floor__exists,axiom,
! [A: $tType] :
( ( archim462609752435547400_field @ A )
=> ! [X: A] :
? [Z2: int] :
( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ Z2 ) @ X )
& ( ord_less @ A @ X @ ( ring_1_of_int @ A @ ( plus_plus @ int @ Z2 @ ( one_one @ int ) ) ) ) ) ) ).
% floor_exists
thf(fact_2113_floor__exists1,axiom,
! [A: $tType] :
( ( archim462609752435547400_field @ A )
=> ! [X: A] :
? [X5: int] :
( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ X5 ) @ X )
& ( ord_less @ A @ X @ ( ring_1_of_int @ A @ ( plus_plus @ int @ X5 @ ( one_one @ int ) ) ) )
& ! [Y3: int] :
( ( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ Y3 ) @ X )
& ( ord_less @ A @ X @ ( ring_1_of_int @ A @ ( plus_plus @ int @ Y3 @ ( one_one @ int ) ) ) ) )
=> ( Y3 = X5 ) ) ) ) ).
% floor_exists1
thf(fact_2114_numeral__inc,axiom,
! [A: $tType] :
( ( numeral @ A )
=> ! [X: num] :
( ( numeral_numeral @ A @ ( inc @ X ) )
= ( plus_plus @ A @ ( numeral_numeral @ A @ X ) @ ( one_one @ A ) ) ) ) ).
% numeral_inc
thf(fact_2115_of__int__neg__numeral,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [K: num] :
( ( ring_1_of_int @ A @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ K ) ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ K ) ) ) ) ).
% of_int_neg_numeral
thf(fact_2116_divmod__nat__def,axiom,
( divmod_nat
= ( ^ [M2: nat,N: nat] : ( product_Pair @ nat @ nat @ ( divide_divide @ nat @ M2 @ N ) @ ( modulo_modulo @ nat @ M2 @ N ) ) ) ) ).
% divmod_nat_def
thf(fact_2117_listrel1p__def,axiom,
! [A: $tType] :
( ( listrel1p @ A )
= ( ^ [R4: A > A > $o,Xs2: list @ A,Ys3: list @ A] : ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs2 @ Ys3 ) @ ( listrel1 @ A @ ( collect @ ( product_prod @ A @ A ) @ ( product_case_prod @ A @ A @ $o @ R4 ) ) ) ) ) ) ).
% listrel1p_def
thf(fact_2118_round__unique,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Y: int] :
( ( ord_less @ A @ ( minus_minus @ A @ X @ ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) @ ( ring_1_of_int @ A @ Y ) )
=> ( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ Y ) @ ( plus_plus @ A @ X @ ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) )
=> ( ( archimedean_round @ A @ X )
= Y ) ) ) ) ).
% round_unique
thf(fact_2119_of__int__round__gt,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] : ( ord_less @ A @ ( minus_minus @ A @ X @ ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) @ ( ring_1_of_int @ A @ ( archimedean_round @ A @ X ) ) ) ) ).
% of_int_round_gt
thf(fact_2120_of__int__round__ge,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] : ( ord_less_eq @ A @ ( minus_minus @ A @ X @ ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) @ ( ring_1_of_int @ A @ ( archimedean_round @ A @ X ) ) ) ) ).
% of_int_round_ge
thf(fact_2121_of__int__round__le,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] : ( ord_less_eq @ A @ ( ring_1_of_int @ A @ ( archimedean_round @ A @ X ) ) @ ( plus_plus @ A @ X @ ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% of_int_round_le
thf(fact_2122_int__ge__less__than2__def,axiom,
( int_ge_less_than2
= ( ^ [D5: int] :
( collect @ ( product_prod @ int @ int )
@ ( product_case_prod @ int @ int @ $o
@ ^ [Z7: int,Z6: int] :
( ( ord_less_eq @ int @ D5 @ Z6 )
& ( ord_less @ int @ Z7 @ Z6 ) ) ) ) ) ) ).
% int_ge_less_than2_def
thf(fact_2123_int__ge__less__than__def,axiom,
( int_ge_less_than
= ( ^ [D5: int] :
( collect @ ( product_prod @ int @ int )
@ ( product_case_prod @ int @ int @ $o
@ ^ [Z7: int,Z6: int] :
( ( ord_less_eq @ int @ D5 @ Z7 )
& ( ord_less @ int @ Z7 @ Z6 ) ) ) ) ) ) ).
% int_ge_less_than_def
thf(fact_2124_round__0,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ( ( archimedean_round @ A @ ( zero_zero @ A ) )
= ( zero_zero @ int ) ) ) ).
% round_0
thf(fact_2125_round__mono,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ord_less_eq @ int @ ( archimedean_round @ A @ X ) @ ( archimedean_round @ A @ Y ) ) ) ) ).
% round_mono
thf(fact_2126_signed__take__bit__eq__take__bit__minus,axiom,
( ( bit_ri4674362597316999326ke_bit @ int )
= ( ^ [N: nat,K2: int] : ( minus_minus @ int @ ( bit_se2584673776208193580ke_bit @ int @ ( suc @ N ) @ K2 ) @ ( times_times @ int @ ( power_power @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ ( suc @ N ) ) @ ( zero_neq_one_of_bool @ int @ ( bit_se5641148757651400278ts_bit @ int @ K2 @ N ) ) ) ) ) ) ).
% signed_take_bit_eq_take_bit_minus
thf(fact_2127_mask__numeral,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: num] :
( ( bit_se2239418461657761734s_mask @ A @ ( numeral_numeral @ nat @ N2 ) )
= ( plus_plus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se2239418461657761734s_mask @ A @ ( pred_numeral @ N2 ) ) ) ) ) ) ).
% mask_numeral
thf(fact_2128_set__encode__insert,axiom,
! [A4: set @ nat,N2: nat] :
( ( finite_finite @ nat @ A4 )
=> ( ~ ( member2 @ nat @ N2 @ A4 )
=> ( ( nat_set_encode @ ( insert2 @ nat @ N2 @ A4 ) )
= ( plus_plus @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ ( nat_set_encode @ A4 ) ) ) ) ) ).
% set_encode_insert
thf(fact_2129_Sum__Icc__nat,axiom,
! [M: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [X2: nat] : X2
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( divide_divide @ nat @ ( minus_minus @ nat @ ( times_times @ nat @ N2 @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) ) @ ( times_times @ nat @ M @ ( minus_minus @ nat @ M @ ( one_one @ nat ) ) ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ).
% Sum_Icc_nat
thf(fact_2130_neg__numeral__le__ceiling,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [V2: num,X: A] :
( ( ord_less_eq @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ V2 ) ) @ ( archimedean_ceiling @ A @ X ) )
= ( ord_less @ A @ ( minus_minus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) @ ( one_one @ A ) ) @ X ) ) ) ).
% neg_numeral_le_ceiling
thf(fact_2131_ceiling__less__neg__numeral,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,V2: num] :
( ( ord_less @ int @ ( archimedean_ceiling @ A @ X ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ V2 ) ) )
= ( ord_less_eq @ A @ X @ ( minus_minus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) @ ( one_one @ A ) ) ) ) ) ).
% ceiling_less_neg_numeral
thf(fact_2132_arith__series__nat,axiom,
! [A3: nat,D2: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [I5: nat] : ( plus_plus @ nat @ A3 @ ( times_times @ nat @ I5 @ D2 ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) )
= ( divide_divide @ nat @ ( times_times @ nat @ ( suc @ N2 ) @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ A3 ) @ ( times_times @ nat @ N2 @ D2 ) ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ).
% arith_series_nat
thf(fact_2133_mask__nat__positive__iff,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( bit_se2239418461657761734s_mask @ nat @ N2 ) )
= ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ).
% mask_nat_positive_iff
thf(fact_2134_singletonI,axiom,
! [A: $tType,A3: A] : ( member2 @ A @ A3 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ).
% singletonI
thf(fact_2135_insert__subset,axiom,
! [A: $tType,X: A,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ B3 )
= ( ( member2 @ A @ X @ B3 )
& ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ) ).
% insert_subset
thf(fact_2136_bit__0__eq,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ( ( bit_se5641148757651400278ts_bit @ A @ ( zero_zero @ A ) )
= ( bot_bot @ ( nat > $o ) ) ) ) ).
% bit_0_eq
thf(fact_2137_sum_Oneutral__const,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B] :
( ( groups7311177749621191930dd_sum @ B @ A
@ ^ [Uu3: B] : ( zero_zero @ A )
@ A4 )
= ( zero_zero @ A ) ) ) ).
% sum.neutral_const
thf(fact_2138_singleton__conv,axiom,
! [A: $tType,A3: A] :
( ( collect @ A
@ ^ [X2: A] : ( X2 = A3 ) )
= ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ).
% singleton_conv
thf(fact_2139_singleton__conv2,axiom,
! [A: $tType,A3: A] :
( ( collect @ A
@ ( ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ A3 ) )
= ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ).
% singleton_conv2
thf(fact_2140_of__int__sum,axiom,
! [A: $tType,B: $tType] :
( ( ring_1 @ A )
=> ! [F2: B > int,A4: set @ B] :
( ( ring_1_of_int @ A @ ( groups7311177749621191930dd_sum @ B @ int @ F2 @ A4 ) )
= ( groups7311177749621191930dd_sum @ B @ A
@ ^ [X2: B] : ( ring_1_of_int @ A @ ( F2 @ X2 ) )
@ A4 ) ) ) ).
% of_int_sum
thf(fact_2141_sum_Oempty,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: B > A] :
( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( bot_bot @ ( set @ B ) ) )
= ( zero_zero @ A ) ) ) ).
% sum.empty
thf(fact_2142_sum_Oinfinite,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,G: B > A] :
( ~ ( finite_finite @ B @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 )
= ( zero_zero @ A ) ) ) ) ).
% sum.infinite
thf(fact_2143_sum__eq__0__iff,axiom,
! [A: $tType,B: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [F5: set @ B,F2: B > A] :
( ( finite_finite @ B @ F5 )
=> ( ( ( groups7311177749621191930dd_sum @ B @ A @ F2 @ F5 )
= ( zero_zero @ A ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ F5 )
=> ( ( F2 @ X2 )
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% sum_eq_0_iff
thf(fact_2144_singleton__insert__inj__eq_H,axiom,
! [A: $tType,A3: A,A4: set @ A,B2: A] :
( ( ( insert2 @ A @ A3 @ A4 )
= ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) )
= ( ( A3 = B2 )
& ( ord_less_eq @ ( set @ A ) @ A4 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% singleton_insert_inj_eq'
thf(fact_2145_singleton__insert__inj__eq,axiom,
! [A: $tType,B2: A,A3: A,A4: set @ A] :
( ( ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) )
= ( insert2 @ A @ A3 @ A4 ) )
= ( ( A3 = B2 )
& ( ord_less_eq @ ( set @ A ) @ A4 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% singleton_insert_inj_eq
thf(fact_2146_atLeastAtMost__singleton,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A3: A] :
( ( set_or1337092689740270186AtMost @ A @ A3 @ A3 )
= ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% atLeastAtMost_singleton
thf(fact_2147_atLeastAtMost__singleton__iff,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
= ( insert2 @ A @ C2 @ ( bot_bot @ ( set @ A ) ) ) )
= ( ( A3 = B2 )
& ( B2 = C2 ) ) ) ) ).
% atLeastAtMost_singleton_iff
thf(fact_2148_insert__Diff__single,axiom,
! [A: $tType,A3: A,A4: set @ A] :
( ( insert2 @ A @ A3 @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( insert2 @ A @ A3 @ A4 ) ) ).
% insert_Diff_single
thf(fact_2149_ceiling__zero,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ( ( archimedean_ceiling @ A @ ( zero_zero @ A ) )
= ( zero_zero @ int ) ) ) ).
% ceiling_zero
thf(fact_2150_mask__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ( ( bit_se2239418461657761734s_mask @ A @ ( zero_zero @ nat ) )
= ( zero_zero @ A ) ) ) ).
% mask_0
thf(fact_2151_mask__eq__0__iff,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat] :
( ( ( bit_se2239418461657761734s_mask @ A @ N2 )
= ( zero_zero @ A ) )
= ( N2
= ( zero_zero @ nat ) ) ) ) ).
% mask_eq_0_iff
thf(fact_2152_sum_Odelta,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ A )
=> ! [S3: set @ B,A3: B,B2: B > A] :
( ( finite_finite @ B @ S3 )
=> ( ( ( member2 @ B @ A3 @ S3 )
=> ( ( groups7311177749621191930dd_sum @ B @ A
@ ^ [K2: B] : ( if @ A @ ( K2 = A3 ) @ ( B2 @ K2 ) @ ( zero_zero @ A ) )
@ S3 )
= ( B2 @ A3 ) ) )
& ( ~ ( member2 @ B @ A3 @ S3 )
=> ( ( groups7311177749621191930dd_sum @ B @ A
@ ^ [K2: B] : ( if @ A @ ( K2 = A3 ) @ ( B2 @ K2 ) @ ( zero_zero @ A ) )
@ S3 )
= ( zero_zero @ A ) ) ) ) ) ) ).
% sum.delta
thf(fact_2153_sum_Odelta_H,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ A )
=> ! [S3: set @ B,A3: B,B2: B > A] :
( ( finite_finite @ B @ S3 )
=> ( ( ( member2 @ B @ A3 @ S3 )
=> ( ( groups7311177749621191930dd_sum @ B @ A
@ ^ [K2: B] : ( if @ A @ ( A3 = K2 ) @ ( B2 @ K2 ) @ ( zero_zero @ A ) )
@ S3 )
= ( B2 @ A3 ) ) )
& ( ~ ( member2 @ B @ A3 @ S3 )
=> ( ( groups7311177749621191930dd_sum @ B @ A
@ ^ [K2: B] : ( if @ A @ ( A3 = K2 ) @ ( B2 @ K2 ) @ ( zero_zero @ A ) )
@ S3 )
= ( zero_zero @ A ) ) ) ) ) ) ).
% sum.delta'
thf(fact_2154_List_Oset__insert,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( set2 @ A @ ( insert @ A @ X @ Xs ) )
= ( insert2 @ A @ X @ ( set2 @ A @ Xs ) ) ) ).
% List.set_insert
thf(fact_2155_sum_Oinsert,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,X: B,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ~ ( member2 @ B @ X @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( insert2 @ B @ X @ A4 ) )
= ( plus_plus @ A @ ( G @ X ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 ) ) ) ) ) ) ).
% sum.insert
thf(fact_2156_bit__numeral__Bit0__Suc__iff,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [M: num,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( numeral_numeral @ A @ ( bit0 @ M ) ) @ ( suc @ N2 ) )
= ( bit_se5641148757651400278ts_bit @ A @ ( numeral_numeral @ A @ M ) @ N2 ) ) ) ).
% bit_numeral_Bit0_Suc_iff
thf(fact_2157_bit__numeral__Bit1__Suc__iff,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [M: num,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( numeral_numeral @ A @ ( bit1 @ M ) ) @ ( suc @ N2 ) )
= ( bit_se5641148757651400278ts_bit @ A @ ( numeral_numeral @ A @ M ) @ N2 ) ) ) ).
% bit_numeral_Bit1_Suc_iff
thf(fact_2158_mask__Suc__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ( ( bit_se2239418461657761734s_mask @ A @ ( suc @ ( zero_zero @ nat ) ) )
= ( one_one @ A ) ) ) ).
% mask_Suc_0
thf(fact_2159_subset__Compl__singleton,axiom,
! [A: $tType,A4: set @ A,B2: A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ ( uminus_uminus @ ( set @ A ) @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( ~ ( member2 @ A @ B2 @ A4 ) ) ) ).
% subset_Compl_singleton
thf(fact_2160_ceiling__add__of__int,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Z: int] :
( ( archimedean_ceiling @ A @ ( plus_plus @ A @ X @ ( ring_1_of_int @ A @ Z ) ) )
= ( plus_plus @ int @ ( archimedean_ceiling @ A @ X ) @ Z ) ) ) ).
% ceiling_add_of_int
thf(fact_2161_ceiling__le__zero,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less_eq @ int @ ( archimedean_ceiling @ A @ X ) @ ( zero_zero @ int ) )
= ( ord_less_eq @ A @ X @ ( zero_zero @ A ) ) ) ) ).
% ceiling_le_zero
thf(fact_2162_zero__less__ceiling,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less @ int @ ( zero_zero @ int ) @ ( archimedean_ceiling @ A @ X ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ X ) ) ) ).
% zero_less_ceiling
thf(fact_2163_ceiling__le__numeral,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,V2: num] :
( ( ord_less_eq @ int @ ( archimedean_ceiling @ A @ X ) @ ( numeral_numeral @ int @ V2 ) )
= ( ord_less_eq @ A @ X @ ( numeral_numeral @ A @ V2 ) ) ) ) ).
% ceiling_le_numeral
thf(fact_2164_ceiling__less__one,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less @ int @ ( archimedean_ceiling @ A @ X ) @ ( one_one @ int ) )
= ( ord_less_eq @ A @ X @ ( zero_zero @ A ) ) ) ) ).
% ceiling_less_one
thf(fact_2165_one__le__ceiling,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less_eq @ int @ ( one_one @ int ) @ ( archimedean_ceiling @ A @ X ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ X ) ) ) ).
% one_le_ceiling
thf(fact_2166_numeral__less__ceiling,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [V2: num,X: A] :
( ( ord_less @ int @ ( numeral_numeral @ int @ V2 ) @ ( archimedean_ceiling @ A @ X ) )
= ( ord_less @ A @ ( numeral_numeral @ A @ V2 ) @ X ) ) ) ).
% numeral_less_ceiling
thf(fact_2167_ceiling__le__one,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less_eq @ int @ ( archimedean_ceiling @ A @ X ) @ ( one_one @ int ) )
= ( ord_less_eq @ A @ X @ ( one_one @ A ) ) ) ) ).
% ceiling_le_one
thf(fact_2168_one__less__ceiling,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less @ int @ ( one_one @ int ) @ ( archimedean_ceiling @ A @ X ) )
= ( ord_less @ A @ ( one_one @ A ) @ X ) ) ) ).
% one_less_ceiling
thf(fact_2169_set__replicate,axiom,
! [A: $tType,N2: nat,X: A] :
( ( N2
!= ( zero_zero @ nat ) )
=> ( ( set2 @ A @ ( replicate @ A @ N2 @ X ) )
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% set_replicate
thf(fact_2170_ceiling__add__numeral,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,V2: num] :
( ( archimedean_ceiling @ A @ ( plus_plus @ A @ X @ ( numeral_numeral @ A @ V2 ) ) )
= ( plus_plus @ int @ ( archimedean_ceiling @ A @ X ) @ ( numeral_numeral @ int @ V2 ) ) ) ) ).
% ceiling_add_numeral
thf(fact_2171_ceiling__add__one,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( archimedean_ceiling @ A @ ( plus_plus @ A @ X @ ( one_one @ A ) ) )
= ( plus_plus @ int @ ( archimedean_ceiling @ A @ X ) @ ( one_one @ int ) ) ) ) ).
% ceiling_add_one
thf(fact_2172_bit__minus__numeral__Bit0__Suc__iff,axiom,
! [W2: num,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ ( bit0 @ W2 ) ) ) @ ( suc @ N2 ) )
= ( bit_se5641148757651400278ts_bit @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ W2 ) ) @ N2 ) ) ).
% bit_minus_numeral_Bit0_Suc_iff
thf(fact_2173_bit__minus__numeral__Bit1__Suc__iff,axiom,
! [W2: num,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ ( bit1 @ W2 ) ) ) @ ( suc @ N2 ) )
= ( ~ ( bit_se5641148757651400278ts_bit @ int @ ( numeral_numeral @ int @ W2 ) @ N2 ) ) ) ).
% bit_minus_numeral_Bit1_Suc_iff
thf(fact_2174_bit__0,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A] :
( ( bit_se5641148757651400278ts_bit @ A @ A3 @ ( zero_zero @ nat ) )
= ( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) ) ) ).
% bit_0
thf(fact_2175_sum_Ocl__ivl__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [N2: nat,M: nat,G: nat > A] :
( ( ( ord_less @ nat @ ( suc @ N2 ) @ M )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ ( suc @ N2 ) ) )
= ( zero_zero @ A ) ) )
& ( ~ ( ord_less @ nat @ ( suc @ N2 ) @ M )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) @ ( G @ ( suc @ N2 ) ) ) ) ) ) ) ).
% sum.cl_ivl_Suc
thf(fact_2176_ceiling__less__zero,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less @ int @ ( archimedean_ceiling @ A @ X ) @ ( zero_zero @ int ) )
= ( ord_less_eq @ A @ X @ ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ) ).
% ceiling_less_zero
thf(fact_2177_zero__le__ceiling,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ ( archimedean_ceiling @ A @ X ) )
= ( ord_less @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ X ) ) ) ).
% zero_le_ceiling
thf(fact_2178_sum__zero__power,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A4: set @ nat,C2: nat > A] :
( ( ( ( finite_finite @ nat @ A4 )
& ( member2 @ nat @ ( zero_zero @ nat ) @ A4 ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ ( zero_zero @ A ) @ I5 ) )
@ A4 )
= ( C2 @ ( zero_zero @ nat ) ) ) )
& ( ~ ( ( finite_finite @ nat @ A4 )
& ( member2 @ nat @ ( zero_zero @ nat ) @ A4 ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ ( zero_zero @ A ) @ I5 ) )
@ A4 )
= ( zero_zero @ A ) ) ) ) ) ).
% sum_zero_power
thf(fact_2179_bit__mod__2__iff,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( modulo_modulo @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ N2 )
= ( ( N2
= ( zero_zero @ nat ) )
& ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) ) ) ).
% bit_mod_2_iff
thf(fact_2180_ceiling__less__numeral,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,V2: num] :
( ( ord_less @ int @ ( archimedean_ceiling @ A @ X ) @ ( numeral_numeral @ int @ V2 ) )
= ( ord_less_eq @ A @ X @ ( minus_minus @ A @ ( numeral_numeral @ A @ V2 ) @ ( one_one @ A ) ) ) ) ) ).
% ceiling_less_numeral
thf(fact_2181_numeral__le__ceiling,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [V2: num,X: A] :
( ( ord_less_eq @ int @ ( numeral_numeral @ int @ V2 ) @ ( archimedean_ceiling @ A @ X ) )
= ( ord_less @ A @ ( minus_minus @ A @ ( numeral_numeral @ A @ V2 ) @ ( one_one @ A ) ) @ X ) ) ) ).
% numeral_le_ceiling
thf(fact_2182_ceiling__le__neg__numeral,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,V2: num] :
( ( ord_less_eq @ int @ ( archimedean_ceiling @ A @ X ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ V2 ) ) )
= ( ord_less_eq @ A @ X @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) ) ) ) ).
% ceiling_le_neg_numeral
thf(fact_2183_neg__numeral__less__ceiling,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [V2: num,X: A] :
( ( ord_less @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ V2 ) ) @ ( archimedean_ceiling @ A @ X ) )
= ( ord_less @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) @ X ) ) ) ).
% neg_numeral_less_ceiling
thf(fact_2184_sum__zero__power_H,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A4: set @ nat,C2: nat > A,D2: nat > A] :
( ( ( ( finite_finite @ nat @ A4 )
& ( member2 @ nat @ ( zero_zero @ nat ) @ A4 ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( divide_divide @ A @ ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ ( zero_zero @ A ) @ I5 ) ) @ ( D2 @ I5 ) )
@ A4 )
= ( divide_divide @ A @ ( C2 @ ( zero_zero @ nat ) ) @ ( D2 @ ( zero_zero @ nat ) ) ) ) )
& ( ~ ( ( finite_finite @ nat @ A4 )
& ( member2 @ nat @ ( zero_zero @ nat ) @ A4 ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( divide_divide @ A @ ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ ( zero_zero @ A ) @ I5 ) ) @ ( D2 @ I5 ) )
@ A4 )
= ( zero_zero @ A ) ) ) ) ) ).
% sum_zero_power'
thf(fact_2185_sum_Oinsert__if,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,X: B,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( ( member2 @ B @ X @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( insert2 @ B @ X @ A4 ) )
= ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 ) ) )
& ( ~ ( member2 @ B @ X @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( insert2 @ B @ X @ A4 ) )
= ( plus_plus @ A @ ( G @ X ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 ) ) ) ) ) ) ) ).
% sum.insert_if
thf(fact_2186_sum_Oneutral,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,G: B > A] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ( G @ X5 )
= ( zero_zero @ A ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 )
= ( zero_zero @ A ) ) ) ) ).
% sum.neutral
thf(fact_2187_sum_Onot__neutral__contains__not__neutral,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: B > A,A4: set @ B] :
( ( ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 )
!= ( zero_zero @ A ) )
=> ~ ! [A7: B] :
( ( member2 @ B @ A7 @ A4 )
=> ( ( G @ A7 )
= ( zero_zero @ A ) ) ) ) ) ).
% sum.not_neutral_contains_not_neutral
thf(fact_2188_bit__disjunctive__add__iff,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,B2: A,N2: nat] :
( ! [N3: nat] :
( ~ ( bit_se5641148757651400278ts_bit @ A @ A3 @ N3 )
| ~ ( bit_se5641148757651400278ts_bit @ A @ B2 @ N3 ) )
=> ( ( bit_se5641148757651400278ts_bit @ A @ ( plus_plus @ A @ A3 @ B2 ) @ N2 )
= ( ( bit_se5641148757651400278ts_bit @ A @ A3 @ N2 )
| ( bit_se5641148757651400278ts_bit @ A @ B2 @ N2 ) ) ) ) ) ).
% bit_disjunctive_add_iff
thf(fact_2189_singletonD,axiom,
! [A: $tType,B2: A,A3: A] :
( ( member2 @ A @ B2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) )
=> ( B2 = A3 ) ) ).
% singletonD
thf(fact_2190_singleton__iff,axiom,
! [A: $tType,B2: A,A3: A] :
( ( member2 @ A @ B2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) )
= ( B2 = A3 ) ) ).
% singleton_iff
thf(fact_2191_doubleton__eq__iff,axiom,
! [A: $tType,A3: A,B2: A,C2: A,D2: A] :
( ( ( insert2 @ A @ A3 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) )
= ( insert2 @ A @ C2 @ ( insert2 @ A @ D2 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( ( ( A3 = C2 )
& ( B2 = D2 ) )
| ( ( A3 = D2 )
& ( B2 = C2 ) ) ) ) ).
% doubleton_eq_iff
thf(fact_2192_insert__not__empty,axiom,
! [A: $tType,A3: A,A4: set @ A] :
( ( insert2 @ A @ A3 @ A4 )
!= ( bot_bot @ ( set @ A ) ) ) ).
% insert_not_empty
thf(fact_2193_singleton__inject,axiom,
! [A: $tType,A3: A,B2: A] :
( ( ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) )
= ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) )
=> ( A3 = B2 ) ) ).
% singleton_inject
thf(fact_2194_insert__subsetI,axiom,
! [A: $tType,X: A,A4: set @ A,X7: set @ A] :
( ( member2 @ A @ X @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ X7 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ X7 ) @ A4 ) ) ) ).
% insert_subsetI
thf(fact_2195_insert__mono,axiom,
! [A: $tType,C5: set @ A,D6: set @ A,A3: A] :
( ( ord_less_eq @ ( set @ A ) @ C5 @ D6 )
=> ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ A3 @ C5 ) @ ( insert2 @ A @ A3 @ D6 ) ) ) ).
% insert_mono
thf(fact_2196_subset__insert,axiom,
! [A: $tType,X: A,A4: set @ A,B3: set @ A] :
( ~ ( member2 @ A @ X @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ B3 ) )
= ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ) ).
% subset_insert
thf(fact_2197_subset__insertI,axiom,
! [A: $tType,B3: set @ A,A3: A] : ( ord_less_eq @ ( set @ A ) @ B3 @ ( insert2 @ A @ A3 @ B3 ) ) ).
% subset_insertI
thf(fact_2198_subset__insertI2,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,B2: A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ ( insert2 @ A @ B2 @ B3 ) ) ) ).
% subset_insertI2
thf(fact_2199_less__eq__mask,axiom,
! [N2: nat] : ( ord_less_eq @ nat @ N2 @ ( bit_se2239418461657761734s_mask @ nat @ N2 ) ) ).
% less_eq_mask
thf(fact_2200_sum__mono,axiom,
! [A: $tType,B: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [K5: set @ B,F2: B > A,G: B > A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ K5 )
=> ( ord_less_eq @ A @ ( F2 @ I3 ) @ ( G @ I3 ) ) )
=> ( ord_less_eq @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ K5 ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ K5 ) ) ) ) ).
% sum_mono
thf(fact_2201_sum_Odistrib,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: B > A,H2: B > A,A4: set @ B] :
( ( groups7311177749621191930dd_sum @ B @ A
@ ^ [X2: B] : ( plus_plus @ A @ ( G @ X2 ) @ ( H2 @ X2 ) )
@ A4 )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 ) @ ( groups7311177749621191930dd_sum @ B @ A @ H2 @ A4 ) ) ) ) ).
% sum.distrib
thf(fact_2202_sum__diff1__nat,axiom,
! [A: $tType,A3: A,A4: set @ A,F2: A > nat] :
( ( ( member2 @ A @ A3 @ A4 )
=> ( ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( minus_minus @ nat @ ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ A4 ) @ ( F2 @ A3 ) ) ) )
& ( ~ ( member2 @ A @ A3 @ A4 )
=> ( ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ A4 ) ) ) ) ).
% sum_diff1_nat
thf(fact_2203_Collect__conv__if,axiom,
! [A: $tType,P2: A > $o,A3: A] :
( ( ( P2 @ A3 )
=> ( ( collect @ A
@ ^ [X2: A] :
( ( X2 = A3 )
& ( P2 @ X2 ) ) )
= ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) )
& ( ~ ( P2 @ A3 )
=> ( ( collect @ A
@ ^ [X2: A] :
( ( X2 = A3 )
& ( P2 @ X2 ) ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% Collect_conv_if
thf(fact_2204_Collect__conv__if2,axiom,
! [A: $tType,P2: A > $o,A3: A] :
( ( ( P2 @ A3 )
=> ( ( collect @ A
@ ^ [X2: A] :
( ( A3 = X2 )
& ( P2 @ X2 ) ) )
= ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) )
& ( ~ ( P2 @ A3 )
=> ( ( collect @ A
@ ^ [X2: A] :
( ( A3 = X2 )
& ( P2 @ X2 ) ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% Collect_conv_if2
thf(fact_2205_sum_Oremove,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,X: B,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( member2 @ B @ X @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 )
= ( plus_plus @ A @ ( G @ X ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ ( minus_minus @ ( set @ B ) @ A4 @ ( insert2 @ B @ X @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ) ) ) ).
% sum.remove
thf(fact_2206_sum_Oinsert__remove,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,G: B > A,X: B] :
( ( finite_finite @ B @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( insert2 @ B @ X @ A4 ) )
= ( plus_plus @ A @ ( G @ X ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ ( minus_minus @ ( set @ B ) @ A4 @ ( insert2 @ B @ X @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ) ) ).
% sum.insert_remove
thf(fact_2207_sum__diff1,axiom,
! [A: $tType,B: $tType] :
( ( ab_group_add @ A )
=> ! [A4: set @ B,A3: B,F2: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( ( member2 @ B @ A3 @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ F2 @ ( minus_minus @ ( set @ B ) @ A4 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) )
= ( minus_minus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) @ ( F2 @ A3 ) ) ) )
& ( ~ ( member2 @ B @ A3 @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ F2 @ ( minus_minus @ ( set @ B ) @ A4 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) )
= ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) ) ) ) ) ) ).
% sum_diff1
thf(fact_2208_sum__nonneg,axiom,
! [A: $tType,B: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A4: set @ B,F2: B > A] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ X5 ) ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) ) ) ) ).
% sum_nonneg
thf(fact_2209_sum__nonpos,axiom,
! [B: $tType,A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A4: set @ B,F2: B > A] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( zero_zero @ A ) ) )
=> ( ord_less_eq @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) @ ( zero_zero @ A ) ) ) ) ).
% sum_nonpos
thf(fact_2210_not__bit__1__Suc,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat] :
~ ( bit_se5641148757651400278ts_bit @ A @ ( one_one @ A ) @ ( suc @ N2 ) ) ) ).
% not_bit_1_Suc
thf(fact_2211_sum__mono__inv,axiom,
! [A: $tType,I7: $tType] :
( ( ordere8940638589300402666id_add @ A )
=> ! [F2: I7 > A,I6: set @ I7,G: I7 > A,I: I7] :
( ( ( groups7311177749621191930dd_sum @ I7 @ A @ F2 @ I6 )
= ( groups7311177749621191930dd_sum @ I7 @ A @ G @ I6 ) )
=> ( ! [I3: I7] :
( ( member2 @ I7 @ I3 @ I6 )
=> ( ord_less_eq @ A @ ( F2 @ I3 ) @ ( G @ I3 ) ) )
=> ( ( member2 @ I7 @ I @ I6 )
=> ( ( finite_finite @ I7 @ I6 )
=> ( ( F2 @ I )
= ( G @ I ) ) ) ) ) ) ) ).
% sum_mono_inv
thf(fact_2212_bit__1__iff,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( one_one @ A ) @ N2 )
= ( N2
= ( zero_zero @ nat ) ) ) ) ).
% bit_1_iff
thf(fact_2213_sum__cong__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ nat,F2: nat > A,G: nat > A] :
( ~ ( member2 @ nat @ ( zero_zero @ nat ) @ A4 )
=> ( ! [X5: nat] :
( ( member2 @ nat @ ( suc @ X5 ) @ A4 )
=> ( ( F2 @ ( suc @ X5 ) )
= ( G @ ( suc @ X5 ) ) ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ A4 )
= ( groups7311177749621191930dd_sum @ nat @ A @ G @ A4 ) ) ) ) ) ).
% sum_cong_Suc
thf(fact_2214_bit__take__bit__iff,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,A3: A,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( bit_se2584673776208193580ke_bit @ A @ M @ A3 ) @ N2 )
= ( ( ord_less @ nat @ N2 @ M )
& ( bit_se5641148757651400278ts_bit @ A @ A3 @ N2 ) ) ) ) ).
% bit_take_bit_iff
thf(fact_2215_ceiling__mono,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ Y @ X )
=> ( ord_less_eq @ int @ ( archimedean_ceiling @ A @ Y ) @ ( archimedean_ceiling @ A @ X ) ) ) ) ).
% ceiling_mono
thf(fact_2216_le__of__int__ceiling,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] : ( ord_less_eq @ A @ X @ ( ring_1_of_int @ A @ ( archimedean_ceiling @ A @ X ) ) ) ) ).
% le_of_int_ceiling
thf(fact_2217_ceiling__less__cancel,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ int @ ( archimedean_ceiling @ A @ X ) @ ( archimedean_ceiling @ A @ Y ) )
=> ( ord_less @ A @ X @ Y ) ) ) ).
% ceiling_less_cancel
thf(fact_2218_bit__of__bool__iff,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [B2: $o,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( zero_neq_one_of_bool @ A @ B2 ) @ N2 )
= ( B2
& ( N2
= ( zero_zero @ nat ) ) ) ) ) ).
% bit_of_bool_iff
thf(fact_2219_sum_Odelta__remove,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [S3: set @ B,A3: B,B2: B > A,C2: B > A] :
( ( finite_finite @ B @ S3 )
=> ( ( ( member2 @ B @ A3 @ S3 )
=> ( ( groups7311177749621191930dd_sum @ B @ A
@ ^ [K2: B] : ( if @ A @ ( K2 = A3 ) @ ( B2 @ K2 ) @ ( C2 @ K2 ) )
@ S3 )
= ( plus_plus @ A @ ( B2 @ A3 ) @ ( groups7311177749621191930dd_sum @ B @ A @ C2 @ ( minus_minus @ ( set @ B ) @ S3 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) )
& ( ~ ( member2 @ B @ A3 @ S3 )
=> ( ( groups7311177749621191930dd_sum @ B @ A
@ ^ [K2: B] : ( if @ A @ ( K2 = A3 ) @ ( B2 @ K2 ) @ ( C2 @ K2 ) )
@ S3 )
= ( groups7311177749621191930dd_sum @ B @ A @ C2 @ ( minus_minus @ ( set @ B ) @ S3 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ) ) ) ).
% sum.delta_remove
thf(fact_2220_finite_Ocases,axiom,
! [A: $tType,A3: set @ A] :
( ( finite_finite @ A @ A3 )
=> ( ( A3
!= ( bot_bot @ ( set @ A ) ) )
=> ~ ! [A9: set @ A] :
( ? [A7: A] :
( A3
= ( insert2 @ A @ A7 @ A9 ) )
=> ~ ( finite_finite @ A @ A9 ) ) ) ) ).
% finite.cases
thf(fact_2221_finite_Osimps,axiom,
! [A: $tType] :
( ( finite_finite @ A )
= ( ^ [A5: set @ A] :
( ( A5
= ( bot_bot @ ( set @ A ) ) )
| ? [A6: set @ A,B4: A] :
( ( A5
= ( insert2 @ A @ B4 @ A6 ) )
& ( finite_finite @ A @ A6 ) ) ) ) ) ).
% finite.simps
thf(fact_2222_finite__induct,axiom,
! [A: $tType,F5: set @ A,P2: ( set @ A ) > $o] :
( ( finite_finite @ A @ F5 )
=> ( ( P2 @ ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A,F6: set @ A] :
( ( finite_finite @ A @ F6 )
=> ( ~ ( member2 @ A @ X5 @ F6 )
=> ( ( P2 @ F6 )
=> ( P2 @ ( insert2 @ A @ X5 @ F6 ) ) ) ) )
=> ( P2 @ F5 ) ) ) ) ).
% finite_induct
thf(fact_2223_finite__ne__induct,axiom,
! [A: $tType,F5: set @ A,P2: ( set @ A ) > $o] :
( ( finite_finite @ A @ F5 )
=> ( ( F5
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] : ( P2 @ ( insert2 @ A @ X5 @ ( bot_bot @ ( set @ A ) ) ) )
=> ( ! [X5: A,F6: set @ A] :
( ( finite_finite @ A @ F6 )
=> ( ( F6
!= ( bot_bot @ ( set @ A ) ) )
=> ( ~ ( member2 @ A @ X5 @ F6 )
=> ( ( P2 @ F6 )
=> ( P2 @ ( insert2 @ A @ X5 @ F6 ) ) ) ) ) )
=> ( P2 @ F5 ) ) ) ) ) ).
% finite_ne_induct
thf(fact_2224_infinite__finite__induct,axiom,
! [A: $tType,P2: ( set @ A ) > $o,A4: set @ A] :
( ! [A9: set @ A] :
( ~ ( finite_finite @ A @ A9 )
=> ( P2 @ A9 ) )
=> ( ( P2 @ ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A,F6: set @ A] :
( ( finite_finite @ A @ F6 )
=> ( ~ ( member2 @ A @ X5 @ F6 )
=> ( ( P2 @ F6 )
=> ( P2 @ ( insert2 @ A @ X5 @ F6 ) ) ) ) )
=> ( P2 @ A4 ) ) ) ) ).
% infinite_finite_induct
thf(fact_2225_subset__singleton__iff,axiom,
! [A: $tType,X7: set @ A,A3: A] :
( ( ord_less_eq @ ( set @ A ) @ X7 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) )
= ( ( X7
= ( bot_bot @ ( set @ A ) ) )
| ( X7
= ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% subset_singleton_iff
thf(fact_2226_subset__singletonD,axiom,
! [A: $tType,A4: set @ A,X: A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
=> ( ( A4
= ( bot_bot @ ( set @ A ) ) )
| ( A4
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% subset_singletonD
thf(fact_2227_atLeastAtMost__singleton_H,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A3: A,B2: A] :
( ( A3 = B2 )
=> ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
= ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% atLeastAtMost_singleton'
thf(fact_2228_Diff__insert__absorb,axiom,
! [A: $tType,X: A,A4: set @ A] :
( ~ ( member2 @ A @ X @ A4 )
=> ( ( minus_minus @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= A4 ) ) ).
% Diff_insert_absorb
thf(fact_2229_Diff__insert2,axiom,
! [A: $tType,A4: set @ A,A3: A,B3: set @ A] :
( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ B3 ) )
= ( minus_minus @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) @ B3 ) ) ).
% Diff_insert2
thf(fact_2230_insert__Diff,axiom,
! [A: $tType,A3: A,A4: set @ A] :
( ( member2 @ A @ A3 @ A4 )
=> ( ( insert2 @ A @ A3 @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) )
= A4 ) ) ).
% insert_Diff
thf(fact_2231_Diff__insert,axiom,
! [A: $tType,A4: set @ A,A3: A,B3: set @ A] :
( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ B3 ) )
= ( minus_minus @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% Diff_insert
thf(fact_2232_subset__Diff__insert,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,X: A,C5: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ ( minus_minus @ ( set @ A ) @ B3 @ ( insert2 @ A @ X @ C5 ) ) )
= ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( minus_minus @ ( set @ A ) @ B3 @ C5 ) )
& ~ ( member2 @ A @ X @ A4 ) ) ) ).
% subset_Diff_insert
thf(fact_2233_sum_Ointer__filter,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,G: B > A,P2: B > $o] :
( ( finite_finite @ B @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G
@ ( collect @ B
@ ^ [X2: B] :
( ( member2 @ B @ X2 @ A4 )
& ( P2 @ X2 ) ) ) )
= ( groups7311177749621191930dd_sum @ B @ A
@ ^ [X2: B] : ( if @ A @ ( P2 @ X2 ) @ ( G @ X2 ) @ ( zero_zero @ A ) )
@ A4 ) ) ) ) ).
% sum.inter_filter
thf(fact_2234_member__le__sum,axiom,
! [B: $tType,C: $tType] :
( ( ( ordere6911136660526730532id_add @ B )
& ( semiring_1 @ B ) )
=> ! [I: C,A4: set @ C,F2: C > B] :
( ( member2 @ C @ I @ A4 )
=> ( ! [X5: C] :
( ( member2 @ C @ X5 @ ( minus_minus @ ( set @ C ) @ A4 @ ( insert2 @ C @ I @ ( bot_bot @ ( set @ C ) ) ) ) )
=> ( ord_less_eq @ B @ ( zero_zero @ B ) @ ( F2 @ X5 ) ) )
=> ( ( finite_finite @ C @ A4 )
=> ( ord_less_eq @ B @ ( F2 @ I ) @ ( groups7311177749621191930dd_sum @ C @ B @ F2 @ A4 ) ) ) ) ) ) ).
% member_le_sum
thf(fact_2235_sum__subtractf__nat,axiom,
! [A: $tType,A4: set @ A,G: A > nat,F2: A > nat] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ nat @ ( G @ X5 ) @ ( F2 @ X5 ) ) )
=> ( ( groups7311177749621191930dd_sum @ A @ nat
@ ^ [X2: A] : ( minus_minus @ nat @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ A4 )
= ( minus_minus @ nat @ ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ A4 ) @ ( groups7311177749621191930dd_sum @ A @ nat @ G @ A4 ) ) ) ) ).
% sum_subtractf_nat
thf(fact_2236_sum_Oshift__bounds__cl__Suc__ivl,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% sum.shift_bounds_cl_Suc_ivl
thf(fact_2237_sum_Oshift__bounds__cl__nat__ivl,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,K: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( plus_plus @ nat @ M @ K ) @ ( plus_plus @ nat @ N2 @ K ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( plus_plus @ nat @ I5 @ K ) )
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% sum.shift_bounds_cl_nat_ivl
thf(fact_2238_sum__le__included,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [S: set @ B,T2: set @ C,G: C > A,I: C > B,F2: B > A] :
( ( finite_finite @ B @ S )
=> ( ( finite_finite @ C @ T2 )
=> ( ! [X5: C] :
( ( member2 @ C @ X5 @ T2 )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( G @ X5 ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ S )
=> ? [Xa: C] :
( ( member2 @ C @ Xa @ T2 )
& ( ( I @ Xa )
= X5 )
& ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( G @ Xa ) ) ) )
=> ( ord_less_eq @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ S ) @ ( groups7311177749621191930dd_sum @ C @ A @ G @ T2 ) ) ) ) ) ) ) ).
% sum_le_included
thf(fact_2239_sum__nonneg__eq__0__iff,axiom,
! [A: $tType,B: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [A4: set @ B,F2: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ X5 ) ) )
=> ( ( ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 )
= ( zero_zero @ A ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( ( F2 @ X2 )
= ( zero_zero @ A ) ) ) ) ) ) ) ) ).
% sum_nonneg_eq_0_iff
thf(fact_2240_sum__strict__mono__ex1,axiom,
! [A: $tType,I7: $tType] :
( ( ordere8940638589300402666id_add @ A )
=> ! [A4: set @ I7,F2: I7 > A,G: I7 > A] :
( ( finite_finite @ I7 @ A4 )
=> ( ! [X5: I7] :
( ( member2 @ I7 @ X5 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ? [X3: I7] :
( ( member2 @ I7 @ X3 @ A4 )
& ( ord_less @ A @ ( F2 @ X3 ) @ ( G @ X3 ) ) )
=> ( ord_less @ A @ ( groups7311177749621191930dd_sum @ I7 @ A @ F2 @ A4 ) @ ( groups7311177749621191930dd_sum @ I7 @ A @ G @ A4 ) ) ) ) ) ) ).
% sum_strict_mono_ex1
thf(fact_2241_sum_Orelated,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [R: A > A > $o,S3: set @ B,H2: B > A,G: B > A] :
( ( R @ ( zero_zero @ A ) @ ( zero_zero @ A ) )
=> ( ! [X15: A,Y15: A,X23: A,Y23: A] :
( ( ( R @ X15 @ X23 )
& ( R @ Y15 @ Y23 ) )
=> ( R @ ( plus_plus @ A @ X15 @ Y15 ) @ ( plus_plus @ A @ X23 @ Y23 ) ) )
=> ( ( finite_finite @ B @ S3 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ S3 )
=> ( R @ ( H2 @ X5 ) @ ( G @ X5 ) ) )
=> ( R @ ( groups7311177749621191930dd_sum @ B @ A @ H2 @ S3 ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ S3 ) ) ) ) ) ) ) ).
% sum.related
thf(fact_2242_sum__strict__mono,axiom,
! [A: $tType,B: $tType] :
( ( strict7427464778891057005id_add @ A )
=> ! [A4: set @ B,F2: B > A,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less @ A @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ord_less @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 ) ) ) ) ) ) ).
% sum_strict_mono
thf(fact_2243_sum_Oreindex__bij__witness__not__neutral,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( comm_monoid_add @ A )
=> ! [S5: set @ B,T5: set @ C,S3: set @ B,I: C > B,J: B > C,T4: set @ C,G: B > A,H2: C > A] :
( ( finite_finite @ B @ S5 )
=> ( ( finite_finite @ C @ T5 )
=> ( ! [A7: B] :
( ( member2 @ B @ A7 @ ( minus_minus @ ( set @ B ) @ S3 @ S5 ) )
=> ( ( I @ ( J @ A7 ) )
= A7 ) )
=> ( ! [A7: B] :
( ( member2 @ B @ A7 @ ( minus_minus @ ( set @ B ) @ S3 @ S5 ) )
=> ( member2 @ C @ ( J @ A7 ) @ ( minus_minus @ ( set @ C ) @ T4 @ T5 ) ) )
=> ( ! [B5: C] :
( ( member2 @ C @ B5 @ ( minus_minus @ ( set @ C ) @ T4 @ T5 ) )
=> ( ( J @ ( I @ B5 ) )
= B5 ) )
=> ( ! [B5: C] :
( ( member2 @ C @ B5 @ ( minus_minus @ ( set @ C ) @ T4 @ T5 ) )
=> ( member2 @ B @ ( I @ B5 ) @ ( minus_minus @ ( set @ B ) @ S3 @ S5 ) ) )
=> ( ! [A7: B] :
( ( member2 @ B @ A7 @ S5 )
=> ( ( G @ A7 )
= ( zero_zero @ A ) ) )
=> ( ! [B5: C] :
( ( member2 @ C @ B5 @ T5 )
=> ( ( H2 @ B5 )
= ( zero_zero @ A ) ) )
=> ( ! [A7: B] :
( ( member2 @ B @ A7 @ S3 )
=> ( ( H2 @ ( J @ A7 ) )
= ( G @ A7 ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ S3 )
= ( groups7311177749621191930dd_sum @ C @ A @ H2 @ T4 ) ) ) ) ) ) ) ) ) ) ) ) ).
% sum.reindex_bij_witness_not_neutral
thf(fact_2244_sum__eq__Suc0__iff,axiom,
! [A: $tType,A4: set @ A,F2: A > nat] :
( ( finite_finite @ A @ A4 )
=> ( ( ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ A4 )
= ( suc @ ( zero_zero @ nat ) ) )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( ( F2 @ X2 )
= ( suc @ ( zero_zero @ nat ) ) )
& ! [Y2: A] :
( ( member2 @ A @ Y2 @ A4 )
=> ( ( X2 != Y2 )
=> ( ( F2 @ Y2 )
= ( zero_zero @ nat ) ) ) ) ) ) ) ) ).
% sum_eq_Suc0_iff
thf(fact_2245_sum__SucD,axiom,
! [A: $tType,F2: A > nat,A4: set @ A,N2: nat] :
( ( ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ A4 )
= ( suc @ N2 ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ A4 )
& ( ord_less @ nat @ ( zero_zero @ nat ) @ ( F2 @ X5 ) ) ) ) ).
% sum_SucD
thf(fact_2246_sum__eq__1__iff,axiom,
! [A: $tType,A4: set @ A,F2: A > nat] :
( ( finite_finite @ A @ A4 )
=> ( ( ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ A4 )
= ( one_one @ nat ) )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( ( F2 @ X2 )
= ( one_one @ nat ) )
& ! [Y2: A] :
( ( member2 @ A @ Y2 @ A4 )
=> ( ( X2 != Y2 )
=> ( ( F2 @ Y2 )
= ( zero_zero @ nat ) ) ) ) ) ) ) ) ).
% sum_eq_1_iff
thf(fact_2247_ceiling__le,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,A3: int] :
( ( ord_less_eq @ A @ X @ ( ring_1_of_int @ A @ A3 ) )
=> ( ord_less_eq @ int @ ( archimedean_ceiling @ A @ X ) @ A3 ) ) ) ).
% ceiling_le
thf(fact_2248_ceiling__le__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Z: int] :
( ( ord_less_eq @ int @ ( archimedean_ceiling @ A @ X ) @ Z )
= ( ord_less_eq @ A @ X @ ( ring_1_of_int @ A @ Z ) ) ) ) ).
% ceiling_le_iff
thf(fact_2249_less__ceiling__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Z: int,X: A] :
( ( ord_less @ int @ Z @ ( archimedean_ceiling @ A @ X ) )
= ( ord_less @ A @ ( ring_1_of_int @ A @ Z ) @ X ) ) ) ).
% less_ceiling_iff
thf(fact_2250_ceiling__add__le,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ int @ ( archimedean_ceiling @ A @ ( plus_plus @ A @ X @ Y ) ) @ ( plus_plus @ int @ ( archimedean_ceiling @ A @ X ) @ ( archimedean_ceiling @ A @ Y ) ) ) ) ).
% ceiling_add_le
thf(fact_2251_finite__ranking__induct,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [S3: set @ B,P2: ( set @ B ) > $o,F2: B > A] :
( ( finite_finite @ B @ S3 )
=> ( ( P2 @ ( bot_bot @ ( set @ B ) ) )
=> ( ! [X5: B,S6: set @ B] :
( ( finite_finite @ B @ S6 )
=> ( ! [Y3: B] :
( ( member2 @ B @ Y3 @ S6 )
=> ( ord_less_eq @ A @ ( F2 @ Y3 ) @ ( F2 @ X5 ) ) )
=> ( ( P2 @ S6 )
=> ( P2 @ ( insert2 @ B @ X5 @ S6 ) ) ) ) )
=> ( P2 @ S3 ) ) ) ) ) ).
% finite_ranking_induct
thf(fact_2252_finite__linorder__max__induct,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,P2: ( set @ A ) > $o] :
( ( finite_finite @ A @ A4 )
=> ( ( P2 @ ( bot_bot @ ( set @ A ) ) )
=> ( ! [B5: A,A9: set @ A] :
( ( finite_finite @ A @ A9 )
=> ( ! [X3: A] :
( ( member2 @ A @ X3 @ A9 )
=> ( ord_less @ A @ X3 @ B5 ) )
=> ( ( P2 @ A9 )
=> ( P2 @ ( insert2 @ A @ B5 @ A9 ) ) ) ) )
=> ( P2 @ A4 ) ) ) ) ) ).
% finite_linorder_max_induct
thf(fact_2253_finite__linorder__min__induct,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,P2: ( set @ A ) > $o] :
( ( finite_finite @ A @ A4 )
=> ( ( P2 @ ( bot_bot @ ( set @ A ) ) )
=> ( ! [B5: A,A9: set @ A] :
( ( finite_finite @ A @ A9 )
=> ( ! [X3: A] :
( ( member2 @ A @ X3 @ A9 )
=> ( ord_less @ A @ B5 @ X3 ) )
=> ( ( P2 @ A9 )
=> ( P2 @ ( insert2 @ A @ B5 @ A9 ) ) ) ) )
=> ( P2 @ A4 ) ) ) ) ) ).
% finite_linorder_min_induct
thf(fact_2254_finite__subset__induct_H,axiom,
! [A: $tType,F5: set @ A,A4: set @ A,P2: ( set @ A ) > $o] :
( ( finite_finite @ A @ F5 )
=> ( ( ord_less_eq @ ( set @ A ) @ F5 @ A4 )
=> ( ( P2 @ ( bot_bot @ ( set @ A ) ) )
=> ( ! [A7: A,F6: set @ A] :
( ( finite_finite @ A @ F6 )
=> ( ( member2 @ A @ A7 @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ F6 @ A4 )
=> ( ~ ( member2 @ A @ A7 @ F6 )
=> ( ( P2 @ F6 )
=> ( P2 @ ( insert2 @ A @ A7 @ F6 ) ) ) ) ) ) )
=> ( P2 @ F5 ) ) ) ) ) ).
% finite_subset_induct'
thf(fact_2255_finite__subset__induct,axiom,
! [A: $tType,F5: set @ A,A4: set @ A,P2: ( set @ A ) > $o] :
( ( finite_finite @ A @ F5 )
=> ( ( ord_less_eq @ ( set @ A ) @ F5 @ A4 )
=> ( ( P2 @ ( bot_bot @ ( set @ A ) ) )
=> ( ! [A7: A,F6: set @ A] :
( ( finite_finite @ A @ F6 )
=> ( ( member2 @ A @ A7 @ A4 )
=> ( ~ ( member2 @ A @ A7 @ F6 )
=> ( ( P2 @ F6 )
=> ( P2 @ ( insert2 @ A @ A7 @ F6 ) ) ) ) ) )
=> ( P2 @ F5 ) ) ) ) ) ).
% finite_subset_induct
thf(fact_2256_sum__nonneg__0,axiom,
! [B: $tType,A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [S: set @ B,F2: B > A,I: B] :
( ( finite_finite @ B @ S )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ S )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ I3 ) ) )
=> ( ( ( groups7311177749621191930dd_sum @ B @ A @ F2 @ S )
= ( zero_zero @ A ) )
=> ( ( member2 @ B @ I @ S )
=> ( ( F2 @ I )
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% sum_nonneg_0
thf(fact_2257_sum__nonneg__leq__bound,axiom,
! [B: $tType,A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [S: set @ B,F2: B > A,B3: A,I: B] :
( ( finite_finite @ B @ S )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ S )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ I3 ) ) )
=> ( ( ( groups7311177749621191930dd_sum @ B @ A @ F2 @ S )
= B3 )
=> ( ( member2 @ B @ I @ S )
=> ( ord_less_eq @ A @ ( F2 @ I ) @ B3 ) ) ) ) ) ) ).
% sum_nonneg_leq_bound
thf(fact_2258_infinite__remove,axiom,
! [A: $tType,S3: set @ A,A3: A] :
( ~ ( finite_finite @ A @ S3 )
=> ~ ( finite_finite @ A @ ( minus_minus @ ( set @ A ) @ S3 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% infinite_remove
thf(fact_2259_infinite__coinduct,axiom,
! [A: $tType,X7: ( set @ A ) > $o,A4: set @ A] :
( ( X7 @ A4 )
=> ( ! [A9: set @ A] :
( ( X7 @ A9 )
=> ? [X3: A] :
( ( member2 @ A @ X3 @ A9 )
& ( ( X7 @ ( minus_minus @ ( set @ A ) @ A9 @ ( insert2 @ A @ X3 @ ( bot_bot @ ( set @ A ) ) ) ) )
| ~ ( finite_finite @ A @ ( minus_minus @ ( set @ A ) @ A9 @ ( insert2 @ A @ X3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) )
=> ~ ( finite_finite @ A @ A4 ) ) ) ).
% infinite_coinduct
thf(fact_2260_finite__empty__induct,axiom,
! [A: $tType,A4: set @ A,P2: ( set @ A ) > $o] :
( ( finite_finite @ A @ A4 )
=> ( ( P2 @ A4 )
=> ( ! [A7: A,A9: set @ A] :
( ( finite_finite @ A @ A9 )
=> ( ( member2 @ A @ A7 @ A9 )
=> ( ( P2 @ A9 )
=> ( P2 @ ( minus_minus @ ( set @ A ) @ A9 @ ( insert2 @ A @ A7 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) )
=> ( P2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% finite_empty_induct
thf(fact_2261_Diff__single__insert,axiom,
! [A: $tType,A4: set @ A,X: A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) @ B3 )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ B3 ) ) ) ).
% Diff_single_insert
thf(fact_2262_subset__insert__iff,axiom,
! [A: $tType,A4: set @ A,X: A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ B3 ) )
= ( ( ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) @ B3 ) )
& ( ~ ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ) ) ).
% subset_insert_iff
thf(fact_2263_atLeast0__atMost__Suc,axiom,
! [N2: nat] :
( ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) )
= ( insert2 @ nat @ ( suc @ N2 ) @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ).
% atLeast0_atMost_Suc
thf(fact_2264_atLeastAtMost__insertL,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( insert2 @ nat @ M @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ N2 ) )
= ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ).
% atLeastAtMost_insertL
thf(fact_2265_atLeastAtMostSuc__conv,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ ( suc @ N2 ) )
=> ( ( set_or1337092689740270186AtMost @ nat @ M @ ( suc @ N2 ) )
= ( insert2 @ nat @ ( suc @ N2 ) @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% atLeastAtMostSuc_conv
thf(fact_2266_Icc__eq__insert__lb__nat,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( set_or1337092689740270186AtMost @ nat @ M @ N2 )
= ( insert2 @ nat @ M @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ N2 ) ) ) ) ).
% Icc_eq_insert_lb_nat
thf(fact_2267_sum_Osetdiff__irrelevant,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G
@ ( minus_minus @ ( set @ B ) @ A4
@ ( collect @ B
@ ^ [X2: B] :
( ( G @ X2 )
= ( zero_zero @ A ) ) ) ) )
= ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 ) ) ) ) ).
% sum.setdiff_irrelevant
thf(fact_2268_set__update__subset__insert,axiom,
! [A: $tType,Xs: list @ A,I: nat,X: A] : ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ ( list_update @ A @ Xs @ I @ X ) ) @ ( insert2 @ A @ X @ ( set2 @ A @ Xs ) ) ) ).
% set_update_subset_insert
thf(fact_2269_Compl__insert,axiom,
! [A: $tType,X: A,A4: set @ A] :
( ( uminus_uminus @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) )
= ( minus_minus @ ( set @ A ) @ ( uminus_uminus @ ( set @ A ) @ A4 ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% Compl_insert
thf(fact_2270_sum__power__add,axiom,
! [A: $tType] :
( ( ( monoid_mult @ A )
& ( comm_ring @ A ) )
=> ! [X: A,M: nat,I6: set @ nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( power_power @ A @ X @ ( plus_plus @ nat @ M @ I5 ) )
@ I6 )
= ( times_times @ A @ ( power_power @ A @ X @ M ) @ ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ I6 ) ) ) ) ).
% sum_power_add
thf(fact_2271_sum_OatLeastAtMost__rev,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat,M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ N2 @ M ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( minus_minus @ nat @ ( plus_plus @ nat @ M @ N2 ) @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ N2 @ M ) ) ) ) ).
% sum.atLeastAtMost_rev
thf(fact_2272_less__mask,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
=> ( ord_less @ nat @ N2 @ ( bit_se2239418461657761734s_mask @ nat @ N2 ) ) ) ).
% less_mask
thf(fact_2273_sum__pos2,axiom,
! [A: $tType,B: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [I6: set @ B,I: B,F2: B > A] :
( ( finite_finite @ B @ I6 )
=> ( ( member2 @ B @ I @ I6 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ ( F2 @ I ) )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ I6 )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ I3 ) ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ I6 ) ) ) ) ) ) ) ).
% sum_pos2
thf(fact_2274_sum__pos,axiom,
! [A: $tType,B: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [I6: set @ B,F2: B > A] :
( ( finite_finite @ B @ I6 )
=> ( ( I6
!= ( bot_bot @ ( set @ B ) ) )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ I6 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( F2 @ I3 ) ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ I6 ) ) ) ) ) ) ).
% sum_pos
thf(fact_2275_sum_Omono__neutral__cong__right,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [T4: set @ B,S3: set @ B,G: B > A,H2: B > A] :
( ( finite_finite @ B @ T4 )
=> ( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( G @ X5 )
= ( zero_zero @ A ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ S3 )
=> ( ( G @ X5 )
= ( H2 @ X5 ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ T4 )
= ( groups7311177749621191930dd_sum @ B @ A @ H2 @ S3 ) ) ) ) ) ) ) ).
% sum.mono_neutral_cong_right
thf(fact_2276_sum_Omono__neutral__cong__left,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [T4: set @ B,S3: set @ B,H2: B > A,G: B > A] :
( ( finite_finite @ B @ T4 )
=> ( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( H2 @ X5 )
= ( zero_zero @ A ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ S3 )
=> ( ( G @ X5 )
= ( H2 @ X5 ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ S3 )
= ( groups7311177749621191930dd_sum @ B @ A @ H2 @ T4 ) ) ) ) ) ) ) ).
% sum.mono_neutral_cong_left
thf(fact_2277_sum_Omono__neutral__right,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [T4: set @ B,S3: set @ B,G: B > A] :
( ( finite_finite @ B @ T4 )
=> ( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( G @ X5 )
= ( zero_zero @ A ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ T4 )
= ( groups7311177749621191930dd_sum @ B @ A @ G @ S3 ) ) ) ) ) ) ).
% sum.mono_neutral_right
thf(fact_2278_sum_Omono__neutral__left,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [T4: set @ B,S3: set @ B,G: B > A] :
( ( finite_finite @ B @ T4 )
=> ( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( G @ X5 )
= ( zero_zero @ A ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ S3 )
= ( groups7311177749621191930dd_sum @ B @ A @ G @ T4 ) ) ) ) ) ) ).
% sum.mono_neutral_left
thf(fact_2279_sum_Osame__carrierI,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [C5: set @ B,A4: set @ B,B3: set @ B,G: B > A,H2: B > A] :
( ( finite_finite @ B @ C5 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ C5 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ C5 )
=> ( ! [A7: B] :
( ( member2 @ B @ A7 @ ( minus_minus @ ( set @ B ) @ C5 @ A4 ) )
=> ( ( G @ A7 )
= ( zero_zero @ A ) ) )
=> ( ! [B5: B] :
( ( member2 @ B @ B5 @ ( minus_minus @ ( set @ B ) @ C5 @ B3 ) )
=> ( ( H2 @ B5 )
= ( zero_zero @ A ) ) )
=> ( ( ( groups7311177749621191930dd_sum @ B @ A @ G @ C5 )
= ( groups7311177749621191930dd_sum @ B @ A @ H2 @ C5 ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 )
= ( groups7311177749621191930dd_sum @ B @ A @ H2 @ B3 ) ) ) ) ) ) ) ) ) ).
% sum.same_carrierI
thf(fact_2280_sum_Osame__carrier,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [C5: set @ B,A4: set @ B,B3: set @ B,G: B > A,H2: B > A] :
( ( finite_finite @ B @ C5 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ C5 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ C5 )
=> ( ! [A7: B] :
( ( member2 @ B @ A7 @ ( minus_minus @ ( set @ B ) @ C5 @ A4 ) )
=> ( ( G @ A7 )
= ( zero_zero @ A ) ) )
=> ( ! [B5: B] :
( ( member2 @ B @ B5 @ ( minus_minus @ ( set @ B ) @ C5 @ B3 ) )
=> ( ( H2 @ B5 )
= ( zero_zero @ A ) ) )
=> ( ( ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 )
= ( groups7311177749621191930dd_sum @ B @ A @ H2 @ B3 ) )
= ( ( groups7311177749621191930dd_sum @ B @ A @ G @ C5 )
= ( groups7311177749621191930dd_sum @ B @ A @ H2 @ C5 ) ) ) ) ) ) ) ) ) ).
% sum.same_carrier
thf(fact_2281_sum_Osubset__diff,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [B3: set @ B,A4: set @ B,G: B > A] :
( ( ord_less_eq @ ( set @ B ) @ B3 @ A4 )
=> ( ( finite_finite @ B @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ G @ ( minus_minus @ ( set @ B ) @ A4 @ B3 ) ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ B3 ) ) ) ) ) ) ).
% sum.subset_diff
thf(fact_2282_sum__diff,axiom,
! [A: $tType,B: $tType] :
( ( ab_group_add @ A )
=> ! [A4: set @ B,B3: set @ B,F2: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ F2 @ ( minus_minus @ ( set @ B ) @ A4 @ B3 ) )
= ( minus_minus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ B3 ) ) ) ) ) ) ).
% sum_diff
thf(fact_2283_of__int__ceiling__le__add__one,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [R2: A] : ( ord_less_eq @ A @ ( ring_1_of_int @ A @ ( archimedean_ceiling @ A @ R2 ) ) @ ( plus_plus @ A @ R2 @ ( one_one @ A ) ) ) ) ).
% of_int_ceiling_le_add_one
thf(fact_2284_of__int__ceiling__diff__one__le,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [R2: A] : ( ord_less_eq @ A @ ( minus_minus @ A @ ( ring_1_of_int @ A @ ( archimedean_ceiling @ A @ R2 ) ) @ ( one_one @ A ) ) @ R2 ) ) ).
% of_int_ceiling_diff_one_le
thf(fact_2285_sum__diff__nat,axiom,
! [A: $tType,B3: set @ A,A4: set @ A,F2: A > nat] :
( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) )
= ( minus_minus @ nat @ ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ A4 ) @ ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ B3 ) ) ) ) ) ).
% sum_diff_nat
thf(fact_2286_sum__shift__lb__Suc0__0,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [F2: nat > A,K: nat] :
( ( ( F2 @ ( zero_zero @ nat ) )
= ( zero_zero @ A ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ ( zero_zero @ nat ) ) @ K ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ K ) ) ) ) ) ).
% sum_shift_lb_Suc0_0
thf(fact_2287_sum_OatLeast0__atMost__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) ) @ ( G @ ( suc @ N2 ) ) ) ) ) ).
% sum.atLeast0_atMost_Suc
thf(fact_2288_sum_Onat__ivl__Suc_H,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ ( suc @ N2 ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( G @ ( suc @ N2 ) ) @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ) ) ).
% sum.nat_ivl_Suc'
thf(fact_2289_sum_OatLeast__Suc__atMost,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( plus_plus @ A @ ( G @ M ) @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ N2 ) ) ) ) ) ) ).
% sum.atLeast_Suc_atMost
thf(fact_2290_bit__imp__take__bit__positive,axiom,
! [N2: nat,M: nat,K: int] :
( ( ord_less @ nat @ N2 @ M )
=> ( ( bit_se5641148757651400278ts_bit @ int @ K @ N2 )
=> ( ord_less @ int @ ( zero_zero @ int ) @ ( bit_se2584673776208193580ke_bit @ int @ M @ K ) ) ) ) ).
% bit_imp_take_bit_positive
thf(fact_2291_bit__concat__bit__iff,axiom,
! [M: nat,K: int,L: int,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ int @ ( bit_concat_bit @ M @ K @ L ) @ N2 )
= ( ( ( ord_less @ nat @ N2 @ M )
& ( bit_se5641148757651400278ts_bit @ int @ K @ N2 ) )
| ( ( ord_less_eq @ nat @ M @ N2 )
& ( bit_se5641148757651400278ts_bit @ int @ L @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ) ).
% bit_concat_bit_iff
thf(fact_2292_finite__remove__induct,axiom,
! [A: $tType,B3: set @ A,P2: ( set @ A ) > $o] :
( ( finite_finite @ A @ B3 )
=> ( ( P2 @ ( bot_bot @ ( set @ A ) ) )
=> ( ! [A9: set @ A] :
( ( finite_finite @ A @ A9 )
=> ( ( A9
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ A9 @ B3 )
=> ( ! [X3: A] :
( ( member2 @ A @ X3 @ A9 )
=> ( P2 @ ( minus_minus @ ( set @ A ) @ A9 @ ( insert2 @ A @ X3 @ ( bot_bot @ ( set @ A ) ) ) ) ) )
=> ( P2 @ A9 ) ) ) ) )
=> ( P2 @ B3 ) ) ) ) ).
% finite_remove_induct
thf(fact_2293_remove__induct,axiom,
! [A: $tType,P2: ( set @ A ) > $o,B3: set @ A] :
( ( P2 @ ( bot_bot @ ( set @ A ) ) )
=> ( ( ~ ( finite_finite @ A @ B3 )
=> ( P2 @ B3 ) )
=> ( ! [A9: set @ A] :
( ( finite_finite @ A @ A9 )
=> ( ( A9
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ A9 @ B3 )
=> ( ! [X3: A] :
( ( member2 @ A @ X3 @ A9 )
=> ( P2 @ ( minus_minus @ ( set @ A ) @ A9 @ ( insert2 @ A @ X3 @ ( bot_bot @ ( set @ A ) ) ) ) ) )
=> ( P2 @ A9 ) ) ) ) )
=> ( P2 @ B3 ) ) ) ) ).
% remove_induct
thf(fact_2294_finite__induct__select,axiom,
! [A: $tType,S3: set @ A,P2: ( set @ A ) > $o] :
( ( finite_finite @ A @ S3 )
=> ( ( P2 @ ( bot_bot @ ( set @ A ) ) )
=> ( ! [T6: set @ A] :
( ( ord_less @ ( set @ A ) @ T6 @ S3 )
=> ( ( P2 @ T6 )
=> ? [X3: A] :
( ( member2 @ A @ X3 @ ( minus_minus @ ( set @ A ) @ S3 @ T6 ) )
& ( P2 @ ( insert2 @ A @ X3 @ T6 ) ) ) ) )
=> ( P2 @ S3 ) ) ) ) ).
% finite_induct_select
thf(fact_2295_psubset__insert__iff,axiom,
! [A: $tType,A4: set @ A,X: A,B3: set @ A] :
( ( ord_less @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ B3 ) )
= ( ( ( member2 @ A @ X @ B3 )
=> ( ord_less @ ( set @ A ) @ A4 @ B3 ) )
& ( ~ ( member2 @ A @ X @ B3 )
=> ( ( ( member2 @ A @ X @ A4 )
=> ( ord_less @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) @ B3 ) )
& ( ~ ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ) ) ) ) ).
% psubset_insert_iff
thf(fact_2296_set__replicate__Suc,axiom,
! [A: $tType,N2: nat,X: A] :
( ( set2 @ A @ ( replicate @ A @ ( suc @ N2 ) @ X ) )
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ).
% set_replicate_Suc
thf(fact_2297_set__replicate__conv__if,axiom,
! [A: $tType,N2: nat,X: A] :
( ( ( N2
= ( zero_zero @ nat ) )
=> ( ( set2 @ A @ ( replicate @ A @ N2 @ X ) )
= ( bot_bot @ ( set @ A ) ) ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( set2 @ A @ ( replicate @ A @ N2 @ X ) )
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% set_replicate_conv_if
thf(fact_2298_sum_OSuc__reindex__ivl,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) @ ( G @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( G @ M )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ) ) ).
% sum.Suc_reindex_ivl
thf(fact_2299_sum__Suc__diff,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [M: nat,N2: nat,F2: nat > A] :
( ( ord_less_eq @ nat @ M @ ( suc @ N2 ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( minus_minus @ A @ ( F2 @ ( suc @ I5 ) ) @ ( F2 @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( minus_minus @ A @ ( F2 @ ( suc @ N2 ) ) @ ( F2 @ M ) ) ) ) ) ).
% sum_Suc_diff
thf(fact_2300_exp__eq__0__imp__not__bit,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [N2: nat,A3: A] :
( ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 )
= ( zero_zero @ A ) )
=> ~ ( bit_se5641148757651400278ts_bit @ A @ A3 @ N2 ) ) ) ).
% exp_eq_0_imp_not_bit
thf(fact_2301_bit__Suc,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ A3 @ ( suc @ N2 ) )
= ( bit_se5641148757651400278ts_bit @ A @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ N2 ) ) ) ).
% bit_Suc
thf(fact_2302_sum__mono2,axiom,
! [A: $tType,B: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [B3: set @ B,A4: set @ B,F2: B > A] :
( ( finite_finite @ B @ B3 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ B3 )
=> ( ! [B5: B] :
( ( member2 @ B @ B5 @ ( minus_minus @ ( set @ B ) @ B3 @ A4 ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ B5 ) ) )
=> ( ord_less_eq @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ B3 ) ) ) ) ) ) ).
% sum_mono2
thf(fact_2303_ceiling__correct,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less @ A @ ( minus_minus @ A @ ( ring_1_of_int @ A @ ( archimedean_ceiling @ A @ X ) ) @ ( one_one @ A ) ) @ X )
& ( ord_less_eq @ A @ X @ ( ring_1_of_int @ A @ ( archimedean_ceiling @ A @ X ) ) ) ) ) ).
% ceiling_correct
thf(fact_2304_ceiling__unique,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Z: int,X: A] :
( ( ord_less @ A @ ( minus_minus @ A @ ( ring_1_of_int @ A @ Z ) @ ( one_one @ A ) ) @ X )
=> ( ( ord_less_eq @ A @ X @ ( ring_1_of_int @ A @ Z ) )
=> ( ( archimedean_ceiling @ A @ X )
= Z ) ) ) ) ).
% ceiling_unique
thf(fact_2305_ceiling__eq__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,A3: int] :
( ( ( archimedean_ceiling @ A @ X )
= A3 )
= ( ( ord_less @ A @ ( minus_minus @ A @ ( ring_1_of_int @ A @ A3 ) @ ( one_one @ A ) ) @ X )
& ( ord_less_eq @ A @ X @ ( ring_1_of_int @ A @ A3 ) ) ) ) ) ).
% ceiling_eq_iff
thf(fact_2306_ceiling__split,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [P2: int > $o,T2: A] :
( ( P2 @ ( archimedean_ceiling @ A @ T2 ) )
= ( ! [I5: int] :
( ( ( ord_less @ A @ ( minus_minus @ A @ ( ring_1_of_int @ A @ I5 ) @ ( one_one @ A ) ) @ T2 )
& ( ord_less_eq @ A @ T2 @ ( ring_1_of_int @ A @ I5 ) ) )
=> ( P2 @ I5 ) ) ) ) ) ).
% ceiling_split
thf(fact_2307_mult__ceiling__le,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less_eq @ int @ ( archimedean_ceiling @ A @ ( times_times @ A @ A3 @ B2 ) ) @ ( times_times @ int @ ( archimedean_ceiling @ A @ A3 ) @ ( archimedean_ceiling @ A @ B2 ) ) ) ) ) ) ).
% mult_ceiling_le
thf(fact_2308_ceiling__less__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Z: int] :
( ( ord_less @ int @ ( archimedean_ceiling @ A @ X ) @ Z )
= ( ord_less_eq @ A @ X @ ( minus_minus @ A @ ( ring_1_of_int @ A @ Z ) @ ( one_one @ A ) ) ) ) ) ).
% ceiling_less_iff
thf(fact_2309_le__ceiling__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Z: int,X: A] :
( ( ord_less_eq @ int @ Z @ ( archimedean_ceiling @ A @ X ) )
= ( ord_less @ A @ ( minus_minus @ A @ ( ring_1_of_int @ A @ Z ) @ ( one_one @ A ) ) @ X ) ) ) ).
% le_ceiling_iff
thf(fact_2310_int__bit__bound,axiom,
! [K: int] :
~ ! [N3: nat] :
( ! [M4: nat] :
( ( ord_less_eq @ nat @ N3 @ M4 )
=> ( ( bit_se5641148757651400278ts_bit @ int @ K @ M4 )
= ( bit_se5641148757651400278ts_bit @ int @ K @ N3 ) ) )
=> ~ ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 )
=> ( ( bit_se5641148757651400278ts_bit @ int @ K @ ( minus_minus @ nat @ N3 @ ( one_one @ nat ) ) )
= ( ~ ( bit_se5641148757651400278ts_bit @ int @ K @ N3 ) ) ) ) ) ).
% int_bit_bound
thf(fact_2311_sum_Oub__add__nat,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [M: nat,N2: nat,G: nat > A,P4: nat] :
( ( ord_less_eq @ nat @ M @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ ( plus_plus @ nat @ N2 @ P4 ) ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) @ ( plus_plus @ nat @ N2 @ P4 ) ) ) ) ) ) ) ).
% sum.ub_add_nat
thf(fact_2312_sum__count__set,axiom,
! [A: $tType,Xs: list @ A,X7: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs ) @ X7 )
=> ( ( finite_finite @ A @ X7 )
=> ( ( groups7311177749621191930dd_sum @ A @ nat @ ( count_list @ A @ Xs ) @ X7 )
= ( size_size @ ( list @ A ) @ Xs ) ) ) ) ).
% sum_count_set
thf(fact_2313_sum__strict__mono2,axiom,
! [B: $tType,A: $tType] :
( ( ordere8940638589300402666id_add @ B )
=> ! [B3: set @ A,A4: set @ A,B2: A,F2: A > B] :
( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( member2 @ A @ B2 @ ( minus_minus @ ( set @ A ) @ B3 @ A4 ) )
=> ( ( ord_less @ B @ ( zero_zero @ B ) @ ( F2 @ B2 ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ B3 )
=> ( ord_less_eq @ B @ ( zero_zero @ B ) @ ( F2 @ X5 ) ) )
=> ( ord_less @ B @ ( groups7311177749621191930dd_sum @ A @ B @ F2 @ A4 ) @ ( groups7311177749621191930dd_sum @ A @ B @ F2 @ B3 ) ) ) ) ) ) ) ) ).
% sum_strict_mono2
thf(fact_2314_ceiling__divide__upper,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Q2: A,P4: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Q2 )
=> ( ord_less_eq @ A @ P4 @ ( times_times @ A @ ( ring_1_of_int @ A @ ( archimedean_ceiling @ A @ ( divide_divide @ A @ P4 @ Q2 ) ) ) @ Q2 ) ) ) ) ).
% ceiling_divide_upper
thf(fact_2315_Suc__mask__eq__exp,axiom,
! [N2: nat] :
( ( suc @ ( bit_se2239418461657761734s_mask @ nat @ N2 ) )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ).
% Suc_mask_eq_exp
thf(fact_2316_mask__nat__less__exp,axiom,
! [N2: nat] : ( ord_less @ nat @ ( bit_se2239418461657761734s_mask @ nat @ N2 ) @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ).
% mask_nat_less_exp
thf(fact_2317_sum__natinterval__diff,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [M: nat,N2: nat,F2: nat > A] :
( ( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( minus_minus @ A @ ( F2 @ K2 ) @ ( F2 @ ( plus_plus @ nat @ K2 @ ( one_one @ nat ) ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( minus_minus @ A @ ( F2 @ M ) @ ( F2 @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) ) ) ) )
& ( ~ ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( minus_minus @ A @ ( F2 @ K2 ) @ ( F2 @ ( plus_plus @ nat @ K2 @ ( one_one @ nat ) ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( zero_zero @ A ) ) ) ) ) ).
% sum_natinterval_diff
thf(fact_2318_sum__telescope_H_H,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [M: nat,N2: nat,F2: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( minus_minus @ A @ ( F2 @ K2 ) @ ( F2 @ ( minus_minus @ nat @ K2 @ ( one_one @ nat ) ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ N2 ) )
= ( minus_minus @ A @ ( F2 @ N2 ) @ ( F2 @ M ) ) ) ) ) ).
% sum_telescope''
thf(fact_2319_semiring__bit__operations__class_Oeven__mask__iff,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se2239418461657761734s_mask @ A @ N2 ) )
= ( N2
= ( zero_zero @ nat ) ) ) ) ).
% semiring_bit_operations_class.even_mask_iff
thf(fact_2320_even__bit__succ__iff,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,N2: nat] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( bit_se5641148757651400278ts_bit @ A @ ( plus_plus @ A @ ( one_one @ A ) @ A3 ) @ N2 )
= ( ( bit_se5641148757651400278ts_bit @ A @ A3 @ N2 )
| ( N2
= ( zero_zero @ nat ) ) ) ) ) ) ).
% even_bit_succ_iff
thf(fact_2321_odd__bit__iff__bit__pred,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,N2: nat] :
( ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 )
=> ( ( bit_se5641148757651400278ts_bit @ A @ A3 @ N2 )
= ( ( bit_se5641148757651400278ts_bit @ A @ ( minus_minus @ A @ A3 @ ( one_one @ A ) ) @ N2 )
| ( N2
= ( zero_zero @ nat ) ) ) ) ) ) ).
% odd_bit_iff_bit_pred
thf(fact_2322_set__decode__plus__power__2,axiom,
! [N2: nat,Z: nat] :
( ~ ( member2 @ nat @ N2 @ ( nat_set_decode @ Z ) )
=> ( ( nat_set_decode @ ( plus_plus @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ Z ) )
= ( insert2 @ nat @ N2 @ ( nat_set_decode @ Z ) ) ) ) ).
% set_decode_plus_power_2
thf(fact_2323_ceiling__divide__lower,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Q2: A,P4: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Q2 )
=> ( ord_less @ A @ ( times_times @ A @ ( minus_minus @ A @ ( ring_1_of_int @ A @ ( archimedean_ceiling @ A @ ( divide_divide @ A @ P4 @ Q2 ) ) ) @ ( one_one @ A ) ) @ Q2 ) @ P4 ) ) ) ).
% ceiling_divide_lower
thf(fact_2324_ceiling__eq,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [N2: int,X: A] :
( ( ord_less @ A @ ( ring_1_of_int @ A @ N2 ) @ X )
=> ( ( ord_less_eq @ A @ X @ ( plus_plus @ A @ ( ring_1_of_int @ A @ N2 ) @ ( one_one @ A ) ) )
=> ( ( archimedean_ceiling @ A @ X )
= ( plus_plus @ int @ N2 @ ( one_one @ int ) ) ) ) ) ) ).
% ceiling_eq
thf(fact_2325_mask__eq__sum__exp,axiom,
! [A: $tType] :
( ( semiring_parity @ A )
=> ! [N2: nat] :
( ( minus_minus @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) @ ( one_one @ A ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) )
@ ( collect @ nat
@ ^ [Q5: nat] : ( ord_less @ nat @ Q5 @ N2 ) ) ) ) ) ).
% mask_eq_sum_exp
thf(fact_2326_sum__gp__multiplied,axiom,
! [A: $tType] :
( ( ( monoid_mult @ A )
& ( comm_ring @ A ) )
=> ! [M: nat,N2: nat,X: A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( times_times @ A @ ( minus_minus @ A @ ( one_one @ A ) @ X ) @ ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) )
= ( minus_minus @ A @ ( power_power @ A @ X @ M ) @ ( power_power @ A @ X @ ( suc @ N2 ) ) ) ) ) ) ).
% sum_gp_multiplied
thf(fact_2327_sum_Oin__pairs,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( plus_plus @ A @ ( G @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) ) @ ( G @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% sum.in_pairs
thf(fact_2328_bit__sum__mult__2__cases,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A,B2: A,N2: nat] :
( ! [J2: nat] :
~ ( bit_se5641148757651400278ts_bit @ A @ A3 @ ( suc @ J2 ) )
=> ( ( bit_se5641148757651400278ts_bit @ A @ ( plus_plus @ A @ A3 @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) ) @ N2 )
= ( ( ( N2
= ( zero_zero @ nat ) )
=> ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( bit_se5641148757651400278ts_bit @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ B2 ) @ N2 ) ) ) ) ) ) ).
% bit_sum_mult_2_cases
thf(fact_2329_bit__rec,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ( ( bit_se5641148757651400278ts_bit @ A )
= ( ^ [A5: A,N: nat] :
( ( ( N
= ( zero_zero @ nat ) )
=> ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A5 ) )
& ( ( N
!= ( zero_zero @ nat ) )
=> ( bit_se5641148757651400278ts_bit @ A @ ( divide_divide @ A @ A5 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( minus_minus @ nat @ N @ ( one_one @ nat ) ) ) ) ) ) ) ) ).
% bit_rec
thf(fact_2330_mask__eq__sum__exp__nat,axiom,
! [N2: nat] :
( ( minus_minus @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ ( suc @ ( zero_zero @ nat ) ) )
= ( groups7311177749621191930dd_sum @ nat @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
@ ( collect @ nat
@ ^ [Q5: nat] : ( ord_less @ nat @ Q5 @ N2 ) ) ) ) ).
% mask_eq_sum_exp_nat
thf(fact_2331_gauss__sum__nat,axiom,
! [N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [X2: nat] : X2
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) )
= ( divide_divide @ nat @ ( times_times @ nat @ N2 @ ( suc @ N2 ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ).
% gauss_sum_nat
thf(fact_2332_take__bit__Suc__from__most,axiom,
! [N2: nat,K: int] :
( ( bit_se2584673776208193580ke_bit @ int @ ( suc @ N2 ) @ K )
= ( plus_plus @ int @ ( times_times @ int @ ( power_power @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ N2 ) @ ( zero_neq_one_of_bool @ int @ ( bit_se5641148757651400278ts_bit @ int @ K @ N2 ) ) ) @ ( bit_se2584673776208193580ke_bit @ int @ N2 @ K ) ) ) ).
% take_bit_Suc_from_most
thf(fact_2333_sum__gp,axiom,
! [A: $tType] :
( ( ( division_ring @ A )
& ( comm_ring @ A ) )
=> ! [N2: nat,M: nat,X: A] :
( ( ( ord_less @ nat @ N2 @ M )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( zero_zero @ A ) ) )
& ( ~ ( ord_less @ nat @ N2 @ M )
=> ( ( ( X
= ( one_one @ A ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( semiring_1_of_nat @ A @ ( minus_minus @ nat @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) @ M ) ) ) )
& ( ( X
!= ( one_one @ A ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( divide_divide @ A @ ( minus_minus @ A @ ( power_power @ A @ X @ M ) @ ( power_power @ A @ X @ ( suc @ N2 ) ) ) @ ( minus_minus @ A @ ( one_one @ A ) @ X ) ) ) ) ) ) ) ) ).
% sum_gp
thf(fact_2334_gauss__sum__from__Suc__0,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ ( semiring_1_of_nat @ A ) @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 ) )
= ( divide_divide @ A @ ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( plus_plus @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( one_one @ A ) ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% gauss_sum_from_Suc_0
thf(fact_2335_sum__gp__offset,axiom,
! [A: $tType] :
( ( ( division_ring @ A )
& ( comm_ring @ A ) )
=> ! [X: A,M: nat,N2: nat] :
( ( ( X
= ( one_one @ A ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ ( set_or1337092689740270186AtMost @ nat @ M @ ( plus_plus @ nat @ M @ N2 ) ) )
= ( plus_plus @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( one_one @ A ) ) ) )
& ( ( X
!= ( one_one @ A ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ ( set_or1337092689740270186AtMost @ nat @ M @ ( plus_plus @ nat @ M @ N2 ) ) )
= ( divide_divide @ A @ ( times_times @ A @ ( power_power @ A @ X @ M ) @ ( minus_minus @ A @ ( one_one @ A ) @ ( power_power @ A @ X @ ( suc @ N2 ) ) ) ) @ ( minus_minus @ A @ ( one_one @ A ) @ X ) ) ) ) ) ) ).
% sum_gp_offset
thf(fact_2336_double__gauss__sum__from__Suc__0,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [N2: nat] :
( ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( groups7311177749621191930dd_sum @ nat @ A @ ( semiring_1_of_nat @ A ) @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 ) ) )
= ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( plus_plus @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( one_one @ A ) ) ) ) ) ).
% double_gauss_sum_from_Suc_0
thf(fact_2337_arith__series,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [A3: A,D2: A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( plus_plus @ A @ A3 @ ( times_times @ A @ ( semiring_1_of_nat @ A @ I5 ) @ D2 ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) )
= ( divide_divide @ A @ ( times_times @ A @ ( plus_plus @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( one_one @ A ) ) @ ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) @ ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 ) @ D2 ) ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% arith_series
thf(fact_2338_gauss__sum,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ ( semiring_1_of_nat @ A ) @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) )
= ( divide_divide @ A @ ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( plus_plus @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( one_one @ A ) ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% gauss_sum
thf(fact_2339_double__gauss__sum,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [N2: nat] :
( ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( groups7311177749621191930dd_sum @ nat @ A @ ( semiring_1_of_nat @ A ) @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) ) )
= ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( plus_plus @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( one_one @ A ) ) ) ) ) ).
% double_gauss_sum
thf(fact_2340_of__nat__eq__iff,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ! [M: nat,N2: nat] :
( ( ( semiring_1_of_nat @ A @ M )
= ( semiring_1_of_nat @ A @ N2 ) )
= ( M = N2 ) ) ) ).
% of_nat_eq_iff
thf(fact_2341_numeral__le__real__of__nat__iff,axiom,
! [N2: num,M: nat] :
( ( ord_less_eq @ real @ ( numeral_numeral @ real @ N2 ) @ ( semiring_1_of_nat @ real @ M ) )
= ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ N2 ) @ M ) ) ).
% numeral_le_real_of_nat_iff
thf(fact_2342_int__eq__iff__numeral,axiom,
! [M: nat,V2: num] :
( ( ( semiring_1_of_nat @ int @ M )
= ( numeral_numeral @ int @ V2 ) )
= ( M
= ( numeral_numeral @ nat @ V2 ) ) ) ).
% int_eq_iff_numeral
thf(fact_2343_negative__eq__positive,axiom,
! [N2: nat,M: nat] :
( ( ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ N2 ) )
= ( semiring_1_of_nat @ int @ M ) )
= ( ( N2
= ( zero_zero @ nat ) )
& ( M
= ( zero_zero @ nat ) ) ) ) ).
% negative_eq_positive
thf(fact_2344_of__int__of__nat__eq,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [N2: nat] :
( ( ring_1_of_int @ A @ ( semiring_1_of_nat @ int @ N2 ) )
= ( semiring_1_of_nat @ A @ N2 ) ) ) ).
% of_int_of_nat_eq
thf(fact_2345_negative__zle,axiom,
! [N2: nat,M: nat] : ( ord_less_eq @ int @ ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ N2 ) ) @ ( semiring_1_of_nat @ int @ M ) ) ).
% negative_zle
thf(fact_2346_int__dvd__int__iff,axiom,
! [M: nat,N2: nat] :
( ( dvd_dvd @ int @ ( semiring_1_of_nat @ int @ M ) @ ( semiring_1_of_nat @ int @ N2 ) )
= ( dvd_dvd @ nat @ M @ N2 ) ) ).
% int_dvd_int_iff
thf(fact_2347_of__nat__eq__0__iff,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ! [M: nat] :
( ( ( semiring_1_of_nat @ A @ M )
= ( zero_zero @ A ) )
= ( M
= ( zero_zero @ nat ) ) ) ) ).
% of_nat_eq_0_iff
thf(fact_2348_of__nat__0__eq__iff,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ! [N2: nat] :
( ( ( zero_zero @ A )
= ( semiring_1_of_nat @ A @ N2 ) )
= ( ( zero_zero @ nat )
= N2 ) ) ) ).
% of_nat_0_eq_iff
thf(fact_2349_of__nat__0,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( semiring_1_of_nat @ A @ ( zero_zero @ nat ) )
= ( zero_zero @ A ) ) ) ).
% of_nat_0
thf(fact_2350_of__nat__less__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [M: nat,N2: nat] :
( ( ord_less @ A @ ( semiring_1_of_nat @ A @ M ) @ ( semiring_1_of_nat @ A @ N2 ) )
= ( ord_less @ nat @ M @ N2 ) ) ) ).
% of_nat_less_iff
thf(fact_2351_of__nat__le__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [M: nat,N2: nat] :
( ( ord_less_eq @ A @ ( semiring_1_of_nat @ A @ M ) @ ( semiring_1_of_nat @ A @ N2 ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ) ).
% of_nat_le_iff
thf(fact_2352_real__of__nat__less__numeral__iff,axiom,
! [N2: nat,W2: num] :
( ( ord_less @ real @ ( semiring_1_of_nat @ real @ N2 ) @ ( numeral_numeral @ real @ W2 ) )
= ( ord_less @ nat @ N2 @ ( numeral_numeral @ nat @ W2 ) ) ) ).
% real_of_nat_less_numeral_iff
thf(fact_2353_numeral__less__real__of__nat__iff,axiom,
! [W2: num,N2: nat] :
( ( ord_less @ real @ ( numeral_numeral @ real @ W2 ) @ ( semiring_1_of_nat @ real @ N2 ) )
= ( ord_less @ nat @ ( numeral_numeral @ nat @ W2 ) @ N2 ) ) ).
% numeral_less_real_of_nat_iff
thf(fact_2354_of__nat__add,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [M: nat,N2: nat] :
( ( semiring_1_of_nat @ A @ ( plus_plus @ nat @ M @ N2 ) )
= ( plus_plus @ A @ ( semiring_1_of_nat @ A @ M ) @ ( semiring_1_of_nat @ A @ N2 ) ) ) ) ).
% of_nat_add
thf(fact_2355_of__nat__mult,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [M: nat,N2: nat] :
( ( semiring_1_of_nat @ A @ ( times_times @ nat @ M @ N2 ) )
= ( times_times @ A @ ( semiring_1_of_nat @ A @ M ) @ ( semiring_1_of_nat @ A @ N2 ) ) ) ) ).
% of_nat_mult
thf(fact_2356_of__nat__1,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( semiring_1_of_nat @ A @ ( one_one @ nat ) )
= ( one_one @ A ) ) ) ).
% of_nat_1
thf(fact_2357_of__nat__1__eq__iff,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ! [N2: nat] :
( ( ( one_one @ A )
= ( semiring_1_of_nat @ A @ N2 ) )
= ( N2
= ( one_one @ nat ) ) ) ) ).
% of_nat_1_eq_iff
thf(fact_2358_of__nat__eq__1__iff,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ! [N2: nat] :
( ( ( semiring_1_of_nat @ A @ N2 )
= ( one_one @ A ) )
= ( N2
= ( one_one @ nat ) ) ) ) ).
% of_nat_eq_1_iff
thf(fact_2359_negative__zless,axiom,
! [N2: nat,M: nat] : ( ord_less @ int @ ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ ( suc @ N2 ) ) ) @ ( semiring_1_of_nat @ int @ M ) ) ).
% negative_zless
thf(fact_2360_of__nat__of__bool,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [P2: $o] :
( ( semiring_1_of_nat @ A @ ( zero_neq_one_of_bool @ nat @ P2 ) )
= ( zero_neq_one_of_bool @ A @ P2 ) ) ) ).
% of_nat_of_bool
thf(fact_2361_of__nat__sum,axiom,
! [A: $tType,B: $tType] :
( ( semiring_1 @ A )
=> ! [F2: B > nat,A4: set @ B] :
( ( semiring_1_of_nat @ A @ ( groups7311177749621191930dd_sum @ B @ nat @ F2 @ A4 ) )
= ( groups7311177749621191930dd_sum @ B @ A
@ ^ [X2: B] : ( semiring_1_of_nat @ A @ ( F2 @ X2 ) )
@ A4 ) ) ) ).
% of_nat_sum
thf(fact_2362_of__nat__le__0__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [M: nat] :
( ( ord_less_eq @ A @ ( semiring_1_of_nat @ A @ M ) @ ( zero_zero @ A ) )
= ( M
= ( zero_zero @ nat ) ) ) ) ).
% of_nat_le_0_iff
thf(fact_2363_of__nat__Suc,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [M: nat] :
( ( semiring_1_of_nat @ A @ ( suc @ M ) )
= ( plus_plus @ A @ ( one_one @ A ) @ ( semiring_1_of_nat @ A @ M ) ) ) ) ).
% of_nat_Suc
thf(fact_2364_of__nat__0__less__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [N2: nat] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( semiring_1_of_nat @ A @ N2 ) )
= ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ).
% of_nat_0_less_iff
thf(fact_2365_of__nat__power__less__of__nat__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [X: nat,B2: nat,W2: nat] :
( ( ord_less @ A @ ( semiring_1_of_nat @ A @ X ) @ ( power_power @ A @ ( semiring_1_of_nat @ A @ B2 ) @ W2 ) )
= ( ord_less @ nat @ X @ ( power_power @ nat @ B2 @ W2 ) ) ) ) ).
% of_nat_power_less_of_nat_cancel_iff
thf(fact_2366_of__nat__less__of__nat__power__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [B2: nat,W2: nat,X: nat] :
( ( ord_less @ A @ ( power_power @ A @ ( semiring_1_of_nat @ A @ B2 ) @ W2 ) @ ( semiring_1_of_nat @ A @ X ) )
= ( ord_less @ nat @ ( power_power @ nat @ B2 @ W2 ) @ X ) ) ) ).
% of_nat_less_of_nat_power_cancel_iff
thf(fact_2367_of__nat__le__of__nat__power__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [B2: nat,W2: nat,X: nat] :
( ( ord_less_eq @ A @ ( power_power @ A @ ( semiring_1_of_nat @ A @ B2 ) @ W2 ) @ ( semiring_1_of_nat @ A @ X ) )
= ( ord_less_eq @ nat @ ( power_power @ nat @ B2 @ W2 ) @ X ) ) ) ).
% of_nat_le_of_nat_power_cancel_iff
thf(fact_2368_of__nat__power__le__of__nat__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [X: nat,B2: nat,W2: nat] :
( ( ord_less_eq @ A @ ( semiring_1_of_nat @ A @ X ) @ ( power_power @ A @ ( semiring_1_of_nat @ A @ B2 ) @ W2 ) )
= ( ord_less_eq @ nat @ X @ ( power_power @ nat @ B2 @ W2 ) ) ) ) ).
% of_nat_power_le_of_nat_cancel_iff
thf(fact_2369_of__nat__zero__less__power__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [X: nat,N2: nat] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( power_power @ A @ ( semiring_1_of_nat @ A @ X ) @ N2 ) )
= ( ( ord_less @ nat @ ( zero_zero @ nat ) @ X )
| ( N2
= ( zero_zero @ nat ) ) ) ) ) ).
% of_nat_zero_less_power_iff
thf(fact_2370_numeral__power__less__of__nat__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [I: num,N2: nat,X: nat] :
( ( ord_less @ A @ ( power_power @ A @ ( numeral_numeral @ A @ I ) @ N2 ) @ ( semiring_1_of_nat @ A @ X ) )
= ( ord_less @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ I ) @ N2 ) @ X ) ) ) ).
% numeral_power_less_of_nat_cancel_iff
thf(fact_2371_of__nat__less__numeral__power__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [X: nat,I: num,N2: nat] :
( ( ord_less @ A @ ( semiring_1_of_nat @ A @ X ) @ ( power_power @ A @ ( numeral_numeral @ A @ I ) @ N2 ) )
= ( ord_less @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ I ) @ N2 ) ) ) ) ).
% of_nat_less_numeral_power_cancel_iff
thf(fact_2372_numeral__power__le__of__nat__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [I: num,N2: nat,X: nat] :
( ( ord_less_eq @ A @ ( power_power @ A @ ( numeral_numeral @ A @ I ) @ N2 ) @ ( semiring_1_of_nat @ A @ X ) )
= ( ord_less_eq @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ I ) @ N2 ) @ X ) ) ) ).
% numeral_power_le_of_nat_cancel_iff
thf(fact_2373_of__nat__le__numeral__power__cancel__iff,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [X: nat,I: num,N2: nat] :
( ( ord_less_eq @ A @ ( semiring_1_of_nat @ A @ X ) @ ( power_power @ A @ ( numeral_numeral @ A @ I ) @ N2 ) )
= ( ord_less_eq @ nat @ X @ ( power_power @ nat @ ( numeral_numeral @ nat @ I ) @ N2 ) ) ) ) ).
% of_nat_le_numeral_power_cancel_iff
thf(fact_2374_int__sum,axiom,
! [B: $tType,F2: B > nat,A4: set @ B] :
( ( semiring_1_of_nat @ int @ ( groups7311177749621191930dd_sum @ B @ nat @ F2 @ A4 ) )
= ( groups7311177749621191930dd_sum @ B @ int
@ ^ [X2: B] : ( semiring_1_of_nat @ int @ ( F2 @ X2 ) )
@ A4 ) ) ).
% int_sum
thf(fact_2375_real__arch__simple,axiom,
! [A: $tType] :
( ( archim462609752435547400_field @ A )
=> ! [X: A] :
? [N3: nat] : ( ord_less_eq @ A @ X @ ( semiring_1_of_nat @ A @ N3 ) ) ) ).
% real_arch_simple
thf(fact_2376_reals__Archimedean2,axiom,
! [A: $tType] :
( ( archim462609752435547400_field @ A )
=> ! [X: A] :
? [N3: nat] : ( ord_less @ A @ X @ ( semiring_1_of_nat @ A @ N3 ) ) ) ).
% reals_Archimedean2
thf(fact_2377_mult__of__nat__commute,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [X: nat,Y: A] :
( ( times_times @ A @ ( semiring_1_of_nat @ A @ X ) @ Y )
= ( times_times @ A @ Y @ ( semiring_1_of_nat @ A @ X ) ) ) ) ).
% mult_of_nat_commute
thf(fact_2378_nat__less__real__le,axiom,
( ( ord_less @ nat )
= ( ^ [N: nat,M2: nat] : ( ord_less_eq @ real @ ( plus_plus @ real @ ( semiring_1_of_nat @ real @ N ) @ ( one_one @ real ) ) @ ( semiring_1_of_nat @ real @ M2 ) ) ) ) ).
% nat_less_real_le
thf(fact_2379_int__cases2,axiom,
! [Z: int] :
( ! [N3: nat] :
( Z
!= ( semiring_1_of_nat @ int @ N3 ) )
=> ~ ! [N3: nat] :
( Z
!= ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ N3 ) ) ) ) ).
% int_cases2
thf(fact_2380_int__diff__cases,axiom,
! [Z: int] :
~ ! [M3: nat,N3: nat] :
( Z
!= ( minus_minus @ int @ ( semiring_1_of_nat @ int @ M3 ) @ ( semiring_1_of_nat @ int @ N3 ) ) ) ).
% int_diff_cases
thf(fact_2381_of__nat__less__of__int__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: nat,X: int] :
( ( ord_less @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( ring_1_of_int @ A @ X ) )
= ( ord_less @ int @ ( semiring_1_of_nat @ int @ N2 ) @ X ) ) ) ).
% of_nat_less_of_int_iff
thf(fact_2382_not__bit__Suc__0__Suc,axiom,
! [N2: nat] :
~ ( bit_se5641148757651400278ts_bit @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( suc @ N2 ) ) ).
% not_bit_Suc_0_Suc
thf(fact_2383_bit__Suc__0__iff,axiom,
! [N2: nat] :
( ( bit_se5641148757651400278ts_bit @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
= ( N2
= ( zero_zero @ nat ) ) ) ).
% bit_Suc_0_iff
thf(fact_2384_of__nat__0__le__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [N2: nat] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( semiring_1_of_nat @ A @ N2 ) ) ) ).
% of_nat_0_le_iff
thf(fact_2385_of__nat__less__0__iff,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [M: nat] :
~ ( ord_less @ A @ ( semiring_1_of_nat @ A @ M ) @ ( zero_zero @ A ) ) ) ).
% of_nat_less_0_iff
thf(fact_2386_of__nat__neq__0,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ! [N2: nat] :
( ( semiring_1_of_nat @ A @ ( suc @ N2 ) )
!= ( zero_zero @ A ) ) ) ).
% of_nat_neq_0
thf(fact_2387_of__nat__less__imp__less,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [M: nat,N2: nat] :
( ( ord_less @ A @ ( semiring_1_of_nat @ A @ M ) @ ( semiring_1_of_nat @ A @ N2 ) )
=> ( ord_less @ nat @ M @ N2 ) ) ) ).
% of_nat_less_imp_less
thf(fact_2388_less__imp__of__nat__less,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ N2 )
=> ( ord_less @ A @ ( semiring_1_of_nat @ A @ M ) @ ( semiring_1_of_nat @ A @ N2 ) ) ) ) ).
% less_imp_of_nat_less
thf(fact_2389_of__nat__mono,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [I: nat,J: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ord_less_eq @ A @ ( semiring_1_of_nat @ A @ I ) @ ( semiring_1_of_nat @ A @ J ) ) ) ) ).
% of_nat_mono
thf(fact_2390_nat__le__real__less,axiom,
( ( ord_less_eq @ nat )
= ( ^ [N: nat,M2: nat] : ( ord_less @ real @ ( semiring_1_of_nat @ real @ N ) @ ( plus_plus @ real @ ( semiring_1_of_nat @ real @ M2 ) @ ( one_one @ real ) ) ) ) ) ).
% nat_le_real_less
thf(fact_2391_int__ops_I1_J,axiom,
( ( semiring_1_of_nat @ int @ ( zero_zero @ nat ) )
= ( zero_zero @ int ) ) ).
% int_ops(1)
thf(fact_2392_nat__int__comparison_I2_J,axiom,
( ( ord_less @ nat )
= ( ^ [A5: nat,B4: nat] : ( ord_less @ int @ ( semiring_1_of_nat @ int @ A5 ) @ ( semiring_1_of_nat @ int @ B4 ) ) ) ) ).
% nat_int_comparison(2)
thf(fact_2393_int__cases,axiom,
! [Z: int] :
( ! [N3: nat] :
( Z
!= ( semiring_1_of_nat @ int @ N3 ) )
=> ~ ! [N3: nat] :
( Z
!= ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ ( suc @ N3 ) ) ) ) ) ).
% int_cases
thf(fact_2394_int__of__nat__induct,axiom,
! [P2: int > $o,Z: int] :
( ! [N3: nat] : ( P2 @ ( semiring_1_of_nat @ int @ N3 ) )
=> ( ! [N3: nat] : ( P2 @ ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ ( suc @ N3 ) ) ) )
=> ( P2 @ Z ) ) ) ).
% int_of_nat_induct
thf(fact_2395_zle__int,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ int @ ( semiring_1_of_nat @ int @ M ) @ ( semiring_1_of_nat @ int @ N2 ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ).
% zle_int
thf(fact_2396_nat__int__comparison_I3_J,axiom,
( ( ord_less_eq @ nat )
= ( ^ [A5: nat,B4: nat] : ( ord_less_eq @ int @ ( semiring_1_of_nat @ int @ A5 ) @ ( semiring_1_of_nat @ int @ B4 ) ) ) ) ).
% nat_int_comparison(3)
thf(fact_2397_zero__le__imp__eq__int,axiom,
! [K: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ K )
=> ? [N3: nat] :
( K
= ( semiring_1_of_nat @ int @ N3 ) ) ) ).
% zero_le_imp_eq_int
thf(fact_2398_nonneg__int__cases,axiom,
! [K: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ K )
=> ~ ! [N3: nat] :
( K
!= ( semiring_1_of_nat @ int @ N3 ) ) ) ).
% nonneg_int_cases
thf(fact_2399_zadd__int__left,axiom,
! [M: nat,N2: nat,Z: int] :
( ( plus_plus @ int @ ( semiring_1_of_nat @ int @ M ) @ ( plus_plus @ int @ ( semiring_1_of_nat @ int @ N2 ) @ Z ) )
= ( plus_plus @ int @ ( semiring_1_of_nat @ int @ ( plus_plus @ nat @ M @ N2 ) ) @ Z ) ) ).
% zadd_int_left
thf(fact_2400_int__ops_I5_J,axiom,
! [A3: nat,B2: nat] :
( ( semiring_1_of_nat @ int @ ( plus_plus @ nat @ A3 @ B2 ) )
= ( plus_plus @ int @ ( semiring_1_of_nat @ int @ A3 ) @ ( semiring_1_of_nat @ int @ B2 ) ) ) ).
% int_ops(5)
thf(fact_2401_int__plus,axiom,
! [N2: nat,M: nat] :
( ( semiring_1_of_nat @ int @ ( plus_plus @ nat @ N2 @ M ) )
= ( plus_plus @ int @ ( semiring_1_of_nat @ int @ N2 ) @ ( semiring_1_of_nat @ int @ M ) ) ) ).
% int_plus
thf(fact_2402_zle__iff__zadd,axiom,
( ( ord_less_eq @ int )
= ( ^ [W3: int,Z6: int] :
? [N: nat] :
( Z6
= ( plus_plus @ int @ W3 @ ( semiring_1_of_nat @ int @ N ) ) ) ) ) ).
% zle_iff_zadd
thf(fact_2403_not__int__zless__negative,axiom,
! [N2: nat,M: nat] :
~ ( ord_less @ int @ ( semiring_1_of_nat @ int @ N2 ) @ ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ M ) ) ) ).
% not_int_zless_negative
thf(fact_2404_of__nat__max,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [X: nat,Y: nat] :
( ( semiring_1_of_nat @ A @ ( ord_max @ nat @ X @ Y ) )
= ( ord_max @ A @ ( semiring_1_of_nat @ A @ X ) @ ( semiring_1_of_nat @ A @ Y ) ) ) ) ).
% of_nat_max
thf(fact_2405_nat__less__as__int,axiom,
( ( ord_less @ nat )
= ( ^ [A5: nat,B4: nat] : ( ord_less @ int @ ( semiring_1_of_nat @ int @ A5 ) @ ( semiring_1_of_nat @ int @ B4 ) ) ) ) ).
% nat_less_as_int
thf(fact_2406_nat__leq__as__int,axiom,
( ( ord_less_eq @ nat )
= ( ^ [A5: nat,B4: nat] : ( ord_less_eq @ int @ ( semiring_1_of_nat @ int @ A5 ) @ ( semiring_1_of_nat @ int @ B4 ) ) ) ) ).
% nat_leq_as_int
thf(fact_2407_not__bit__Suc__0__numeral,axiom,
! [N2: num] :
~ ( bit_se5641148757651400278ts_bit @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( numeral_numeral @ nat @ N2 ) ) ).
% not_bit_Suc_0_numeral
thf(fact_2408_ex__less__of__nat__mult,axiom,
! [A: $tType] :
( ( archim462609752435547400_field @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ X )
=> ? [N3: nat] : ( ord_less @ A @ Y @ ( times_times @ A @ ( semiring_1_of_nat @ A @ N3 ) @ X ) ) ) ) ).
% ex_less_of_nat_mult
thf(fact_2409_of__nat__diff,axiom,
! [A: $tType] :
( ( semiring_1_cancel @ A )
=> ! [N2: nat,M: nat] :
( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( semiring_1_of_nat @ A @ ( minus_minus @ nat @ M @ N2 ) )
= ( minus_minus @ A @ ( semiring_1_of_nat @ A @ M ) @ ( semiring_1_of_nat @ A @ N2 ) ) ) ) ) ).
% of_nat_diff
thf(fact_2410_real__archimedian__rdiv__eq__0,axiom,
! [X: real,C2: real] :
( ( ord_less_eq @ real @ ( zero_zero @ real ) @ X )
=> ( ( ord_less_eq @ real @ ( zero_zero @ real ) @ C2 )
=> ( ! [M3: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M3 )
=> ( ord_less_eq @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ M3 ) @ X ) @ C2 ) )
=> ( X
= ( zero_zero @ real ) ) ) ) ) ).
% real_archimedian_rdiv_eq_0
thf(fact_2411_int__cases4,axiom,
! [M: int] :
( ! [N3: nat] :
( M
!= ( semiring_1_of_nat @ int @ N3 ) )
=> ~ ! [N3: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 )
=> ( M
!= ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ N3 ) ) ) ) ) ).
% int_cases4
thf(fact_2412_int__zle__neg,axiom,
! [N2: nat,M: nat] :
( ( ord_less_eq @ int @ ( semiring_1_of_nat @ int @ N2 ) @ ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ M ) ) )
= ( ( N2
= ( zero_zero @ nat ) )
& ( M
= ( zero_zero @ nat ) ) ) ) ).
% int_zle_neg
thf(fact_2413_int__ops_I4_J,axiom,
! [A3: nat] :
( ( semiring_1_of_nat @ int @ ( suc @ A3 ) )
= ( plus_plus @ int @ ( semiring_1_of_nat @ int @ A3 ) @ ( one_one @ int ) ) ) ).
% int_ops(4)
thf(fact_2414_int__Suc,axiom,
! [N2: nat] :
( ( semiring_1_of_nat @ int @ ( suc @ N2 ) )
= ( plus_plus @ int @ ( semiring_1_of_nat @ int @ N2 ) @ ( one_one @ int ) ) ) ).
% int_Suc
thf(fact_2415_zless__iff__Suc__zadd,axiom,
( ( ord_less @ int )
= ( ^ [W3: int,Z6: int] :
? [N: nat] :
( Z6
= ( plus_plus @ int @ W3 @ ( semiring_1_of_nat @ int @ ( suc @ N ) ) ) ) ) ) ).
% zless_iff_Suc_zadd
thf(fact_2416_nonpos__int__cases,axiom,
! [K: int] :
( ( ord_less_eq @ int @ K @ ( zero_zero @ int ) )
=> ~ ! [N3: nat] :
( K
!= ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ N3 ) ) ) ) ).
% nonpos_int_cases
thf(fact_2417_negative__zle__0,axiom,
! [N2: nat] : ( ord_less_eq @ int @ ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ N2 ) ) @ ( zero_zero @ int ) ) ).
% negative_zle_0
thf(fact_2418_simp__from__to,axiom,
( ( set_or1337092689740270186AtMost @ int )
= ( ^ [I5: int,J3: int] : ( if @ ( set @ int ) @ ( ord_less @ int @ J3 @ I5 ) @ ( bot_bot @ ( set @ int ) ) @ ( insert2 @ int @ I5 @ ( set_or1337092689740270186AtMost @ int @ ( plus_plus @ int @ I5 @ ( one_one @ int ) ) @ J3 ) ) ) ) ) ).
% simp_from_to
thf(fact_2419_sum__nth__roots,axiom,
! [N2: nat,C2: complex] :
( ( ord_less @ nat @ ( one_one @ nat ) @ N2 )
=> ( ( groups7311177749621191930dd_sum @ complex @ complex
@ ^ [X2: complex] : X2
@ ( collect @ complex
@ ^ [Z6: complex] :
( ( power_power @ complex @ Z6 @ N2 )
= C2 ) ) )
= ( zero_zero @ complex ) ) ) ).
% sum_nth_roots
thf(fact_2420_sum__roots__unity,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( one_one @ nat ) @ N2 )
=> ( ( groups7311177749621191930dd_sum @ complex @ complex
@ ^ [X2: complex] : X2
@ ( collect @ complex
@ ^ [Z6: complex] :
( ( power_power @ complex @ Z6 @ N2 )
= ( one_one @ complex ) ) ) )
= ( zero_zero @ complex ) ) ) ).
% sum_roots_unity
thf(fact_2421_mod__mult2__eq_H,axiom,
! [A: $tType] :
( ( euclid5411537665997757685th_nat @ A )
=> ! [A3: A,M: nat,N2: nat] :
( ( modulo_modulo @ A @ A3 @ ( times_times @ A @ ( semiring_1_of_nat @ A @ M ) @ ( semiring_1_of_nat @ A @ N2 ) ) )
= ( plus_plus @ A @ ( times_times @ A @ ( semiring_1_of_nat @ A @ M ) @ ( modulo_modulo @ A @ ( divide_divide @ A @ A3 @ ( semiring_1_of_nat @ A @ M ) ) @ ( semiring_1_of_nat @ A @ N2 ) ) ) @ ( modulo_modulo @ A @ A3 @ ( semiring_1_of_nat @ A @ M ) ) ) ) ) ).
% mod_mult2_eq'
thf(fact_2422_zero__less__imp__eq__int,axiom,
! [K: int] :
( ( ord_less @ int @ ( zero_zero @ int ) @ K )
=> ? [N3: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 )
& ( K
= ( semiring_1_of_nat @ int @ N3 ) ) ) ) ).
% zero_less_imp_eq_int
thf(fact_2423_pos__int__cases,axiom,
! [K: int] :
( ( ord_less @ int @ ( zero_zero @ int ) @ K )
=> ~ ! [N3: nat] :
( ( K
= ( semiring_1_of_nat @ int @ N3 ) )
=> ~ ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 ) ) ) ).
% pos_int_cases
thf(fact_2424_int__cases3,axiom,
! [K: int] :
( ( K
!= ( zero_zero @ int ) )
=> ( ! [N3: nat] :
( ( K
= ( semiring_1_of_nat @ int @ N3 ) )
=> ~ ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 ) )
=> ~ ! [N3: nat] :
( ( K
= ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ N3 ) ) )
=> ~ ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 ) ) ) ) ).
% int_cases3
thf(fact_2425_zmult__zless__mono2__lemma,axiom,
! [I: int,J: int,K: nat] :
( ( ord_less @ int @ I @ J )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ord_less @ int @ ( times_times @ int @ ( semiring_1_of_nat @ int @ K ) @ I ) @ ( times_times @ int @ ( semiring_1_of_nat @ int @ K ) @ J ) ) ) ) ).
% zmult_zless_mono2_lemma
thf(fact_2426_not__zle__0__negative,axiom,
! [N2: nat] :
~ ( ord_less_eq @ int @ ( zero_zero @ int ) @ ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ ( suc @ N2 ) ) ) ) ).
% not_zle_0_negative
thf(fact_2427_negD,axiom,
! [X: int] :
( ( ord_less @ int @ X @ ( zero_zero @ int ) )
=> ? [N3: nat] :
( X
= ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ ( suc @ N3 ) ) ) ) ) ).
% negD
thf(fact_2428_negative__zless__0,axiom,
! [N2: nat] : ( ord_less @ int @ ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ ( suc @ N2 ) ) ) @ ( zero_zero @ int ) ) ).
% negative_zless_0
thf(fact_2429_nat__approx__posE,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [E3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ E3 )
=> ~ ! [N3: nat] :
~ ( ord_less @ A @ ( divide_divide @ A @ ( one_one @ A ) @ ( semiring_1_of_nat @ A @ ( suc @ N3 ) ) ) @ E3 ) ) ) ).
% nat_approx_posE
thf(fact_2430_of__nat__less__two__power,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: nat] : ( ord_less @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) ) ) ).
% of_nat_less_two_power
thf(fact_2431_inverse__of__nat__le,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [N2: nat,M: nat] :
( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( N2
!= ( zero_zero @ nat ) )
=> ( ord_less_eq @ A @ ( divide_divide @ A @ ( one_one @ A ) @ ( semiring_1_of_nat @ A @ M ) ) @ ( divide_divide @ A @ ( one_one @ A ) @ ( semiring_1_of_nat @ A @ N2 ) ) ) ) ) ) ).
% inverse_of_nat_le
thf(fact_2432_neg__int__cases,axiom,
! [K: int] :
( ( ord_less @ int @ K @ ( zero_zero @ int ) )
=> ~ ! [N3: nat] :
( ( K
= ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ N3 ) ) )
=> ~ ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 ) ) ) ).
% neg_int_cases
thf(fact_2433_zdiff__int__split,axiom,
! [P2: int > $o,X: nat,Y: nat] :
( ( P2 @ ( semiring_1_of_nat @ int @ ( minus_minus @ nat @ X @ Y ) ) )
= ( ( ( ord_less_eq @ nat @ Y @ X )
=> ( P2 @ ( minus_minus @ int @ ( semiring_1_of_nat @ int @ X ) @ ( semiring_1_of_nat @ int @ Y ) ) ) )
& ( ( ord_less @ nat @ X @ Y )
=> ( P2 @ ( zero_zero @ int ) ) ) ) ) ).
% zdiff_int_split
thf(fact_2434_double__arith__series,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A,D2: A,N2: nat] :
( ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( plus_plus @ A @ A3 @ ( times_times @ A @ ( semiring_1_of_nat @ A @ I5 ) @ D2 ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) ) )
= ( times_times @ A @ ( plus_plus @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( one_one @ A ) ) @ ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) @ ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 ) @ D2 ) ) ) ) ) ).
% double_arith_series
thf(fact_2435_of__nat__code__if,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( semiring_1_of_nat @ A )
= ( ^ [N: nat] :
( if @ A
@ ( N
= ( zero_zero @ nat ) )
@ ( zero_zero @ A )
@ ( product_case_prod @ nat @ nat @ A
@ ^ [M2: nat,Q5: nat] :
( if @ A
@ ( Q5
= ( zero_zero @ nat ) )
@ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ A @ M2 ) )
@ ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ A @ M2 ) ) @ ( one_one @ A ) ) )
@ ( divmod_nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% of_nat_code_if
thf(fact_2436_lemma__termdiff2,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [H2: A,Z: A,N2: nat] :
( ( H2
!= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ ( divide_divide @ A @ ( minus_minus @ A @ ( power_power @ A @ ( plus_plus @ A @ Z @ H2 ) @ N2 ) @ ( power_power @ A @ Z @ N2 ) ) @ H2 ) @ ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( power_power @ A @ Z @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) )
= ( times_times @ A @ H2
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [P6: nat] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [Q5: nat] : ( times_times @ A @ ( power_power @ A @ ( plus_plus @ A @ Z @ H2 ) @ Q5 ) @ ( power_power @ A @ Z @ ( minus_minus @ nat @ ( minus_minus @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ Q5 ) ) )
@ ( set_ord_lessThan @ nat @ ( minus_minus @ nat @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) @ P6 ) ) )
@ ( set_ord_lessThan @ nat @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ) ) ) ).
% lemma_termdiff2
thf(fact_2437_lemma__termdiff3,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [H2: A,Z: A,K5: real,N2: nat] :
( ( H2
!= ( zero_zero @ A ) )
=> ( ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ Z ) @ K5 )
=> ( ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ Z @ H2 ) ) @ K5 )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ ( divide_divide @ A @ ( minus_minus @ A @ ( power_power @ A @ ( plus_plus @ A @ Z @ H2 ) @ N2 ) @ ( power_power @ A @ Z @ N2 ) ) @ H2 ) @ ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( power_power @ A @ Z @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ) @ ( times_times @ real @ ( times_times @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ N2 ) @ ( semiring_1_of_nat @ real @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) @ ( power_power @ real @ K5 @ ( minus_minus @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( real_V7770717601297561774m_norm @ A @ H2 ) ) ) ) ) ) ) ).
% lemma_termdiff3
thf(fact_2438_pochhammer__double,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [Z: A,N2: nat] :
( ( comm_s3205402744901411588hammer @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ Z ) @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) )
= ( times_times @ A @ ( times_times @ A @ ( semiring_1_of_nat @ A @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) @ ( comm_s3205402744901411588hammer @ A @ Z @ N2 ) ) @ ( comm_s3205402744901411588hammer @ A @ ( plus_plus @ A @ Z @ ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) @ N2 ) ) ) ) ).
% pochhammer_double
thf(fact_2439_of__nat__code,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( semiring_1_of_nat @ A )
= ( ^ [N: nat] :
( semiri8178284476397505188at_aux @ A
@ ^ [I5: A] : ( plus_plus @ A @ I5 @ ( one_one @ A ) )
@ N
@ ( zero_zero @ A ) ) ) ) ) ).
% of_nat_code
thf(fact_2440_and__int_Oelims,axiom,
! [X: int,Xa2: int,Y: int] :
( ( ( bit_se5824344872417868541ns_and @ int @ X @ Xa2 )
= Y )
=> ( ( ( ( member2 @ int @ X @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) )
& ( member2 @ int @ Xa2 @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) ) )
=> ( Y
= ( uminus_uminus @ int
@ ( zero_neq_one_of_bool @ int
@ ( ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ X )
& ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ Xa2 ) ) ) ) ) )
& ( ~ ( ( member2 @ int @ X @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) )
& ( member2 @ int @ Xa2 @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) ) )
=> ( Y
= ( plus_plus @ int
@ ( zero_neq_one_of_bool @ int
@ ( ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ X )
& ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ Xa2 ) ) )
@ ( times_times @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ ( bit_se5824344872417868541ns_and @ int @ ( divide_divide @ int @ X @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ int @ Xa2 @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ).
% and_int.elims
thf(fact_2441_lessThan__iff,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [I: A,K: A] :
( ( member2 @ A @ I @ ( set_ord_lessThan @ A @ K ) )
= ( ord_less @ A @ I @ K ) ) ) ).
% lessThan_iff
thf(fact_2442_and__zero__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se5824344872417868541ns_and @ A @ A3 @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% and_zero_eq
thf(fact_2443_zero__and__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se5824344872417868541ns_and @ A @ ( zero_zero @ A ) @ A3 )
= ( zero_zero @ A ) ) ) ).
% zero_and_eq
thf(fact_2444_bit_Oconj__zero__left,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [X: A] :
( ( bit_se5824344872417868541ns_and @ A @ ( zero_zero @ A ) @ X )
= ( zero_zero @ A ) ) ) ).
% bit.conj_zero_left
thf(fact_2445_bit_Oconj__zero__right,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [X: A] :
( ( bit_se5824344872417868541ns_and @ A @ X @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% bit.conj_zero_right
thf(fact_2446_lessThan__subset__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_ord_lessThan @ A @ X ) @ ( set_ord_lessThan @ A @ Y ) )
= ( ord_less_eq @ A @ X @ Y ) ) ) ).
% lessThan_subset_iff
thf(fact_2447_pochhammer__0,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A] :
( ( comm_s3205402744901411588hammer @ A @ A3 @ ( zero_zero @ nat ) )
= ( one_one @ A ) ) ) ).
% pochhammer_0
thf(fact_2448_pochhammer__Suc0,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A] :
( ( comm_s3205402744901411588hammer @ A @ A3 @ ( suc @ ( zero_zero @ nat ) ) )
= A3 ) ) ).
% pochhammer_Suc0
thf(fact_2449_lessThan__0,axiom,
( ( set_ord_lessThan @ nat @ ( zero_zero @ nat ) )
= ( bot_bot @ ( set @ nat ) ) ) ).
% lessThan_0
thf(fact_2450_single__Diff__lessThan,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [K: A] :
( ( minus_minus @ ( set @ A ) @ ( insert2 @ A @ K @ ( bot_bot @ ( set @ A ) ) ) @ ( set_ord_lessThan @ A @ K ) )
= ( insert2 @ A @ K @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% single_Diff_lessThan
thf(fact_2451_sum_OlessThan__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_ord_lessThan @ nat @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_ord_lessThan @ nat @ N2 ) ) @ ( G @ N2 ) ) ) ) ).
% sum.lessThan_Suc
thf(fact_2452_and__numerals_I5_J,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [X: num] :
( ( bit_se5824344872417868541ns_and @ A @ ( numeral_numeral @ A @ ( bit0 @ X ) ) @ ( one_one @ A ) )
= ( zero_zero @ A ) ) ) ).
% and_numerals(5)
thf(fact_2453_and__numerals_I1_J,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [Y: num] :
( ( bit_se5824344872417868541ns_and @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ Y ) ) )
= ( zero_zero @ A ) ) ) ).
% and_numerals(1)
thf(fact_2454_and__numerals_I7_J,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [X: num,Y: num] :
( ( bit_se5824344872417868541ns_and @ A @ ( numeral_numeral @ A @ ( bit1 @ X ) ) @ ( numeral_numeral @ A @ ( bit1 @ Y ) ) )
= ( plus_plus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se5824344872417868541ns_and @ A @ ( numeral_numeral @ A @ X ) @ ( numeral_numeral @ A @ Y ) ) ) ) ) ) ).
% and_numerals(7)
thf(fact_2455_int__int__eq,axiom,
! [M: nat,N2: nat] :
( ( ( semiring_1_of_nat @ int @ M )
= ( semiring_1_of_nat @ int @ N2 ) )
= ( M = N2 ) ) ).
% int_int_eq
thf(fact_2456_lessThan__non__empty,axiom,
! [A: $tType] :
( ( no_bot @ A )
=> ! [X: A] :
( ( set_ord_lessThan @ A @ X )
!= ( bot_bot @ ( set @ A ) ) ) ) ).
% lessThan_non_empty
thf(fact_2457_lessThan__def,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( set_ord_lessThan @ A )
= ( ^ [U2: A] :
( collect @ A
@ ^ [X2: A] : ( ord_less @ A @ X2 @ U2 ) ) ) ) ) ).
% lessThan_def
thf(fact_2458_Iio__eq__empty__iff,axiom,
! [A: $tType] :
( ( ( linorder @ A )
& ( order_bot @ A ) )
=> ! [N2: A] :
( ( ( set_ord_lessThan @ A @ N2 )
= ( bot_bot @ ( set @ A ) ) )
= ( N2
= ( bot_bot @ A ) ) ) ) ).
% Iio_eq_empty_iff
thf(fact_2459_lessThan__strict__subset__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [M: A,N2: A] :
( ( ord_less @ ( set @ A ) @ ( set_ord_lessThan @ A @ M ) @ ( set_ord_lessThan @ A @ N2 ) )
= ( ord_less @ A @ M @ N2 ) ) ) ).
% lessThan_strict_subset_iff
thf(fact_2460_pochhammer__pos,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [X: A,N2: nat] :
( ( ord_less @ A @ ( zero_zero @ A ) @ X )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( comm_s3205402744901411588hammer @ A @ X @ N2 ) ) ) ) ).
% pochhammer_pos
thf(fact_2461_pochhammer__eq__0__mono,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,N2: nat,M: nat] :
( ( ( comm_s3205402744901411588hammer @ A @ A3 @ N2 )
= ( zero_zero @ A ) )
=> ( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( comm_s3205402744901411588hammer @ A @ A3 @ M )
= ( zero_zero @ A ) ) ) ) ) ).
% pochhammer_eq_0_mono
thf(fact_2462_pochhammer__neq__0__mono,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,M: nat,N2: nat] :
( ( ( comm_s3205402744901411588hammer @ A @ A3 @ M )
!= ( zero_zero @ A ) )
=> ( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( comm_s3205402744901411588hammer @ A @ A3 @ N2 )
!= ( zero_zero @ A ) ) ) ) ) ).
% pochhammer_neq_0_mono
thf(fact_2463_lessThan__Suc,axiom,
! [K: nat] :
( ( set_ord_lessThan @ nat @ ( suc @ K ) )
= ( insert2 @ nat @ K @ ( set_ord_lessThan @ nat @ K ) ) ) ).
% lessThan_Suc
thf(fact_2464_lessThan__empty__iff,axiom,
! [N2: nat] :
( ( ( set_ord_lessThan @ nat @ N2 )
= ( bot_bot @ ( set @ nat ) ) )
= ( N2
= ( zero_zero @ nat ) ) ) ).
% lessThan_empty_iff
thf(fact_2465_pochhammer__nonneg,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [X: A,N2: nat] :
( ( ord_less @ A @ ( zero_zero @ A ) @ X )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( comm_s3205402744901411588hammer @ A @ X @ N2 ) ) ) ) ).
% pochhammer_nonneg
thf(fact_2466_of__nat__aux_Osimps_I2_J,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [Inc: A > A,N2: nat,I: A] :
( ( semiri8178284476397505188at_aux @ A @ Inc @ ( suc @ N2 ) @ I )
= ( semiri8178284476397505188at_aux @ A @ Inc @ N2 @ ( Inc @ I ) ) ) ) ).
% of_nat_aux.simps(2)
thf(fact_2467_of__nat__aux_Osimps_I1_J,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [Inc: A > A,I: A] :
( ( semiri8178284476397505188at_aux @ A @ Inc @ ( zero_zero @ nat ) @ I )
= I ) ) ).
% of_nat_aux.simps(1)
thf(fact_2468_pochhammer__0__left,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [N2: nat] :
( ( ( N2
= ( zero_zero @ nat ) )
=> ( ( comm_s3205402744901411588hammer @ A @ ( zero_zero @ A ) @ N2 )
= ( one_one @ A ) ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( comm_s3205402744901411588hammer @ A @ ( zero_zero @ A ) @ N2 )
= ( zero_zero @ A ) ) ) ) ) ).
% pochhammer_0_left
thf(fact_2469_sum_Onat__diff__reindex,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( minus_minus @ nat @ N2 @ ( suc @ I5 ) ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ).
% sum.nat_diff_reindex
thf(fact_2470_sum__diff__distrib,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [Q: A > nat,P2: A > nat,N2: A] :
( ! [X5: A] : ( ord_less_eq @ nat @ ( Q @ X5 ) @ ( P2 @ X5 ) )
=> ( ( minus_minus @ nat @ ( groups7311177749621191930dd_sum @ A @ nat @ P2 @ ( set_ord_lessThan @ A @ N2 ) ) @ ( groups7311177749621191930dd_sum @ A @ nat @ Q @ ( set_ord_lessThan @ A @ N2 ) ) )
= ( groups7311177749621191930dd_sum @ A @ nat
@ ^ [X2: A] : ( minus_minus @ nat @ ( P2 @ X2 ) @ ( Q @ X2 ) )
@ ( set_ord_lessThan @ A @ N2 ) ) ) ) ) ).
% sum_diff_distrib
thf(fact_2471_pochhammer__rec,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A,N2: nat] :
( ( comm_s3205402744901411588hammer @ A @ A3 @ ( suc @ N2 ) )
= ( times_times @ A @ A3 @ ( comm_s3205402744901411588hammer @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ N2 ) ) ) ) ).
% pochhammer_rec
thf(fact_2472_pochhammer__Suc,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A,N2: nat] :
( ( comm_s3205402744901411588hammer @ A @ A3 @ ( suc @ N2 ) )
= ( times_times @ A @ ( comm_s3205402744901411588hammer @ A @ A3 @ N2 ) @ ( plus_plus @ A @ A3 @ ( semiring_1_of_nat @ A @ N2 ) ) ) ) ) ).
% pochhammer_Suc
thf(fact_2473_pochhammer__rec_H,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [Z: A,N2: nat] :
( ( comm_s3205402744901411588hammer @ A @ Z @ ( suc @ N2 ) )
= ( times_times @ A @ ( plus_plus @ A @ Z @ ( semiring_1_of_nat @ A @ N2 ) ) @ ( comm_s3205402744901411588hammer @ A @ Z @ N2 ) ) ) ) ).
% pochhammer_rec'
thf(fact_2474_pochhammer__eq__0__iff,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,N2: nat] :
( ( ( comm_s3205402744901411588hammer @ A @ A3 @ N2 )
= ( zero_zero @ A ) )
= ( ? [K2: nat] :
( ( ord_less @ nat @ K2 @ N2 )
& ( A3
= ( uminus_uminus @ A @ ( semiring_1_of_nat @ A @ K2 ) ) ) ) ) ) ) ).
% pochhammer_eq_0_iff
thf(fact_2475_pochhammer__of__nat__eq__0__iff,axiom,
! [A: $tType] :
( ( ( ring_char_0 @ A )
& ( idom @ A ) )
=> ! [N2: nat,K: nat] :
( ( ( comm_s3205402744901411588hammer @ A @ ( uminus_uminus @ A @ ( semiring_1_of_nat @ A @ N2 ) ) @ K )
= ( zero_zero @ A ) )
= ( ord_less @ nat @ N2 @ K ) ) ) ).
% pochhammer_of_nat_eq_0_iff
thf(fact_2476_pochhammer__of__nat__eq__0__lemma,axiom,
! [A: $tType] :
( ( idom @ A )
=> ! [N2: nat,K: nat] :
( ( ord_less @ nat @ N2 @ K )
=> ( ( comm_s3205402744901411588hammer @ A @ ( uminus_uminus @ A @ ( semiring_1_of_nat @ A @ N2 ) ) @ K )
= ( zero_zero @ A ) ) ) ) ).
% pochhammer_of_nat_eq_0_lemma
thf(fact_2477_pochhammer__of__nat__eq__0__lemma_H,axiom,
! [A: $tType] :
( ( ( ring_char_0 @ A )
& ( idom @ A ) )
=> ! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( comm_s3205402744901411588hammer @ A @ ( uminus_uminus @ A @ ( semiring_1_of_nat @ A @ N2 ) ) @ K )
!= ( zero_zero @ A ) ) ) ) ).
% pochhammer_of_nat_eq_0_lemma'
thf(fact_2478_pochhammer__product_H,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [Z: A,N2: nat,M: nat] :
( ( comm_s3205402744901411588hammer @ A @ Z @ ( plus_plus @ nat @ N2 @ M ) )
= ( times_times @ A @ ( comm_s3205402744901411588hammer @ A @ Z @ N2 ) @ ( comm_s3205402744901411588hammer @ A @ ( plus_plus @ A @ Z @ ( semiring_1_of_nat @ A @ N2 ) ) @ M ) ) ) ) ).
% pochhammer_product'
thf(fact_2479_sum_OlessThan__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_ord_lessThan @ nat @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( G @ ( zero_zero @ nat ) )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ).
% sum.lessThan_Suc_shift
thf(fact_2480_sum__lessThan__telescope_H,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [F2: nat > A,M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [N: nat] : ( minus_minus @ A @ ( F2 @ N ) @ ( F2 @ ( suc @ N ) ) )
@ ( set_ord_lessThan @ nat @ M ) )
= ( minus_minus @ A @ ( F2 @ ( zero_zero @ nat ) ) @ ( F2 @ M ) ) ) ) ).
% sum_lessThan_telescope'
thf(fact_2481_sum__lessThan__telescope,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [F2: nat > A,M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [N: nat] : ( minus_minus @ A @ ( F2 @ ( suc @ N ) ) @ ( F2 @ N ) )
@ ( set_ord_lessThan @ nat @ M ) )
= ( minus_minus @ A @ ( F2 @ M ) @ ( F2 @ ( zero_zero @ nat ) ) ) ) ) ).
% sum_lessThan_telescope
thf(fact_2482_sum_OatLeast1__atMost__eq,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( G @ ( suc @ K2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ).
% sum.atLeast1_atMost_eq
thf(fact_2483_pochhammer__product,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [M: nat,N2: nat,Z: A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( comm_s3205402744901411588hammer @ A @ Z @ N2 )
= ( times_times @ A @ ( comm_s3205402744901411588hammer @ A @ Z @ M ) @ ( comm_s3205402744901411588hammer @ A @ ( plus_plus @ A @ Z @ ( semiring_1_of_nat @ A @ M ) ) @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ) ) ).
% pochhammer_product
thf(fact_2484_and__exp__eq__0__iff__not__bit,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A,N2: nat] :
( ( ( bit_se5824344872417868541ns_and @ A @ A3 @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( zero_zero @ A ) )
= ( ~ ( bit_se5641148757651400278ts_bit @ A @ A3 @ N2 ) ) ) ) ).
% and_exp_eq_0_iff_not_bit
thf(fact_2485_lemma__termdiff1,axiom,
! [A: $tType] :
( ( ( monoid_mult @ A )
& ( comm_ring @ A ) )
=> ! [Z: A,H2: A,M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [P6: nat] : ( minus_minus @ A @ ( times_times @ A @ ( power_power @ A @ ( plus_plus @ A @ Z @ H2 ) @ ( minus_minus @ nat @ M @ P6 ) ) @ ( power_power @ A @ Z @ P6 ) ) @ ( power_power @ A @ Z @ M ) )
@ ( set_ord_lessThan @ nat @ M ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [P6: nat] : ( times_times @ A @ ( power_power @ A @ Z @ P6 ) @ ( minus_minus @ A @ ( power_power @ A @ ( plus_plus @ A @ Z @ H2 ) @ ( minus_minus @ nat @ M @ P6 ) ) @ ( power_power @ A @ Z @ ( minus_minus @ nat @ M @ P6 ) ) ) )
@ ( set_ord_lessThan @ nat @ M ) ) ) ) ).
% lemma_termdiff1
thf(fact_2486_power__diff__sumr2,axiom,
! [A: $tType] :
( ( ( monoid_mult @ A )
& ( comm_ring @ A ) )
=> ! [X: A,N2: nat,Y: A] :
( ( minus_minus @ A @ ( power_power @ A @ X @ N2 ) @ ( power_power @ A @ Y @ N2 ) )
= ( times_times @ A @ ( minus_minus @ A @ X @ Y )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( power_power @ A @ Y @ ( minus_minus @ nat @ N2 @ ( suc @ I5 ) ) ) @ ( power_power @ A @ X @ I5 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ).
% power_diff_sumr2
thf(fact_2487_diff__power__eq__sum,axiom,
! [A: $tType] :
( ( ( monoid_mult @ A )
& ( comm_ring @ A ) )
=> ! [X: A,N2: nat,Y: A] :
( ( minus_minus @ A @ ( power_power @ A @ X @ ( suc @ N2 ) ) @ ( power_power @ A @ Y @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( minus_minus @ A @ X @ Y )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [P6: nat] : ( times_times @ A @ ( power_power @ A @ X @ P6 ) @ ( power_power @ A @ Y @ ( minus_minus @ nat @ N2 @ P6 ) ) )
@ ( set_ord_lessThan @ nat @ ( suc @ N2 ) ) ) ) ) ) ).
% diff_power_eq_sum
thf(fact_2488_pochhammer__absorb__comp,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [R2: A,K: nat] :
( ( times_times @ A @ ( minus_minus @ A @ R2 @ ( semiring_1_of_nat @ A @ K ) ) @ ( comm_s3205402744901411588hammer @ A @ ( uminus_uminus @ A @ R2 ) @ K ) )
= ( times_times @ A @ R2 @ ( comm_s3205402744901411588hammer @ A @ ( plus_plus @ A @ ( uminus_uminus @ A @ R2 ) @ ( one_one @ A ) ) @ K ) ) ) ) ).
% pochhammer_absorb_comp
thf(fact_2489_real__sum__nat__ivl__bounded2,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat,F2: nat > A,K5: A,K: nat] :
( ! [P7: nat] :
( ( ord_less @ nat @ P7 @ N2 )
=> ( ord_less_eq @ A @ ( F2 @ P7 ) @ K5 ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ K5 )
=> ( ord_less_eq @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_lessThan @ nat @ ( minus_minus @ nat @ N2 @ K ) ) ) @ ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 ) @ K5 ) ) ) ) ) ).
% real_sum_nat_ivl_bounded2
thf(fact_2490_one__diff__power__eq_H,axiom,
! [A: $tType] :
( ( ( monoid_mult @ A )
& ( comm_ring @ A ) )
=> ! [X: A,N2: nat] :
( ( minus_minus @ A @ ( one_one @ A ) @ ( power_power @ A @ X @ N2 ) )
= ( times_times @ A @ ( minus_minus @ A @ ( one_one @ A ) @ X )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( power_power @ A @ X @ ( minus_minus @ nat @ N2 @ ( suc @ I5 ) ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ).
% one_diff_power_eq'
thf(fact_2491_sum__split__even__odd,axiom,
! [F2: nat > real,G: nat > real,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( if @ real @ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) @ ( F2 @ I5 ) @ ( G @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( F2 @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( G @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) @ ( one_one @ nat ) ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ).
% sum_split_even_odd
thf(fact_2492_pochhammer__minus_H,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [B2: A,K: nat] :
( ( comm_s3205402744901411588hammer @ A @ ( plus_plus @ A @ ( minus_minus @ A @ B2 @ ( semiring_1_of_nat @ A @ K ) ) @ ( one_one @ A ) ) @ K )
= ( times_times @ A @ ( power_power @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ K ) @ ( comm_s3205402744901411588hammer @ A @ ( uminus_uminus @ A @ B2 ) @ K ) ) ) ) ).
% pochhammer_minus'
thf(fact_2493_pochhammer__minus,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [B2: A,K: nat] :
( ( comm_s3205402744901411588hammer @ A @ ( uminus_uminus @ A @ B2 ) @ K )
= ( times_times @ A @ ( power_power @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ K ) @ ( comm_s3205402744901411588hammer @ A @ ( plus_plus @ A @ ( minus_minus @ A @ B2 @ ( semiring_1_of_nat @ A @ K ) ) @ ( one_one @ A ) ) @ K ) ) ) ) ).
% pochhammer_minus
thf(fact_2494_and__int_Osimps,axiom,
( ( bit_se5824344872417868541ns_and @ int )
= ( ^ [K2: int,L2: int] :
( if @ int
@ ( ( member2 @ int @ K2 @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) )
& ( member2 @ int @ L2 @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) ) )
@ ( uminus_uminus @ int
@ ( zero_neq_one_of_bool @ int
@ ( ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ K2 )
& ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ L2 ) ) ) )
@ ( plus_plus @ int
@ ( zero_neq_one_of_bool @ int
@ ( ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ K2 )
& ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ L2 ) ) )
@ ( times_times @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ ( bit_se5824344872417868541ns_and @ int @ ( divide_divide @ int @ K2 @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ int @ L2 @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ).
% and_int.simps
thf(fact_2495_norm__le__zero__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X: A] :
( ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ X ) @ ( zero_zero @ real ) )
= ( X
= ( zero_zero @ A ) ) ) ) ).
% norm_le_zero_iff
thf(fact_2496_zero__less__norm__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X: A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ ( real_V7770717601297561774m_norm @ A @ X ) )
= ( X
!= ( zero_zero @ A ) ) ) ) ).
% zero_less_norm_iff
thf(fact_2497_norm__zero,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ( ( real_V7770717601297561774m_norm @ A @ ( zero_zero @ A ) )
= ( zero_zero @ real ) ) ) ).
% norm_zero
thf(fact_2498_norm__eq__zero,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X: A] :
( ( ( real_V7770717601297561774m_norm @ A @ X )
= ( zero_zero @ real ) )
= ( X
= ( zero_zero @ A ) ) ) ) ).
% norm_eq_zero
thf(fact_2499_lemma__NBseq__def2,axiom,
! [A: $tType,B: $tType] :
( ( real_V822414075346904944vector @ B )
=> ! [X7: A > B] :
( ( ? [K6: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ K6 )
& ! [N: A] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ B @ ( X7 @ N ) ) @ K6 ) ) )
= ( ? [N6: nat] :
! [N: A] : ( ord_less @ real @ ( real_V7770717601297561774m_norm @ B @ ( X7 @ N ) ) @ ( semiring_1_of_nat @ real @ ( suc @ N6 ) ) ) ) ) ) ).
% lemma_NBseq_def2
thf(fact_2500_lemma__NBseq__def,axiom,
! [A: $tType,B: $tType] :
( ( real_V822414075346904944vector @ B )
=> ! [X7: A > B] :
( ( ? [K6: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ K6 )
& ! [N: A] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ B @ ( X7 @ N ) ) @ K6 ) ) )
= ( ? [N6: nat] :
! [N: A] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ B @ ( X7 @ N ) ) @ ( semiring_1_of_nat @ real @ ( suc @ N6 ) ) ) ) ) ) ).
% lemma_NBseq_def
thf(fact_2501_and__nat__numerals_I3_J,axiom,
! [X: num] :
( ( bit_se5824344872417868541ns_and @ nat @ ( numeral_numeral @ nat @ ( bit0 @ X ) ) @ ( suc @ ( zero_zero @ nat ) ) )
= ( zero_zero @ nat ) ) ).
% and_nat_numerals(3)
thf(fact_2502_and__nat__numerals_I1_J,axiom,
! [Y: num] :
( ( bit_se5824344872417868541ns_and @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( numeral_numeral @ nat @ ( bit0 @ Y ) ) )
= ( zero_zero @ nat ) ) ).
% and_nat_numerals(1)
thf(fact_2503_and__nat__numerals_I4_J,axiom,
! [X: num] :
( ( bit_se5824344872417868541ns_and @ nat @ ( numeral_numeral @ nat @ ( bit1 @ X ) ) @ ( suc @ ( zero_zero @ nat ) ) )
= ( one_one @ nat ) ) ).
% and_nat_numerals(4)
thf(fact_2504_and__nat__numerals_I2_J,axiom,
! [Y: num] :
( ( bit_se5824344872417868541ns_and @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( numeral_numeral @ nat @ ( bit1 @ Y ) ) )
= ( one_one @ nat ) ) ).
% and_nat_numerals(2)
thf(fact_2505_Suc__0__and__eq,axiom,
! [N2: nat] :
( ( bit_se5824344872417868541ns_and @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
= ( modulo_modulo @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ).
% Suc_0_and_eq
thf(fact_2506_and__Suc__0__eq,axiom,
! [N2: nat] :
( ( bit_se5824344872417868541ns_and @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) )
= ( modulo_modulo @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ).
% and_Suc_0_eq
thf(fact_2507_and__nat__unfold,axiom,
( ( bit_se5824344872417868541ns_and @ nat )
= ( ^ [M2: nat,N: nat] :
( if @ nat
@ ( ( M2
= ( zero_zero @ nat ) )
| ( N
= ( zero_zero @ nat ) ) )
@ ( zero_zero @ nat )
@ ( plus_plus @ nat @ ( times_times @ nat @ ( modulo_modulo @ nat @ M2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( modulo_modulo @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( bit_se5824344872417868541ns_and @ nat @ ( divide_divide @ nat @ M2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ).
% and_nat_unfold
thf(fact_2508_and__nat__rec,axiom,
( ( bit_se5824344872417868541ns_and @ nat )
= ( ^ [M2: nat,N: nat] :
( plus_plus @ nat
@ ( zero_neq_one_of_bool @ nat
@ ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M2 )
& ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) ) )
@ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( bit_se5824344872417868541ns_and @ nat @ ( divide_divide @ nat @ M2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% and_nat_rec
thf(fact_2509_nonzero__norm__divide,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( real_V7770717601297561774m_norm @ A @ ( divide_divide @ A @ A3 @ B2 ) )
= ( divide_divide @ real @ ( real_V7770717601297561774m_norm @ A @ A3 ) @ ( real_V7770717601297561774m_norm @ A @ B2 ) ) ) ) ) ).
% nonzero_norm_divide
thf(fact_2510_norm__diff__ineq,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ real @ ( minus_minus @ real @ ( real_V7770717601297561774m_norm @ A @ A3 ) @ ( real_V7770717601297561774m_norm @ A @ B2 ) ) @ ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ A3 @ B2 ) ) ) ) ).
% norm_diff_ineq
thf(fact_2511_norm__uminus__minus,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X: A,Y: A] :
( ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ ( uminus_uminus @ A @ X ) @ Y ) )
= ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ X @ Y ) ) ) ) ).
% norm_uminus_minus
thf(fact_2512_power__eq__imp__eq__norm,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [W2: A,N2: nat,Z: A] :
( ( ( power_power @ A @ W2 @ N2 )
= ( power_power @ A @ Z @ N2 ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( real_V7770717601297561774m_norm @ A @ W2 )
= ( real_V7770717601297561774m_norm @ A @ Z ) ) ) ) ) ).
% power_eq_imp_eq_norm
thf(fact_2513_norm__triangle__lt,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X: A,Y: A,E3: real] :
( ( ord_less @ real @ ( plus_plus @ real @ ( real_V7770717601297561774m_norm @ A @ X ) @ ( real_V7770717601297561774m_norm @ A @ Y ) ) @ E3 )
=> ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ X @ Y ) ) @ E3 ) ) ) ).
% norm_triangle_lt
thf(fact_2514_norm__add__less,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X: A,R2: real,Y: A,S: real] :
( ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ X ) @ R2 )
=> ( ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ Y ) @ S )
=> ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ X @ Y ) ) @ ( plus_plus @ real @ R2 @ S ) ) ) ) ) ).
% norm_add_less
thf(fact_2515_norm__add__leD,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [A3: A,B2: A,C2: real] :
( ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ A3 @ B2 ) ) @ C2 )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ B2 ) @ ( plus_plus @ real @ ( real_V7770717601297561774m_norm @ A @ A3 ) @ C2 ) ) ) ) ).
% norm_add_leD
thf(fact_2516_norm__triangle__le,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X: A,Y: A,E3: real] :
( ( ord_less_eq @ real @ ( plus_plus @ real @ ( real_V7770717601297561774m_norm @ A @ X ) @ ( real_V7770717601297561774m_norm @ A @ Y ) ) @ E3 )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ X @ Y ) ) @ E3 ) ) ) ).
% norm_triangle_le
thf(fact_2517_norm__triangle__ineq,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ X @ Y ) ) @ ( plus_plus @ real @ ( real_V7770717601297561774m_norm @ A @ X ) @ ( real_V7770717601297561774m_norm @ A @ Y ) ) ) ) ).
% norm_triangle_ineq
thf(fact_2518_norm__triangle__mono,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [A3: A,R2: real,B2: A,S: real] :
( ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ A3 ) @ R2 )
=> ( ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ B2 ) @ S )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ A3 @ B2 ) ) @ ( plus_plus @ real @ R2 @ S ) ) ) ) ) ).
% norm_triangle_mono
thf(fact_2519_power__eq__1__iff,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [W2: A,N2: nat] :
( ( ( power_power @ A @ W2 @ N2 )
= ( one_one @ A ) )
=> ( ( ( real_V7770717601297561774m_norm @ A @ W2 )
= ( one_one @ real ) )
| ( N2
= ( zero_zero @ nat ) ) ) ) ) ).
% power_eq_1_iff
thf(fact_2520_norm__diff__triangle__ineq,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( plus_plus @ A @ C2 @ D2 ) ) ) @ ( plus_plus @ real @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ A3 @ C2 ) ) @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ B2 @ D2 ) ) ) ) ) ).
% norm_diff_triangle_ineq
thf(fact_2521_sum__bounds__lt__plus1,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [F2: nat > A,Mm: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( F2 @ ( suc @ K2 ) )
@ ( set_ord_lessThan @ nat @ Mm ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or1337092689740270186AtMost @ nat @ ( one_one @ nat ) @ Mm ) ) ) ) ).
% sum_bounds_lt_plus1
thf(fact_2522_sumr__cos__zero__one,axiom,
! [N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( cos_coeff @ M2 ) @ ( power_power @ real @ ( zero_zero @ real ) @ M2 ) )
@ ( set_ord_lessThan @ nat @ ( suc @ N2 ) ) )
= ( one_one @ real ) ) ).
% sumr_cos_zero_one
thf(fact_2523_pochhammer__times__pochhammer__half,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [Z: A,N2: nat] :
( ( times_times @ A @ ( comm_s3205402744901411588hammer @ A @ Z @ ( suc @ N2 ) ) @ ( comm_s3205402744901411588hammer @ A @ ( plus_plus @ A @ Z @ ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) @ ( suc @ N2 ) ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [K2: nat] : ( plus_plus @ A @ Z @ ( divide_divide @ A @ ( semiring_1_of_nat @ A @ K2 ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ ( one_one @ nat ) ) ) ) ) ) ).
% pochhammer_times_pochhammer_half
thf(fact_2524_pochhammer__code,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ( ( comm_s3205402744901411588hammer @ A )
= ( ^ [A5: A,N: nat] :
( if @ A
@ ( N
= ( zero_zero @ nat ) )
@ ( one_one @ A )
@ ( set_fo6178422350223883121st_nat @ A
@ ^ [O: nat] : ( times_times @ A @ ( plus_plus @ A @ A5 @ ( semiring_1_of_nat @ A @ O ) ) )
@ ( zero_zero @ nat )
@ ( minus_minus @ nat @ N @ ( one_one @ nat ) )
@ ( one_one @ A ) ) ) ) ) ) ).
% pochhammer_code
thf(fact_2525_ceiling__log__nat__eq__powr__iff,axiom,
! [B2: nat,K: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ B2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ( ( archimedean_ceiling @ real @ ( log @ ( semiring_1_of_nat @ real @ B2 ) @ ( semiring_1_of_nat @ real @ K ) ) )
= ( plus_plus @ int @ ( semiring_1_of_nat @ int @ N2 ) @ ( one_one @ int ) ) )
= ( ( ord_less @ nat @ ( power_power @ nat @ B2 @ N2 ) @ K )
& ( ord_less_eq @ nat @ K @ ( power_power @ nat @ B2 @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) ) ) ) ) ) ) ).
% ceiling_log_nat_eq_powr_iff
thf(fact_2526_geometric__deriv__sums,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [Z: A] :
( ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ Z ) @ ( one_one @ real ) )
=> ( sums @ A
@ ^ [N: nat] : ( times_times @ A @ ( semiring_1_of_nat @ A @ ( suc @ N ) ) @ ( power_power @ A @ Z @ N ) )
@ ( divide_divide @ A @ ( one_one @ A ) @ ( power_power @ A @ ( minus_minus @ A @ ( one_one @ A ) @ Z ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ).
% geometric_deriv_sums
thf(fact_2527_of__nat__prod,axiom,
! [A: $tType,B: $tType] :
( ( comm_semiring_1 @ A )
=> ! [F2: B > nat,A4: set @ B] :
( ( semiring_1_of_nat @ A @ ( groups7121269368397514597t_prod @ B @ nat @ F2 @ A4 ) )
= ( groups7121269368397514597t_prod @ B @ A
@ ^ [X2: B] : ( semiring_1_of_nat @ A @ ( F2 @ X2 ) )
@ A4 ) ) ) ).
% of_nat_prod
thf(fact_2528_of__int__prod,axiom,
! [A: $tType,B: $tType] :
( ( comm_ring_1 @ A )
=> ! [F2: B > int,A4: set @ B] :
( ( ring_1_of_int @ A @ ( groups7121269368397514597t_prod @ B @ int @ F2 @ A4 ) )
= ( groups7121269368397514597t_prod @ B @ A
@ ^ [X2: B] : ( ring_1_of_int @ A @ ( F2 @ X2 ) )
@ A4 ) ) ) ).
% of_int_prod
thf(fact_2529_prod__zero__iff,axiom,
! [A: $tType,B: $tType] :
( ( semidom @ A )
=> ! [A4: set @ B,F2: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 )
= ( zero_zero @ A ) )
= ( ? [X2: B] :
( ( member2 @ B @ X2 @ A4 )
& ( ( F2 @ X2 )
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% prod_zero_iff
thf(fact_2530_prod_Oempty,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: B > A] :
( ( groups7121269368397514597t_prod @ B @ A @ G @ ( bot_bot @ ( set @ B ) ) )
= ( one_one @ A ) ) ) ).
% prod.empty
thf(fact_2531_cos__coeff__0,axiom,
( ( cos_coeff @ ( zero_zero @ nat ) )
= ( one_one @ real ) ) ).
% cos_coeff_0
thf(fact_2532_prod_OlessThan__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_ord_lessThan @ nat @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_ord_lessThan @ nat @ N2 ) ) @ ( G @ N2 ) ) ) ) ).
% prod.lessThan_Suc
thf(fact_2533_powser__sums__zero__iff,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [A3: nat > A,X: A] :
( ( sums @ A
@ ^ [N: nat] : ( times_times @ A @ ( A3 @ N ) @ ( power_power @ A @ ( zero_zero @ A ) @ N ) )
@ X )
= ( ( A3 @ ( zero_zero @ nat ) )
= X ) ) ) ).
% powser_sums_zero_iff
thf(fact_2534_prod_Ocl__ivl__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [N2: nat,M: nat,G: nat > A] :
( ( ( ord_less @ nat @ ( suc @ N2 ) @ M )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ ( suc @ N2 ) ) )
= ( one_one @ A ) ) )
& ( ~ ( ord_less @ nat @ ( suc @ N2 ) @ M )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) @ ( G @ ( suc @ N2 ) ) ) ) ) ) ) ).
% prod.cl_ivl_Suc
thf(fact_2535_prod__mono,axiom,
! [A: $tType,B: $tType] :
( ( linordered_semidom @ A )
=> ! [A4: set @ B,F2: B > A,G: B > A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ I3 ) )
& ( ord_less_eq @ A @ ( F2 @ I3 ) @ ( G @ I3 ) ) ) )
=> ( ord_less_eq @ A @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) @ ( groups7121269368397514597t_prod @ B @ A @ G @ A4 ) ) ) ) ).
% prod_mono
thf(fact_2536_prod__nonneg,axiom,
! [A: $tType,B: $tType] :
( ( linordered_semidom @ A )
=> ! [A4: set @ B,F2: B > A] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ X5 ) ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) ) ) ) ).
% prod_nonneg
thf(fact_2537_prod__pos,axiom,
! [A: $tType,B: $tType] :
( ( linordered_semidom @ A )
=> ! [A4: set @ B,F2: B > A] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( F2 @ X5 ) ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) ) ) ) ).
% prod_pos
thf(fact_2538_prod__ge__1,axiom,
! [A: $tType,B: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [A4: set @ B,F2: B > A] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ ( one_one @ A ) @ ( F2 @ X5 ) ) )
=> ( ord_less_eq @ A @ ( one_one @ A ) @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) ) ) ) ).
% prod_ge_1
thf(fact_2539_prod__zero,axiom,
! [B: $tType,A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A4: set @ B,F2: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ? [X3: B] :
( ( member2 @ B @ X3 @ A4 )
& ( ( F2 @ X3 )
= ( zero_zero @ A ) ) )
=> ( ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 )
= ( zero_zero @ A ) ) ) ) ) ).
% prod_zero
thf(fact_2540_prod_Oshift__bounds__cl__Suc__ivl,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% prod.shift_bounds_cl_Suc_ivl
thf(fact_2541_prod_Oshift__bounds__cl__nat__ivl,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,K: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( plus_plus @ nat @ M @ K ) @ ( plus_plus @ nat @ N2 @ K ) ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( plus_plus @ nat @ I5 @ K ) )
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% prod.shift_bounds_cl_nat_ivl
thf(fact_2542_prod__le__1,axiom,
! [B: $tType,A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [A4: set @ B,F2: B > A] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ X5 ) )
& ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( one_one @ A ) ) ) )
=> ( ord_less_eq @ A @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) @ ( one_one @ A ) ) ) ) ).
% prod_le_1
thf(fact_2543_prod__dvd__prod__subset2,axiom,
! [A: $tType,B: $tType] :
( ( comm_semiring_1 @ A )
=> ! [B3: set @ B,A4: set @ B,F2: B > A,G: B > A] :
( ( finite_finite @ B @ B3 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ B3 )
=> ( ! [A7: B] :
( ( member2 @ B @ A7 @ A4 )
=> ( dvd_dvd @ A @ ( F2 @ A7 ) @ ( G @ A7 ) ) )
=> ( dvd_dvd @ A @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) @ ( groups7121269368397514597t_prod @ B @ A @ G @ B3 ) ) ) ) ) ) ).
% prod_dvd_prod_subset2
thf(fact_2544_prod__dvd__prod__subset,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [B3: set @ B,A4: set @ B,F2: B > A] :
( ( finite_finite @ B @ B3 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ B3 )
=> ( dvd_dvd @ A @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ B3 ) ) ) ) ) ).
% prod_dvd_prod_subset
thf(fact_2545_prod_Onat__diff__reindex,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( minus_minus @ nat @ N2 @ ( suc @ I5 ) ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
= ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ).
% prod.nat_diff_reindex
thf(fact_2546_prod_OatLeastAtMost__rev,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat,M: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ N2 @ M ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( minus_minus @ nat @ ( plus_plus @ nat @ M @ N2 ) @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ N2 @ M ) ) ) ) ).
% prod.atLeastAtMost_rev
thf(fact_2547_less__1__prod2,axiom,
! [B: $tType,A: $tType] :
( ( linordered_idom @ B )
=> ! [I6: set @ A,I: A,F2: A > B] :
( ( finite_finite @ A @ I6 )
=> ( ( member2 @ A @ I @ I6 )
=> ( ( ord_less @ B @ ( one_one @ B ) @ ( F2 @ I ) )
=> ( ! [I3: A] :
( ( member2 @ A @ I3 @ I6 )
=> ( ord_less_eq @ B @ ( one_one @ B ) @ ( F2 @ I3 ) ) )
=> ( ord_less @ B @ ( one_one @ B ) @ ( groups7121269368397514597t_prod @ A @ B @ F2 @ I6 ) ) ) ) ) ) ) ).
% less_1_prod2
thf(fact_2548_less__1__prod,axiom,
! [B: $tType,A: $tType] :
( ( linordered_idom @ B )
=> ! [I6: set @ A,F2: A > B] :
( ( finite_finite @ A @ I6 )
=> ( ( I6
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [I3: A] :
( ( member2 @ A @ I3 @ I6 )
=> ( ord_less @ B @ ( one_one @ B ) @ ( F2 @ I3 ) ) )
=> ( ord_less @ B @ ( one_one @ B ) @ ( groups7121269368397514597t_prod @ A @ B @ F2 @ I6 ) ) ) ) ) ) ).
% less_1_prod
thf(fact_2549_prod_Osubset__diff,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [B3: set @ B,A4: set @ B,G: B > A] :
( ( ord_less_eq @ ( set @ B ) @ B3 @ A4 )
=> ( ( finite_finite @ B @ A4 )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ A4 )
= ( times_times @ A @ ( groups7121269368397514597t_prod @ B @ A @ G @ ( minus_minus @ ( set @ B ) @ A4 @ B3 ) ) @ ( groups7121269368397514597t_prod @ B @ A @ G @ B3 ) ) ) ) ) ) ).
% prod.subset_diff
thf(fact_2550_prod_Omono__neutral__cong__right,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [T4: set @ B,S3: set @ B,G: B > A,H2: B > A] :
( ( finite_finite @ B @ T4 )
=> ( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( G @ X5 )
= ( one_one @ A ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ S3 )
=> ( ( G @ X5 )
= ( H2 @ X5 ) ) )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ T4 )
= ( groups7121269368397514597t_prod @ B @ A @ H2 @ S3 ) ) ) ) ) ) ) ).
% prod.mono_neutral_cong_right
thf(fact_2551_prod_Omono__neutral__cong__left,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [T4: set @ B,S3: set @ B,H2: B > A,G: B > A] :
( ( finite_finite @ B @ T4 )
=> ( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( H2 @ X5 )
= ( one_one @ A ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ S3 )
=> ( ( G @ X5 )
= ( H2 @ X5 ) ) )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ S3 )
= ( groups7121269368397514597t_prod @ B @ A @ H2 @ T4 ) ) ) ) ) ) ) ).
% prod.mono_neutral_cong_left
thf(fact_2552_prod_Omono__neutral__right,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [T4: set @ B,S3: set @ B,G: B > A] :
( ( finite_finite @ B @ T4 )
=> ( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( G @ X5 )
= ( one_one @ A ) ) )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ T4 )
= ( groups7121269368397514597t_prod @ B @ A @ G @ S3 ) ) ) ) ) ) ).
% prod.mono_neutral_right
thf(fact_2553_prod_Omono__neutral__left,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [T4: set @ B,S3: set @ B,G: B > A] :
( ( finite_finite @ B @ T4 )
=> ( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( G @ X5 )
= ( one_one @ A ) ) )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ S3 )
= ( groups7121269368397514597t_prod @ B @ A @ G @ T4 ) ) ) ) ) ) ).
% prod.mono_neutral_left
thf(fact_2554_prod_Osame__carrierI,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [C5: set @ B,A4: set @ B,B3: set @ B,G: B > A,H2: B > A] :
( ( finite_finite @ B @ C5 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ C5 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ C5 )
=> ( ! [A7: B] :
( ( member2 @ B @ A7 @ ( minus_minus @ ( set @ B ) @ C5 @ A4 ) )
=> ( ( G @ A7 )
= ( one_one @ A ) ) )
=> ( ! [B5: B] :
( ( member2 @ B @ B5 @ ( minus_minus @ ( set @ B ) @ C5 @ B3 ) )
=> ( ( H2 @ B5 )
= ( one_one @ A ) ) )
=> ( ( ( groups7121269368397514597t_prod @ B @ A @ G @ C5 )
= ( groups7121269368397514597t_prod @ B @ A @ H2 @ C5 ) )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ A4 )
= ( groups7121269368397514597t_prod @ B @ A @ H2 @ B3 ) ) ) ) ) ) ) ) ) ).
% prod.same_carrierI
thf(fact_2555_prod_Osame__carrier,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [C5: set @ B,A4: set @ B,B3: set @ B,G: B > A,H2: B > A] :
( ( finite_finite @ B @ C5 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ C5 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ C5 )
=> ( ! [A7: B] :
( ( member2 @ B @ A7 @ ( minus_minus @ ( set @ B ) @ C5 @ A4 ) )
=> ( ( G @ A7 )
= ( one_one @ A ) ) )
=> ( ! [B5: B] :
( ( member2 @ B @ B5 @ ( minus_minus @ ( set @ B ) @ C5 @ B3 ) )
=> ( ( H2 @ B5 )
= ( one_one @ A ) ) )
=> ( ( ( groups7121269368397514597t_prod @ B @ A @ G @ A4 )
= ( groups7121269368397514597t_prod @ B @ A @ H2 @ B3 ) )
= ( ( groups7121269368397514597t_prod @ B @ A @ G @ C5 )
= ( groups7121269368397514597t_prod @ B @ A @ H2 @ C5 ) ) ) ) ) ) ) ) ) ).
% prod.same_carrier
thf(fact_2556_prod_OatLeast0__atMost__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) ) @ ( G @ ( suc @ N2 ) ) ) ) ) ).
% prod.atLeast0_atMost_Suc
thf(fact_2557_powser__sums__zero,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [A3: nat > A] :
( sums @ A
@ ^ [N: nat] : ( times_times @ A @ ( A3 @ N ) @ ( power_power @ A @ ( zero_zero @ A ) @ N ) )
@ ( A3 @ ( zero_zero @ nat ) ) ) ) ).
% powser_sums_zero
thf(fact_2558_prod_OatLeast__Suc__atMost,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( times_times @ A @ ( G @ M ) @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ N2 ) ) ) ) ) ) ).
% prod.atLeast_Suc_atMost
thf(fact_2559_prod_Onat__ivl__Suc_H,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ ( suc @ N2 ) )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( G @ ( suc @ N2 ) ) @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ) ) ).
% prod.nat_ivl_Suc'
thf(fact_2560_prod_OlessThan__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_ord_lessThan @ nat @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( G @ ( zero_zero @ nat ) )
@ ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ).
% prod.lessThan_Suc_shift
thf(fact_2561_prod_OSuc__reindex__ivl,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( times_times @ A @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) @ ( G @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( G @ M )
@ ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ) ) ).
% prod.Suc_reindex_ivl
thf(fact_2562_prod_OatLeast1__atMost__eq,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [K2: nat] : ( G @ ( suc @ K2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ).
% prod.atLeast1_atMost_eq
thf(fact_2563_prod__mono__strict,axiom,
! [A: $tType,B: $tType] :
( ( linordered_semidom @ A )
=> ! [A4: set @ B,F2: B > A,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ I3 ) )
& ( ord_less @ A @ ( F2 @ I3 ) @ ( G @ I3 ) ) ) )
=> ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ord_less @ A @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) @ ( groups7121269368397514597t_prod @ B @ A @ G @ A4 ) ) ) ) ) ) ).
% prod_mono_strict
thf(fact_2564_prod_Oremove,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A4: set @ B,X: B,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( member2 @ B @ X @ A4 )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ A4 )
= ( times_times @ A @ ( G @ X ) @ ( groups7121269368397514597t_prod @ B @ A @ G @ ( minus_minus @ ( set @ B ) @ A4 @ ( insert2 @ B @ X @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ) ) ) ).
% prod.remove
thf(fact_2565_prod_Oinsert__remove,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A4: set @ B,G: B > A,X: B] :
( ( finite_finite @ B @ A4 )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ ( insert2 @ B @ X @ A4 ) )
= ( times_times @ A @ ( G @ X ) @ ( groups7121269368397514597t_prod @ B @ A @ G @ ( minus_minus @ ( set @ B ) @ A4 @ ( insert2 @ B @ X @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ) ) ).
% prod.insert_remove
thf(fact_2566_prod_Oub__add__nat,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [M: nat,N2: nat,G: nat > A,P4: nat] :
( ( ord_less_eq @ nat @ M @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ ( plus_plus @ nat @ N2 @ P4 ) ) )
= ( times_times @ A @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) @ ( plus_plus @ nat @ N2 @ P4 ) ) ) ) ) ) ) ).
% prod.ub_add_nat
thf(fact_2567_prod_Odelta__remove,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [S3: set @ B,A3: B,B2: B > A,C2: B > A] :
( ( finite_finite @ B @ S3 )
=> ( ( ( member2 @ B @ A3 @ S3 )
=> ( ( groups7121269368397514597t_prod @ B @ A
@ ^ [K2: B] : ( if @ A @ ( K2 = A3 ) @ ( B2 @ K2 ) @ ( C2 @ K2 ) )
@ S3 )
= ( times_times @ A @ ( B2 @ A3 ) @ ( groups7121269368397514597t_prod @ B @ A @ C2 @ ( minus_minus @ ( set @ B ) @ S3 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) )
& ( ~ ( member2 @ B @ A3 @ S3 )
=> ( ( groups7121269368397514597t_prod @ B @ A
@ ^ [K2: B] : ( if @ A @ ( K2 = A3 ) @ ( B2 @ K2 ) @ ( C2 @ K2 ) )
@ S3 )
= ( groups7121269368397514597t_prod @ B @ A @ C2 @ ( minus_minus @ ( set @ B ) @ S3 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ) ) ) ).
% prod.delta_remove
thf(fact_2568_fold__atLeastAtMost__nat_Osimps,axiom,
! [A: $tType] :
( ( set_fo6178422350223883121st_nat @ A )
= ( ^ [F3: nat > A > A,A5: nat,B4: nat,Acc2: A] : ( if @ A @ ( ord_less @ nat @ B4 @ A5 ) @ Acc2 @ ( set_fo6178422350223883121st_nat @ A @ F3 @ ( plus_plus @ nat @ A5 @ ( one_one @ nat ) ) @ B4 @ ( F3 @ A5 @ Acc2 ) ) ) ) ) ).
% fold_atLeastAtMost_nat.simps
thf(fact_2569_fold__atLeastAtMost__nat_Oelims,axiom,
! [A: $tType,X: nat > A > A,Xa2: nat,Xb: nat,Xc: A,Y: A] :
( ( ( set_fo6178422350223883121st_nat @ A @ X @ Xa2 @ Xb @ Xc )
= Y )
=> ( ( ( ord_less @ nat @ Xb @ Xa2 )
=> ( Y = Xc ) )
& ( ~ ( ord_less @ nat @ Xb @ Xa2 )
=> ( Y
= ( set_fo6178422350223883121st_nat @ A @ X @ ( plus_plus @ nat @ Xa2 @ ( one_one @ nat ) ) @ Xb @ ( X @ Xa2 @ Xc ) ) ) ) ) ) ).
% fold_atLeastAtMost_nat.elims
thf(fact_2570_prod__mono2,axiom,
! [B: $tType,A: $tType] :
( ( linordered_idom @ B )
=> ! [B3: set @ A,A4: set @ A,F2: A > B] :
( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ! [B5: A] :
( ( member2 @ A @ B5 @ ( minus_minus @ ( set @ A ) @ B3 @ A4 ) )
=> ( ord_less_eq @ B @ ( one_one @ B ) @ ( F2 @ B5 ) ) )
=> ( ! [A7: A] :
( ( member2 @ A @ A7 @ A4 )
=> ( ord_less_eq @ B @ ( zero_zero @ B ) @ ( F2 @ A7 ) ) )
=> ( ord_less_eq @ B @ ( groups7121269368397514597t_prod @ A @ B @ F2 @ A4 ) @ ( groups7121269368397514597t_prod @ A @ B @ F2 @ B3 ) ) ) ) ) ) ) ).
% prod_mono2
thf(fact_2571_prod__diff1,axiom,
! [A: $tType,B: $tType] :
( ( semidom_divide @ A )
=> ! [A4: set @ B,F2: B > A,A3: B] :
( ( finite_finite @ B @ A4 )
=> ( ( ( F2 @ A3 )
!= ( zero_zero @ A ) )
=> ( ( ( member2 @ B @ A3 @ A4 )
=> ( ( groups7121269368397514597t_prod @ B @ A @ F2 @ ( minus_minus @ ( set @ B ) @ A4 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) )
= ( divide_divide @ A @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) @ ( F2 @ A3 ) ) ) )
& ( ~ ( member2 @ B @ A3 @ A4 )
=> ( ( groups7121269368397514597t_prod @ B @ A @ F2 @ ( minus_minus @ ( set @ B ) @ A4 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) )
= ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) ) ) ) ) ) ) ).
% prod_diff1
thf(fact_2572_log__of__power__less,axiom,
! [M: nat,B2: real,N2: nat] :
( ( ord_less @ real @ ( semiring_1_of_nat @ real @ M ) @ ( power_power @ real @ B2 @ N2 ) )
=> ( ( ord_less @ real @ ( one_one @ real ) @ B2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ord_less @ real @ ( log @ B2 @ ( semiring_1_of_nat @ real @ M ) ) @ ( semiring_1_of_nat @ real @ N2 ) ) ) ) ) ).
% log_of_power_less
thf(fact_2573_pochhammer__Suc__prod,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A,N2: nat] :
( ( comm_s3205402744901411588hammer @ A @ A3 @ ( suc @ N2 ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( plus_plus @ A @ A3 @ ( semiring_1_of_nat @ A @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% pochhammer_Suc_prod
thf(fact_2574_pochhammer__prod__rev,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ( ( comm_s3205402744901411588hammer @ A )
= ( ^ [A5: A,N: nat] :
( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( plus_plus @ A @ A5 @ ( semiring_1_of_nat @ A @ ( minus_minus @ nat @ N @ I5 ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( one_one @ nat ) @ N ) ) ) ) ) ).
% pochhammer_prod_rev
thf(fact_2575_log__of__power__le,axiom,
! [M: nat,B2: real,N2: nat] :
( ( ord_less_eq @ real @ ( semiring_1_of_nat @ real @ M ) @ ( power_power @ real @ B2 @ N2 ) )
=> ( ( ord_less @ real @ ( one_one @ real ) @ B2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ord_less_eq @ real @ ( log @ B2 @ ( semiring_1_of_nat @ real @ M ) ) @ ( semiring_1_of_nat @ real @ N2 ) ) ) ) ) ).
% log_of_power_le
thf(fact_2576_prod_Oin__pairs,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( G @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) ) @ ( G @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% prod.in_pairs
thf(fact_2577_sum__atLeastAtMost__code,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [F2: nat > A,A3: nat,B2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or1337092689740270186AtMost @ nat @ A3 @ B2 ) )
= ( set_fo6178422350223883121st_nat @ A
@ ^ [A5: nat] : ( plus_plus @ A @ ( F2 @ A5 ) )
@ A3
@ B2
@ ( zero_zero @ A ) ) ) ) ).
% sum_atLeastAtMost_code
thf(fact_2578_pochhammer__Suc__prod__rev,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A,N2: nat] :
( ( comm_s3205402744901411588hammer @ A @ A3 @ ( suc @ N2 ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( plus_plus @ A @ A3 @ ( semiring_1_of_nat @ A @ ( minus_minus @ nat @ N2 @ I5 ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% pochhammer_Suc_prod_rev
thf(fact_2579_less__log2__of__power,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ M )
=> ( ord_less @ real @ ( semiring_1_of_nat @ real @ N2 ) @ ( log @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ real @ M ) ) ) ) ).
% less_log2_of_power
thf(fact_2580_le__log2__of__power,axiom,
! [N2: nat,M: nat] :
( ( ord_less_eq @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ M )
=> ( ord_less_eq @ real @ ( semiring_1_of_nat @ real @ N2 ) @ ( log @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ real @ M ) ) ) ) ).
% le_log2_of_power
thf(fact_2581_log2__of__power__less,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ M @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ord_less @ real @ ( log @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ real @ M ) ) @ ( semiring_1_of_nat @ real @ N2 ) ) ) ) ).
% log2_of_power_less
thf(fact_2582_log2__of__power__le,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ord_less_eq @ real @ ( log @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ real @ M ) ) @ ( semiring_1_of_nat @ real @ N2 ) ) ) ) ).
% log2_of_power_le
thf(fact_2583_ceiling__log2__div2,axiom,
! [N2: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( archimedean_ceiling @ real @ ( log @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ real @ N2 ) ) )
= ( plus_plus @ int @ ( archimedean_ceiling @ real @ ( log @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ real @ ( plus_plus @ nat @ ( divide_divide @ nat @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) ) ) @ ( one_one @ int ) ) ) ) ).
% ceiling_log2_div2
thf(fact_2584_ceiling__log__nat__eq__if,axiom,
! [B2: nat,N2: nat,K: nat] :
( ( ord_less @ nat @ ( power_power @ nat @ B2 @ N2 ) @ K )
=> ( ( ord_less_eq @ nat @ K @ ( power_power @ nat @ B2 @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) ) )
=> ( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ B2 )
=> ( ( archimedean_ceiling @ real @ ( log @ ( semiring_1_of_nat @ real @ B2 ) @ ( semiring_1_of_nat @ real @ K ) ) )
= ( plus_plus @ int @ ( semiring_1_of_nat @ int @ N2 ) @ ( one_one @ int ) ) ) ) ) ) ).
% ceiling_log_nat_eq_if
thf(fact_2585_power__half__series,axiom,
( sums @ real
@ ^ [N: nat] : ( power_power @ real @ ( divide_divide @ real @ ( one_one @ real ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) @ ( suc @ N ) )
@ ( one_one @ real ) ) ).
% power_half_series
thf(fact_2586_sums__zero,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ( sums @ A
@ ^ [N: nat] : ( zero_zero @ A )
@ ( zero_zero @ A ) ) ) ).
% sums_zero
thf(fact_2587_sums__If__finite__set_H,axiom,
! [A: $tType] :
( ( ( topolo1287966508704411220up_add @ A )
& ( topological_t2_space @ A ) )
=> ! [G: nat > A,S3: A,A4: set @ nat,S5: A,F2: nat > A] :
( ( sums @ A @ G @ S3 )
=> ( ( finite_finite @ nat @ A4 )
=> ( ( S5
= ( plus_plus @ A @ S3
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [N: nat] : ( minus_minus @ A @ ( F2 @ N ) @ ( G @ N ) )
@ A4 ) ) )
=> ( sums @ A
@ ^ [N: nat] : ( if @ A @ ( member2 @ nat @ N @ A4 ) @ ( F2 @ N ) @ ( G @ N ) )
@ S5 ) ) ) ) ) ).
% sums_If_finite_set'
thf(fact_2588_sums__iff__shift_H,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,N2: nat,S: A] :
( ( sums @ A
@ ^ [I5: nat] : ( F2 @ ( plus_plus @ nat @ I5 @ N2 ) )
@ ( minus_minus @ A @ S @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_lessThan @ nat @ N2 ) ) ) )
= ( sums @ A @ F2 @ S ) ) ) ).
% sums_iff_shift'
thf(fact_2589_sums__split__initial__segment,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,S: A,N2: nat] :
( ( sums @ A @ F2 @ S )
=> ( sums @ A
@ ^ [I5: nat] : ( F2 @ ( plus_plus @ nat @ I5 @ N2 ) )
@ ( minus_minus @ A @ S @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ) ).
% sums_split_initial_segment
thf(fact_2590_sums__iff__shift,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,N2: nat,S: A] :
( ( sums @ A
@ ^ [I5: nat] : ( F2 @ ( plus_plus @ nat @ I5 @ N2 ) )
@ S )
= ( sums @ A @ F2 @ ( plus_plus @ A @ S @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ) ).
% sums_iff_shift
thf(fact_2591_prod__pos__nat__iff,axiom,
! [A: $tType,A4: set @ A,F2: A > nat] :
( ( finite_finite @ A @ A4 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( groups7121269368397514597t_prod @ A @ nat @ F2 @ A4 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ ( F2 @ X2 ) ) ) ) ) ) ).
% prod_pos_nat_iff
thf(fact_2592_int__prod,axiom,
! [B: $tType,F2: B > nat,A4: set @ B] :
( ( semiring_1_of_nat @ int @ ( groups7121269368397514597t_prod @ B @ nat @ F2 @ A4 ) )
= ( groups7121269368397514597t_prod @ B @ int
@ ^ [X2: B] : ( semiring_1_of_nat @ int @ ( F2 @ X2 ) )
@ A4 ) ) ).
% int_prod
thf(fact_2593_prod__int__plus__eq,axiom,
! [I: nat,J: nat] :
( ( groups7121269368397514597t_prod @ nat @ int @ ( semiring_1_of_nat @ int ) @ ( set_or1337092689740270186AtMost @ nat @ I @ ( plus_plus @ nat @ I @ J ) ) )
= ( groups7121269368397514597t_prod @ int @ int
@ ^ [X2: int] : X2
@ ( set_or1337092689740270186AtMost @ int @ ( semiring_1_of_nat @ int @ I ) @ ( semiring_1_of_nat @ int @ ( plus_plus @ nat @ I @ J ) ) ) ) ) ).
% prod_int_plus_eq
thf(fact_2594_sums__le,axiom,
! [A: $tType] :
( ( ( ordere6911136660526730532id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A,G: nat > A,S: A,T2: A] :
( ! [N3: nat] : ( ord_less_eq @ A @ ( F2 @ N3 ) @ ( G @ N3 ) )
=> ( ( sums @ A @ F2 @ S )
=> ( ( sums @ A @ G @ T2 )
=> ( ord_less_eq @ A @ S @ T2 ) ) ) ) ) ).
% sums_le
thf(fact_2595_sums__0,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [F2: nat > A] :
( ! [N3: nat] :
( ( F2 @ N3 )
= ( zero_zero @ A ) )
=> ( sums @ A @ F2 @ ( zero_zero @ A ) ) ) ) ).
% sums_0
thf(fact_2596_sums__single,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [I: nat,F2: nat > A] :
( sums @ A
@ ^ [R4: nat] : ( if @ A @ ( R4 = I ) @ ( F2 @ R4 ) @ ( zero_zero @ A ) )
@ ( F2 @ I ) ) ) ).
% sums_single
thf(fact_2597_sums__add,axiom,
! [A: $tType] :
( ( ( topolo5987344860129210374id_add @ A )
& ( topological_t2_space @ A ) )
=> ! [F2: nat > A,A3: A,G: nat > A,B2: A] :
( ( sums @ A @ F2 @ A3 )
=> ( ( sums @ A @ G @ B2 )
=> ( sums @ A
@ ^ [N: nat] : ( plus_plus @ A @ ( F2 @ N ) @ ( G @ N ) )
@ ( plus_plus @ A @ A3 @ B2 ) ) ) ) ) ).
% sums_add
thf(fact_2598_sums__mult2__iff,axiom,
! [A: $tType] :
( ( ( field @ A )
& ( real_V4412858255891104859lgebra @ A ) )
=> ! [C2: A,F2: nat > A,D2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( sums @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ N ) @ C2 )
@ ( times_times @ A @ D2 @ C2 ) )
= ( sums @ A @ F2 @ D2 ) ) ) ) ).
% sums_mult2_iff
thf(fact_2599_sums__mult__iff,axiom,
! [A: $tType] :
( ( ( field @ A )
& ( real_V4412858255891104859lgebra @ A ) )
=> ! [C2: A,F2: nat > A,D2: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( sums @ A
@ ^ [N: nat] : ( times_times @ A @ C2 @ ( F2 @ N ) )
@ ( times_times @ A @ C2 @ D2 ) )
= ( sums @ A @ F2 @ D2 ) ) ) ) ).
% sums_mult_iff
thf(fact_2600_sums__mult__D,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [C2: A,F2: nat > A,A3: A] :
( ( sums @ A
@ ^ [N: nat] : ( times_times @ A @ C2 @ ( F2 @ N ) )
@ A3 )
=> ( ( C2
!= ( zero_zero @ A ) )
=> ( sums @ A @ F2 @ ( divide_divide @ A @ A3 @ C2 ) ) ) ) ) ).
% sums_mult_D
thf(fact_2601_sums__Suc__imp,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,S: A] :
( ( ( F2 @ ( zero_zero @ nat ) )
= ( zero_zero @ A ) )
=> ( ( sums @ A
@ ^ [N: nat] : ( F2 @ ( suc @ N ) )
@ S )
=> ( sums @ A @ F2 @ S ) ) ) ) ).
% sums_Suc_imp
thf(fact_2602_sums__Suc__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,S: A] :
( ( sums @ A
@ ^ [N: nat] : ( F2 @ ( suc @ N ) )
@ S )
= ( sums @ A @ F2 @ ( plus_plus @ A @ S @ ( F2 @ ( zero_zero @ nat ) ) ) ) ) ) ).
% sums_Suc_iff
thf(fact_2603_sums__Suc,axiom,
! [A: $tType] :
( ( ( topolo5987344860129210374id_add @ A )
& ( topological_t2_space @ A ) )
=> ! [F2: nat > A,L: A] :
( ( sums @ A
@ ^ [N: nat] : ( F2 @ ( suc @ N ) )
@ L )
=> ( sums @ A @ F2 @ ( plus_plus @ A @ L @ ( F2 @ ( zero_zero @ nat ) ) ) ) ) ) ).
% sums_Suc
thf(fact_2604_sums__zero__iff__shift,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [N2: nat,F2: nat > A,S: A] :
( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ N2 )
=> ( ( F2 @ I3 )
= ( zero_zero @ A ) ) )
=> ( ( sums @ A
@ ^ [I5: nat] : ( F2 @ ( plus_plus @ nat @ I5 @ N2 ) )
@ S )
= ( sums @ A @ F2 @ S ) ) ) ) ).
% sums_zero_iff_shift
thf(fact_2605_sums__finite,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [N7: set @ nat,F2: nat > A] :
( ( finite_finite @ nat @ N7 )
=> ( ! [N3: nat] :
( ~ ( member2 @ nat @ N3 @ N7 )
=> ( ( F2 @ N3 )
= ( zero_zero @ A ) ) )
=> ( sums @ A @ F2 @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ N7 ) ) ) ) ) ).
% sums_finite
thf(fact_2606_sums__If__finite,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [P2: nat > $o,F2: nat > A] :
( ( finite_finite @ nat @ ( collect @ nat @ P2 ) )
=> ( sums @ A
@ ^ [R4: nat] : ( if @ A @ ( P2 @ R4 ) @ ( F2 @ R4 ) @ ( zero_zero @ A ) )
@ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( collect @ nat @ P2 ) ) ) ) ) ).
% sums_If_finite
thf(fact_2607_sums__If__finite__set,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [A4: set @ nat,F2: nat > A] :
( ( finite_finite @ nat @ A4 )
=> ( sums @ A
@ ^ [R4: nat] : ( if @ A @ ( member2 @ nat @ R4 @ A4 ) @ ( F2 @ R4 ) @ ( zero_zero @ A ) )
@ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ A4 ) ) ) ) ).
% sums_If_finite_set
thf(fact_2608_powser__sums__if,axiom,
! [A: $tType] :
( ( ( ring_1 @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [M: nat,Z: A] :
( sums @ A
@ ^ [N: nat] : ( times_times @ A @ ( if @ A @ ( N = M ) @ ( one_one @ A ) @ ( zero_zero @ A ) ) @ ( power_power @ A @ Z @ N ) )
@ ( power_power @ A @ Z @ M ) ) ) ).
% powser_sums_if
thf(fact_2609_ln__series,axiom,
! [X: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ X )
=> ( ( ord_less @ real @ X @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) )
=> ( ( ln_ln @ real @ X )
= ( suminf @ real
@ ^ [N: nat] : ( times_times @ real @ ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ N ) @ ( divide_divide @ real @ ( one_one @ real ) @ ( semiring_1_of_nat @ real @ ( plus_plus @ nat @ N @ ( one_one @ nat ) ) ) ) ) @ ( power_power @ real @ ( minus_minus @ real @ X @ ( one_one @ real ) ) @ ( suc @ N ) ) ) ) ) ) ) ).
% ln_series
thf(fact_2610_ceiling__log__eq__powr__iff,axiom,
! [X: real,B2: real,K: nat] :
( ( ord_less @ real @ ( zero_zero @ real ) @ X )
=> ( ( ord_less @ real @ ( one_one @ real ) @ B2 )
=> ( ( ( archimedean_ceiling @ real @ ( log @ B2 @ X ) )
= ( plus_plus @ int @ ( semiring_1_of_nat @ int @ K ) @ ( one_one @ int ) ) )
= ( ( ord_less @ real @ ( powr @ real @ B2 @ ( semiring_1_of_nat @ real @ K ) ) @ X )
& ( ord_less_eq @ real @ X @ ( powr @ real @ B2 @ ( semiring_1_of_nat @ real @ ( plus_plus @ nat @ K @ ( one_one @ nat ) ) ) ) ) ) ) ) ) ).
% ceiling_log_eq_powr_iff
thf(fact_2611_floor__log__nat__eq__powr__iff,axiom,
! [B2: nat,K: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ B2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ( ( archim6421214686448440834_floor @ real @ ( log @ ( semiring_1_of_nat @ real @ B2 ) @ ( semiring_1_of_nat @ real @ K ) ) )
= ( semiring_1_of_nat @ int @ N2 ) )
= ( ( ord_less_eq @ nat @ ( power_power @ nat @ B2 @ N2 ) @ K )
& ( ord_less @ nat @ K @ ( power_power @ nat @ B2 @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) ) ) ) ) ) ) ).
% floor_log_nat_eq_powr_iff
thf(fact_2612_and__int_Opelims,axiom,
! [X: int,Xa2: int,Y: int] :
( ( ( bit_se5824344872417868541ns_and @ int @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ int @ int ) @ bit_and_int_rel @ ( product_Pair @ int @ int @ X @ Xa2 ) )
=> ~ ( ( ( ( ( member2 @ int @ X @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) )
& ( member2 @ int @ Xa2 @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) ) )
=> ( Y
= ( uminus_uminus @ int
@ ( zero_neq_one_of_bool @ int
@ ( ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ X )
& ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ Xa2 ) ) ) ) ) )
& ( ~ ( ( member2 @ int @ X @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) )
& ( member2 @ int @ Xa2 @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) ) )
=> ( Y
= ( plus_plus @ int
@ ( zero_neq_one_of_bool @ int
@ ( ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ X )
& ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ Xa2 ) ) )
@ ( times_times @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ ( bit_se5824344872417868541ns_and @ int @ ( divide_divide @ int @ X @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ int @ Xa2 @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) ) ) ) ) ) )
=> ~ ( accp @ ( product_prod @ int @ int ) @ bit_and_int_rel @ ( product_Pair @ int @ int @ X @ Xa2 ) ) ) ) ) ).
% and_int.pelims
thf(fact_2613_and__int_Opsimps,axiom,
! [K: int,L: int] :
( ( accp @ ( product_prod @ int @ int ) @ bit_and_int_rel @ ( product_Pair @ int @ int @ K @ L ) )
=> ( ( ( ( member2 @ int @ K @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) )
& ( member2 @ int @ L @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) ) )
=> ( ( bit_se5824344872417868541ns_and @ int @ K @ L )
= ( uminus_uminus @ int
@ ( zero_neq_one_of_bool @ int
@ ( ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ K )
& ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ L ) ) ) ) ) )
& ( ~ ( ( member2 @ int @ K @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) )
& ( member2 @ int @ L @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) ) )
=> ( ( bit_se5824344872417868541ns_and @ int @ K @ L )
= ( plus_plus @ int
@ ( zero_neq_one_of_bool @ int
@ ( ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ K )
& ~ ( dvd_dvd @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ L ) ) )
@ ( times_times @ int @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) @ ( bit_se5824344872417868541ns_and @ int @ ( divide_divide @ int @ K @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ int @ L @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ).
% and_int.psimps
thf(fact_2614_gchoose__row__sum__weighted,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [R2: A,M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( times_times @ A @ ( gbinomial @ A @ R2 @ K2 ) @ ( minus_minus @ A @ ( divide_divide @ A @ R2 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( semiring_1_of_nat @ A @ K2 ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ M ) )
= ( times_times @ A @ ( divide_divide @ A @ ( semiring_1_of_nat @ A @ ( suc @ M ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( gbinomial @ A @ R2 @ ( suc @ M ) ) ) ) ) ).
% gchoose_row_sum_weighted
thf(fact_2615_powr__0,axiom,
! [A: $tType] :
( ( ln @ A )
=> ! [Z: A] :
( ( powr @ A @ ( zero_zero @ A ) @ Z )
= ( zero_zero @ A ) ) ) ).
% powr_0
thf(fact_2616_powr__eq__0__iff,axiom,
! [A: $tType] :
( ( ln @ A )
=> ! [W2: A,Z: A] :
( ( ( powr @ A @ W2 @ Z )
= ( zero_zero @ A ) )
= ( W2
= ( zero_zero @ A ) ) ) ) ).
% powr_eq_0_iff
thf(fact_2617_suminf__zero,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topological_t2_space @ A ) )
=> ( ( suminf @ A
@ ^ [N: nat] : ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% suminf_zero
thf(fact_2618_powr__zero__eq__one,axiom,
! [A: $tType] :
( ( ln @ A )
=> ! [X: A] :
( ( ( X
= ( zero_zero @ A ) )
=> ( ( powr @ A @ X @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) )
& ( ( X
!= ( zero_zero @ A ) )
=> ( ( powr @ A @ X @ ( zero_zero @ A ) )
= ( one_one @ A ) ) ) ) ) ).
% powr_zero_eq_one
thf(fact_2619_floor__zero,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ( ( archim6421214686448440834_floor @ A @ ( zero_zero @ A ) )
= ( zero_zero @ int ) ) ) ).
% floor_zero
thf(fact_2620_gbinomial__0_I2_J,axiom,
! [B: $tType] :
( ( ( semiring_char_0 @ B )
& ( semidom_divide @ B ) )
=> ! [K: nat] :
( ( gbinomial @ B @ ( zero_zero @ B ) @ ( suc @ K ) )
= ( zero_zero @ B ) ) ) ).
% gbinomial_0(2)
thf(fact_2621_gbinomial__0_I1_J,axiom,
! [A: $tType] :
( ( ( semiring_char_0 @ A )
& ( semidom_divide @ A ) )
=> ! [A3: A] :
( ( gbinomial @ A @ A3 @ ( zero_zero @ nat ) )
= ( one_one @ A ) ) ) ).
% gbinomial_0(1)
thf(fact_2622_gbinomial__Suc0,axiom,
! [A: $tType] :
( ( ( semiring_char_0 @ A )
& ( semidom_divide @ A ) )
=> ! [A3: A] :
( ( gbinomial @ A @ A3 @ ( suc @ ( zero_zero @ nat ) ) )
= A3 ) ) ).
% gbinomial_Suc0
thf(fact_2623_zero__le__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ ( archim6421214686448440834_floor @ A @ X ) )
= ( ord_less_eq @ A @ ( zero_zero @ A ) @ X ) ) ) ).
% zero_le_floor
thf(fact_2624_floor__less__zero,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( zero_zero @ int ) )
= ( ord_less @ A @ X @ ( zero_zero @ A ) ) ) ) ).
% floor_less_zero
thf(fact_2625_numeral__le__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [V2: num,X: A] :
( ( ord_less_eq @ int @ ( numeral_numeral @ int @ V2 ) @ ( archim6421214686448440834_floor @ A @ X ) )
= ( ord_less_eq @ A @ ( numeral_numeral @ A @ V2 ) @ X ) ) ) ).
% numeral_le_floor
thf(fact_2626_zero__less__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less @ int @ ( zero_zero @ int ) @ ( archim6421214686448440834_floor @ A @ X ) )
= ( ord_less_eq @ A @ ( one_one @ A ) @ X ) ) ) ).
% zero_less_floor
thf(fact_2627_floor__le__zero,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less_eq @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( zero_zero @ int ) )
= ( ord_less @ A @ X @ ( one_one @ A ) ) ) ) ).
% floor_le_zero
thf(fact_2628_floor__less__numeral,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,V2: num] :
( ( ord_less @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( numeral_numeral @ int @ V2 ) )
= ( ord_less @ A @ X @ ( numeral_numeral @ A @ V2 ) ) ) ) ).
% floor_less_numeral
thf(fact_2629_one__le__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less_eq @ int @ ( one_one @ int ) @ ( archim6421214686448440834_floor @ A @ X ) )
= ( ord_less_eq @ A @ ( one_one @ A ) @ X ) ) ) ).
% one_le_floor
thf(fact_2630_floor__less__one,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( one_one @ int ) )
= ( ord_less @ A @ X @ ( one_one @ A ) ) ) ) ).
% floor_less_one
thf(fact_2631_powser__zero,axiom,
! [A: $tType] :
( ( real_V2822296259951069270ebra_1 @ A )
=> ! [F2: nat > A] :
( ( suminf @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ N ) @ ( power_power @ A @ ( zero_zero @ A ) @ N ) ) )
= ( F2 @ ( zero_zero @ nat ) ) ) ) ).
% powser_zero
thf(fact_2632_numeral__less__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [V2: num,X: A] :
( ( ord_less @ int @ ( numeral_numeral @ int @ V2 ) @ ( archim6421214686448440834_floor @ A @ X ) )
= ( ord_less_eq @ A @ ( plus_plus @ A @ ( numeral_numeral @ A @ V2 ) @ ( one_one @ A ) ) @ X ) ) ) ).
% numeral_less_floor
thf(fact_2633_floor__le__numeral,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,V2: num] :
( ( ord_less_eq @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( numeral_numeral @ int @ V2 ) )
= ( ord_less @ A @ X @ ( plus_plus @ A @ ( numeral_numeral @ A @ V2 ) @ ( one_one @ A ) ) ) ) ) ).
% floor_le_numeral
thf(fact_2634_one__less__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less @ int @ ( one_one @ int ) @ ( archim6421214686448440834_floor @ A @ X ) )
= ( ord_less_eq @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ X ) ) ) ).
% one_less_floor
thf(fact_2635_floor__le__one,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less_eq @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( one_one @ int ) )
= ( ord_less @ A @ X @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% floor_le_one
thf(fact_2636_neg__numeral__le__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [V2: num,X: A] :
( ( ord_less_eq @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ V2 ) ) @ ( archim6421214686448440834_floor @ A @ X ) )
= ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) @ X ) ) ) ).
% neg_numeral_le_floor
thf(fact_2637_floor__less__neg__numeral,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,V2: num] :
( ( ord_less @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ V2 ) ) )
= ( ord_less @ A @ X @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) ) ) ) ).
% floor_less_neg_numeral
thf(fact_2638_neg__numeral__less__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [V2: num,X: A] :
( ( ord_less @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ V2 ) ) @ ( archim6421214686448440834_floor @ A @ X ) )
= ( ord_less_eq @ A @ ( plus_plus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) @ ( one_one @ A ) ) @ X ) ) ) ).
% neg_numeral_less_floor
thf(fact_2639_floor__le__neg__numeral,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,V2: num] :
( ( ord_less_eq @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ V2 ) ) )
= ( ord_less @ A @ X @ ( plus_plus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) @ ( one_one @ A ) ) ) ) ) ).
% floor_le_neg_numeral
thf(fact_2640_floor__mono,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ord_less_eq @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( archim6421214686448440834_floor @ A @ Y ) ) ) ) ).
% floor_mono
thf(fact_2641_of__int__floor__le,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] : ( ord_less_eq @ A @ ( ring_1_of_int @ A @ ( archim6421214686448440834_floor @ A @ X ) ) @ X ) ) ).
% of_int_floor_le
thf(fact_2642_floor__less__cancel,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( archim6421214686448440834_floor @ A @ Y ) )
=> ( ord_less @ A @ X @ Y ) ) ) ).
% floor_less_cancel
thf(fact_2643_le__floor__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Z: int,X: A] :
( ( ord_less_eq @ int @ Z @ ( archim6421214686448440834_floor @ A @ X ) )
= ( ord_less_eq @ A @ ( ring_1_of_int @ A @ Z ) @ X ) ) ) ).
% le_floor_iff
thf(fact_2644_floor__less__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Z: int] :
( ( ord_less @ int @ ( archim6421214686448440834_floor @ A @ X ) @ Z )
= ( ord_less @ A @ X @ ( ring_1_of_int @ A @ Z ) ) ) ) ).
% floor_less_iff
thf(fact_2645_le__floor__add,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ int @ ( plus_plus @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( archim6421214686448440834_floor @ A @ Y ) ) @ ( archim6421214686448440834_floor @ A @ ( plus_plus @ A @ X @ Y ) ) ) ) ).
% le_floor_add
thf(fact_2646_floor__add__int,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Z: int] :
( ( plus_plus @ int @ ( archim6421214686448440834_floor @ A @ X ) @ Z )
= ( archim6421214686448440834_floor @ A @ ( plus_plus @ A @ X @ ( ring_1_of_int @ A @ Z ) ) ) ) ) ).
% floor_add_int
thf(fact_2647_int__add__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Z: int,X: A] :
( ( plus_plus @ int @ Z @ ( archim6421214686448440834_floor @ A @ X ) )
= ( archim6421214686448440834_floor @ A @ ( plus_plus @ A @ ( ring_1_of_int @ A @ Z ) @ X ) ) ) ) ).
% int_add_floor
thf(fact_2648_gbinomial__Suc__Suc,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,K: nat] :
( ( gbinomial @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ ( suc @ K ) )
= ( plus_plus @ A @ ( gbinomial @ A @ A3 @ K ) @ ( gbinomial @ A @ A3 @ ( suc @ K ) ) ) ) ) ).
% gbinomial_Suc_Suc
thf(fact_2649_gbinomial__of__nat__symmetric,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( gbinomial @ A @ ( semiring_1_of_nat @ A @ N2 ) @ K )
= ( gbinomial @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( minus_minus @ nat @ N2 @ K ) ) ) ) ) ).
% gbinomial_of_nat_symmetric
thf(fact_2650_powr__add,axiom,
! [A: $tType] :
( ( ( real_V3459762299906320749_field @ A )
& ( ln @ A ) )
=> ! [X: A,A3: A,B2: A] :
( ( powr @ A @ X @ ( plus_plus @ A @ A3 @ B2 ) )
= ( times_times @ A @ ( powr @ A @ X @ A3 ) @ ( powr @ A @ X @ B2 ) ) ) ) ).
% powr_add
thf(fact_2651_suminf__finite,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topological_t2_space @ A ) )
=> ! [N7: set @ nat,F2: nat > A] :
( ( finite_finite @ nat @ N7 )
=> ( ! [N3: nat] :
( ~ ( member2 @ nat @ N3 @ N7 )
=> ( ( F2 @ N3 )
= ( zero_zero @ A ) ) )
=> ( ( suminf @ A @ F2 )
= ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ N7 ) ) ) ) ) ).
% suminf_finite
thf(fact_2652_one__add__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( plus_plus @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( one_one @ int ) )
= ( archim6421214686448440834_floor @ A @ ( plus_plus @ A @ X @ ( one_one @ A ) ) ) ) ) ).
% one_add_floor
thf(fact_2653_gbinomial__addition__formula,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,K: nat] :
( ( gbinomial @ A @ A3 @ ( suc @ K ) )
= ( plus_plus @ A @ ( gbinomial @ A @ ( minus_minus @ A @ A3 @ ( one_one @ A ) ) @ ( suc @ K ) ) @ ( gbinomial @ A @ ( minus_minus @ A @ A3 @ ( one_one @ A ) ) @ K ) ) ) ) ).
% gbinomial_addition_formula
thf(fact_2654_gbinomial__ge__n__over__k__pow__k,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [K: nat,A3: A] :
( ( ord_less_eq @ A @ ( semiring_1_of_nat @ A @ K ) @ A3 )
=> ( ord_less_eq @ A @ ( power_power @ A @ ( divide_divide @ A @ A3 @ ( semiring_1_of_nat @ A @ K ) ) @ K ) @ ( gbinomial @ A @ A3 @ K ) ) ) ) ).
% gbinomial_ge_n_over_k_pow_k
thf(fact_2655_gbinomial__mult__1,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,K: nat] :
( ( times_times @ A @ A3 @ ( gbinomial @ A @ A3 @ K ) )
= ( plus_plus @ A @ ( times_times @ A @ ( semiring_1_of_nat @ A @ K ) @ ( gbinomial @ A @ A3 @ K ) ) @ ( times_times @ A @ ( semiring_1_of_nat @ A @ ( suc @ K ) ) @ ( gbinomial @ A @ A3 @ ( suc @ K ) ) ) ) ) ) ).
% gbinomial_mult_1
thf(fact_2656_gbinomial__mult__1_H,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,K: nat] :
( ( times_times @ A @ ( gbinomial @ A @ A3 @ K ) @ A3 )
= ( plus_plus @ A @ ( times_times @ A @ ( semiring_1_of_nat @ A @ K ) @ ( gbinomial @ A @ A3 @ K ) ) @ ( times_times @ A @ ( semiring_1_of_nat @ A @ ( suc @ K ) ) @ ( gbinomial @ A @ A3 @ ( suc @ K ) ) ) ) ) ) ).
% gbinomial_mult_1'
thf(fact_2657_floor__unique,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Z: int,X: A] :
( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ Z ) @ X )
=> ( ( ord_less @ A @ X @ ( plus_plus @ A @ ( ring_1_of_int @ A @ Z ) @ ( one_one @ A ) ) )
=> ( ( archim6421214686448440834_floor @ A @ X )
= Z ) ) ) ) ).
% floor_unique
thf(fact_2658_floor__eq__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,A3: int] :
( ( ( archim6421214686448440834_floor @ A @ X )
= A3 )
= ( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ A3 ) @ X )
& ( ord_less @ A @ X @ ( plus_plus @ A @ ( ring_1_of_int @ A @ A3 ) @ ( one_one @ A ) ) ) ) ) ) ).
% floor_eq_iff
thf(fact_2659_floor__split,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [P2: int > $o,T2: A] :
( ( P2 @ ( archim6421214686448440834_floor @ A @ T2 ) )
= ( ! [I5: int] :
( ( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ I5 ) @ T2 )
& ( ord_less @ A @ T2 @ ( plus_plus @ A @ ( ring_1_of_int @ A @ I5 ) @ ( one_one @ A ) ) ) )
=> ( P2 @ I5 ) ) ) ) ) ).
% floor_split
thf(fact_2660_le__mult__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ord_less_eq @ int @ ( times_times @ int @ ( archim6421214686448440834_floor @ A @ A3 ) @ ( archim6421214686448440834_floor @ A @ B2 ) ) @ ( archim6421214686448440834_floor @ A @ ( times_times @ A @ A3 @ B2 ) ) ) ) ) ) ).
% le_mult_floor
thf(fact_2661_less__floor__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Z: int,X: A] :
( ( ord_less @ int @ Z @ ( archim6421214686448440834_floor @ A @ X ) )
= ( ord_less_eq @ A @ ( plus_plus @ A @ ( ring_1_of_int @ A @ Z ) @ ( one_one @ A ) ) @ X ) ) ) ).
% less_floor_iff
thf(fact_2662_floor__le__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Z: int] :
( ( ord_less_eq @ int @ ( archim6421214686448440834_floor @ A @ X ) @ Z )
= ( ord_less @ A @ X @ ( plus_plus @ A @ ( ring_1_of_int @ A @ Z ) @ ( one_one @ A ) ) ) ) ) ).
% floor_le_iff
thf(fact_2663_floor__correct,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less_eq @ A @ ( ring_1_of_int @ A @ ( archim6421214686448440834_floor @ A @ X ) ) @ X )
& ( ord_less @ A @ X @ ( ring_1_of_int @ A @ ( plus_plus @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( one_one @ int ) ) ) ) ) ) ).
% floor_correct
thf(fact_2664_Suc__times__gbinomial,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [K: nat,A3: A] :
( ( times_times @ A @ ( semiring_1_of_nat @ A @ ( suc @ K ) ) @ ( gbinomial @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ ( suc @ K ) ) )
= ( times_times @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ ( gbinomial @ A @ A3 @ K ) ) ) ) ).
% Suc_times_gbinomial
thf(fact_2665_gbinomial__absorption,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [K: nat,A3: A] :
( ( times_times @ A @ ( semiring_1_of_nat @ A @ ( suc @ K ) ) @ ( gbinomial @ A @ A3 @ ( suc @ K ) ) )
= ( times_times @ A @ A3 @ ( gbinomial @ A @ ( minus_minus @ A @ A3 @ ( one_one @ A ) ) @ K ) ) ) ) ).
% gbinomial_absorption
thf(fact_2666_gbinomial__trinomial__revision,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [K: nat,M: nat,A3: A] :
( ( ord_less_eq @ nat @ K @ M )
=> ( ( times_times @ A @ ( gbinomial @ A @ A3 @ M ) @ ( gbinomial @ A @ ( semiring_1_of_nat @ A @ M ) @ K ) )
= ( times_times @ A @ ( gbinomial @ A @ A3 @ K ) @ ( gbinomial @ A @ ( minus_minus @ A @ A3 @ ( semiring_1_of_nat @ A @ K ) ) @ ( minus_minus @ nat @ M @ K ) ) ) ) ) ) ).
% gbinomial_trinomial_revision
thf(fact_2667_floor__divide__lower,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Q2: A,P4: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Q2 )
=> ( ord_less_eq @ A @ ( times_times @ A @ ( ring_1_of_int @ A @ ( archim6421214686448440834_floor @ A @ ( divide_divide @ A @ P4 @ Q2 ) ) ) @ Q2 ) @ P4 ) ) ) ).
% floor_divide_lower
thf(fact_2668_gbinomial__rec,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,K: nat] :
( ( gbinomial @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ ( suc @ K ) )
= ( times_times @ A @ ( gbinomial @ A @ A3 @ K ) @ ( divide_divide @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ ( semiring_1_of_nat @ A @ ( suc @ K ) ) ) ) ) ) ).
% gbinomial_rec
thf(fact_2669_gbinomial__factors,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,K: nat] :
( ( gbinomial @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ ( suc @ K ) )
= ( times_times @ A @ ( divide_divide @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ ( semiring_1_of_nat @ A @ ( suc @ K ) ) ) @ ( gbinomial @ A @ A3 @ K ) ) ) ) ).
% gbinomial_factors
thf(fact_2670_floor__divide__upper,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Q2: A,P4: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Q2 )
=> ( ord_less @ A @ P4 @ ( times_times @ A @ ( plus_plus @ A @ ( ring_1_of_int @ A @ ( archim6421214686448440834_floor @ A @ ( divide_divide @ A @ P4 @ Q2 ) ) ) @ ( one_one @ A ) ) @ Q2 ) ) ) ) ).
% floor_divide_upper
thf(fact_2671_round__def,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ( ( archimedean_round @ A )
= ( ^ [X2: A] : ( archim6421214686448440834_floor @ A @ ( plus_plus @ A @ X2 @ ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% round_def
thf(fact_2672_gbinomial__minus,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,K: nat] :
( ( gbinomial @ A @ ( uminus_uminus @ A @ A3 ) @ K )
= ( times_times @ A @ ( power_power @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ K ) @ ( gbinomial @ A @ ( minus_minus @ A @ ( plus_plus @ A @ A3 @ ( semiring_1_of_nat @ A @ K ) ) @ ( one_one @ A ) ) @ K ) ) ) ) ).
% gbinomial_minus
thf(fact_2673_gbinomial__reduce__nat,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [K: nat,A3: A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ( gbinomial @ A @ A3 @ K )
= ( plus_plus @ A @ ( gbinomial @ A @ ( minus_minus @ A @ A3 @ ( one_one @ A ) ) @ ( minus_minus @ nat @ K @ ( one_one @ nat ) ) ) @ ( gbinomial @ A @ ( minus_minus @ A @ A3 @ ( one_one @ A ) ) @ K ) ) ) ) ) ).
% gbinomial_reduce_nat
thf(fact_2674_and__int_Opinduct,axiom,
! [A0: int,A12: int,P2: int > int > $o] :
( ( accp @ ( product_prod @ int @ int ) @ bit_and_int_rel @ ( product_Pair @ int @ int @ A0 @ A12 ) )
=> ( ! [K3: int,L4: int] :
( ( accp @ ( product_prod @ int @ int ) @ bit_and_int_rel @ ( product_Pair @ int @ int @ K3 @ L4 ) )
=> ( ( ~ ( ( member2 @ int @ K3 @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) )
& ( member2 @ int @ L4 @ ( insert2 @ int @ ( zero_zero @ int ) @ ( insert2 @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( bot_bot @ ( set @ int ) ) ) ) ) )
=> ( P2 @ ( divide_divide @ int @ K3 @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ int @ L4 @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) ) ) )
=> ( P2 @ K3 @ L4 ) ) )
=> ( P2 @ A0 @ A12 ) ) ) ).
% and_int.pinduct
thf(fact_2675_gbinomial__sum__up__index,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [K: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [J3: nat] : ( gbinomial @ A @ ( semiring_1_of_nat @ A @ J3 ) @ K )
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) )
= ( gbinomial @ A @ ( plus_plus @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( one_one @ A ) ) @ ( plus_plus @ nat @ K @ ( one_one @ nat ) ) ) ) ) ).
% gbinomial_sum_up_index
thf(fact_2676_gbinomial__absorption_H,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [K: nat,A3: A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ( gbinomial @ A @ A3 @ K )
= ( times_times @ A @ ( divide_divide @ A @ A3 @ ( semiring_1_of_nat @ A @ K ) ) @ ( gbinomial @ A @ ( minus_minus @ A @ A3 @ ( one_one @ A ) ) @ ( minus_minus @ nat @ K @ ( one_one @ nat ) ) ) ) ) ) ) ).
% gbinomial_absorption'
thf(fact_2677_floor__log2__div2,axiom,
! [N2: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( archim6421214686448440834_floor @ real @ ( log @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ real @ N2 ) ) )
= ( plus_plus @ int @ ( archim6421214686448440834_floor @ real @ ( log @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ real @ ( divide_divide @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) @ ( one_one @ int ) ) ) ) ).
% floor_log2_div2
thf(fact_2678_floor__log__nat__eq__if,axiom,
! [B2: nat,N2: nat,K: nat] :
( ( ord_less_eq @ nat @ ( power_power @ nat @ B2 @ N2 ) @ K )
=> ( ( ord_less @ nat @ K @ ( power_power @ nat @ B2 @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) ) )
=> ( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ B2 )
=> ( ( archim6421214686448440834_floor @ real @ ( log @ ( semiring_1_of_nat @ real @ B2 ) @ ( semiring_1_of_nat @ real @ K ) ) )
= ( semiring_1_of_nat @ int @ N2 ) ) ) ) ) ).
% floor_log_nat_eq_if
thf(fact_2679_pi__series,axiom,
( ( divide_divide @ real @ pi @ ( numeral_numeral @ real @ ( bit0 @ ( bit0 @ one2 ) ) ) )
= ( suminf @ real
@ ^ [K2: nat] : ( divide_divide @ real @ ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ K2 ) @ ( one_one @ real ) ) @ ( semiring_1_of_nat @ real @ ( plus_plus @ nat @ ( times_times @ nat @ K2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) ) ) ) ).
% pi_series
thf(fact_2680_upto_Opinduct,axiom,
! [A0: int,A12: int,P2: int > int > $o] :
( ( accp @ ( product_prod @ int @ int ) @ upto_rel @ ( product_Pair @ int @ int @ A0 @ A12 ) )
=> ( ! [I3: int,J2: int] :
( ( accp @ ( product_prod @ int @ int ) @ upto_rel @ ( product_Pair @ int @ int @ I3 @ J2 ) )
=> ( ( ( ord_less_eq @ int @ I3 @ J2 )
=> ( P2 @ ( plus_plus @ int @ I3 @ ( one_one @ int ) ) @ J2 ) )
=> ( P2 @ I3 @ J2 ) ) )
=> ( P2 @ A0 @ A12 ) ) ) ).
% upto.pinduct
thf(fact_2681_gbinomial__partial__row__sum,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( times_times @ A @ ( gbinomial @ A @ A3 @ K2 ) @ ( minus_minus @ A @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( semiring_1_of_nat @ A @ K2 ) ) )
@ ( set_ord_atMost @ nat @ M ) )
= ( times_times @ A @ ( divide_divide @ A @ ( plus_plus @ A @ ( semiring_1_of_nat @ A @ M ) @ ( one_one @ A ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( gbinomial @ A @ A3 @ ( plus_plus @ nat @ M @ ( one_one @ nat ) ) ) ) ) ) ).
% gbinomial_partial_row_sum
thf(fact_2682_arcosh__def,axiom,
! [A: $tType] :
( ( ln @ A )
=> ( ( arcosh @ A )
= ( ^ [X2: A] : ( ln_ln @ A @ ( plus_plus @ A @ X2 @ ( powr @ A @ ( minus_minus @ A @ ( power_power @ A @ X2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ A ) ) @ ( real_Vector_of_real @ A @ ( divide_divide @ real @ ( one_one @ real ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ).
% arcosh_def
thf(fact_2683_round__altdef,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ( ( archimedean_round @ A )
= ( ^ [X2: A] : ( if @ int @ ( ord_less_eq @ A @ ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ ( archimedean_frac @ A @ X2 ) ) @ ( archimedean_ceiling @ A @ X2 ) @ ( archim6421214686448440834_floor @ A @ X2 ) ) ) ) ) ).
% round_altdef
thf(fact_2684_gbinomial__r__part__sum,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ ( gbinomial @ A @ ( plus_plus @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ A @ M ) ) @ ( one_one @ A ) ) ) @ ( set_ord_atMost @ nat @ M ) )
= ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) ) ) ) ).
% gbinomial_r_part_sum
thf(fact_2685_atMost__iff,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [I: A,K: A] :
( ( member2 @ A @ I @ ( set_ord_atMost @ A @ K ) )
= ( ord_less_eq @ A @ I @ K ) ) ) ).
% atMost_iff
thf(fact_2686_atMost__subset__iff,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_ord_atMost @ A @ X ) @ ( set_ord_atMost @ A @ Y ) )
= ( ord_less_eq @ A @ X @ Y ) ) ) ).
% atMost_subset_iff
thf(fact_2687_of__real__eq__0__iff,axiom,
! [A: $tType] :
( ( real_V2191834092415804123ebra_1 @ A )
=> ! [X: real] :
( ( ( real_Vector_of_real @ A @ X )
= ( zero_zero @ A ) )
= ( X
= ( zero_zero @ real ) ) ) ) ).
% of_real_eq_0_iff
thf(fact_2688_of__real__0,axiom,
! [A: $tType] :
( ( real_V2191834092415804123ebra_1 @ A )
=> ( ( real_Vector_of_real @ A @ ( zero_zero @ real ) )
= ( zero_zero @ A ) ) ) ).
% of_real_0
thf(fact_2689_of__real__add,axiom,
! [A: $tType] :
( ( real_V2191834092415804123ebra_1 @ A )
=> ! [X: real,Y: real] :
( ( real_Vector_of_real @ A @ ( plus_plus @ real @ X @ Y ) )
= ( plus_plus @ A @ ( real_Vector_of_real @ A @ X ) @ ( real_Vector_of_real @ A @ Y ) ) ) ) ).
% of_real_add
thf(fact_2690_frac__of__int,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Z: int] :
( ( archimedean_frac @ A @ ( ring_1_of_int @ A @ Z ) )
= ( zero_zero @ A ) ) ) ).
% frac_of_int
thf(fact_2691_Icc__subset__Iic__iff,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [L: A,H2: A,H3: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ L @ H2 ) @ ( set_ord_atMost @ A @ H3 ) )
= ( ~ ( ord_less_eq @ A @ L @ H2 )
| ( ord_less_eq @ A @ H2 @ H3 ) ) ) ) ).
% Icc_subset_Iic_iff
thf(fact_2692_sum_OatMost__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_ord_atMost @ nat @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_ord_atMost @ nat @ N2 ) ) @ ( G @ ( suc @ N2 ) ) ) ) ) ).
% sum.atMost_Suc
thf(fact_2693_prod_OatMost__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_ord_atMost @ nat @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_ord_atMost @ nat @ N2 ) ) @ ( G @ ( suc @ N2 ) ) ) ) ) ).
% prod.atMost_Suc
thf(fact_2694_atMost__0,axiom,
( ( set_ord_atMost @ nat @ ( zero_zero @ nat ) )
= ( insert2 @ nat @ ( zero_zero @ nat ) @ ( bot_bot @ ( set @ nat ) ) ) ) ).
% atMost_0
thf(fact_2695_not__empty__eq__Iic__eq__empty,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [H2: A] :
( ( bot_bot @ ( set @ A ) )
!= ( set_ord_atMost @ A @ H2 ) ) ) ).
% not_empty_eq_Iic_eq_empty
thf(fact_2696_atMost__def,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( set_ord_atMost @ A )
= ( ^ [U2: A] :
( collect @ A
@ ^ [X2: A] : ( ord_less_eq @ A @ X2 @ U2 ) ) ) ) ) ).
% atMost_def
thf(fact_2697_atMost__atLeast0,axiom,
( ( set_ord_atMost @ nat )
= ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) ) ) ).
% atMost_atLeast0
thf(fact_2698_lessThan__Suc__atMost,axiom,
! [K: nat] :
( ( set_ord_lessThan @ nat @ ( suc @ K ) )
= ( set_ord_atMost @ nat @ K ) ) ).
% lessThan_Suc_atMost
thf(fact_2699_atMost__Suc,axiom,
! [K: nat] :
( ( set_ord_atMost @ nat @ ( suc @ K ) )
= ( insert2 @ nat @ ( suc @ K ) @ ( set_ord_atMost @ nat @ K ) ) ) ).
% atMost_Suc
thf(fact_2700_not__Iic__le__Icc,axiom,
! [A: $tType] :
( ( no_bot @ A )
=> ! [H2: A,L3: A,H3: A] :
~ ( ord_less_eq @ ( set @ A ) @ ( set_ord_atMost @ A @ H2 ) @ ( set_or1337092689740270186AtMost @ A @ L3 @ H3 ) ) ) ).
% not_Iic_le_Icc
thf(fact_2701_frac__ge__0,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( archimedean_frac @ A @ X ) ) ) ).
% frac_ge_0
thf(fact_2702_frac__lt__1,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] : ( ord_less @ A @ ( archimedean_frac @ A @ X ) @ ( one_one @ A ) ) ) ).
% frac_lt_1
thf(fact_2703_frac__1__eq,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( archimedean_frac @ A @ ( plus_plus @ A @ X @ ( one_one @ A ) ) )
= ( archimedean_frac @ A @ X ) ) ) ).
% frac_1_eq
thf(fact_2704_Iic__subset__Iio__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_ord_atMost @ A @ A3 ) @ ( set_ord_lessThan @ A @ B2 ) )
= ( ord_less @ A @ A3 @ B2 ) ) ) ).
% Iic_subset_Iio_iff
thf(fact_2705_norm__less__p1,axiom,
! [A: $tType] :
( ( real_V2822296259951069270ebra_1 @ A )
=> ! [X: A] : ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ X ) @ ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ ( real_Vector_of_real @ A @ ( real_V7770717601297561774m_norm @ A @ X ) ) @ ( one_one @ A ) ) ) ) ) ).
% norm_less_p1
thf(fact_2706_sum_OatMost__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_ord_atMost @ nat @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( G @ ( zero_zero @ nat ) )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) ) ) ).
% sum.atMost_Suc_shift
thf(fact_2707_sum__telescope,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [F2: nat > A,I: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( minus_minus @ A @ ( F2 @ I5 ) @ ( F2 @ ( suc @ I5 ) ) )
@ ( set_ord_atMost @ nat @ I ) )
= ( minus_minus @ A @ ( F2 @ ( zero_zero @ nat ) ) @ ( F2 @ ( suc @ I ) ) ) ) ) ).
% sum_telescope
thf(fact_2708_polyfun__eq__coeffs,axiom,
! [A: $tType] :
( ( ( real_V8999393235501362500lgebra @ A )
& ( idom @ A ) )
=> ! [C2: nat > A,N2: nat,D2: nat > A] :
( ( ! [X2: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ X2 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( D2 @ I5 ) @ ( power_power @ A @ X2 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) )
= ( ! [I5: nat] :
( ( ord_less_eq @ nat @ I5 @ N2 )
=> ( ( C2 @ I5 )
= ( D2 @ I5 ) ) ) ) ) ) ).
% polyfun_eq_coeffs
thf(fact_2709_prod_OatMost__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_ord_atMost @ nat @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( G @ ( zero_zero @ nat ) )
@ ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) ) ) ).
% prod.atMost_Suc_shift
thf(fact_2710_sum_Onested__swap_H,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [A3: nat > nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( groups7311177749621191930dd_sum @ nat @ A @ ( A3 @ I5 ) @ ( set_ord_lessThan @ nat @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [J3: nat] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( A3 @ I5 @ J3 )
@ ( set_or1337092689740270186AtMost @ nat @ ( suc @ J3 ) @ N2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ).
% sum.nested_swap'
thf(fact_2711_prod_Onested__swap_H,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: nat > nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( groups7121269368397514597t_prod @ nat @ A @ ( A3 @ I5 ) @ ( set_ord_lessThan @ nat @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [J3: nat] :
( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( A3 @ I5 @ J3 )
@ ( set_or1337092689740270186AtMost @ nat @ ( suc @ J3 ) @ N2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ).
% prod.nested_swap'
thf(fact_2712_frac__eq,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ( archimedean_frac @ A @ X )
= X )
= ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
& ( ord_less @ A @ X @ ( one_one @ A ) ) ) ) ) ).
% frac_eq
thf(fact_2713_polyfun__eq__0,axiom,
! [A: $tType] :
( ( ( real_V8999393235501362500lgebra @ A )
& ( idom @ A ) )
=> ! [C2: nat > A,N2: nat] :
( ( ! [X2: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ X2 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( zero_zero @ A ) ) )
= ( ! [I5: nat] :
( ( ord_less_eq @ nat @ I5 @ N2 )
=> ( ( C2 @ I5 )
= ( zero_zero @ A ) ) ) ) ) ) ).
% polyfun_eq_0
thf(fact_2714_zero__polynom__imp__zero__coeffs,axiom,
! [A: $tType] :
( ( ( ab_semigroup_mult @ A )
& ( real_V8999393235501362500lgebra @ A ) )
=> ! [C2: nat > A,N2: nat,K: nat] :
( ! [W: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ W @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( zero_zero @ A ) )
=> ( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( C2 @ K )
= ( zero_zero @ A ) ) ) ) ) ).
% zero_polynom_imp_zero_coeffs
thf(fact_2715_frac__add,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Y: A] :
( ( ( ord_less @ A @ ( plus_plus @ A @ ( archimedean_frac @ A @ X ) @ ( archimedean_frac @ A @ Y ) ) @ ( one_one @ A ) )
=> ( ( archimedean_frac @ A @ ( plus_plus @ A @ X @ Y ) )
= ( plus_plus @ A @ ( archimedean_frac @ A @ X ) @ ( archimedean_frac @ A @ Y ) ) ) )
& ( ~ ( ord_less @ A @ ( plus_plus @ A @ ( archimedean_frac @ A @ X ) @ ( archimedean_frac @ A @ Y ) ) @ ( one_one @ A ) )
=> ( ( archimedean_frac @ A @ ( plus_plus @ A @ X @ Y ) )
= ( minus_minus @ A @ ( plus_plus @ A @ ( archimedean_frac @ A @ X ) @ ( archimedean_frac @ A @ Y ) ) @ ( one_one @ A ) ) ) ) ) ) ).
% frac_add
thf(fact_2716_sum_OatMost__shift,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_ord_atMost @ nat @ N2 ) )
= ( plus_plus @ A @ ( G @ ( zero_zero @ nat ) )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ).
% sum.atMost_shift
thf(fact_2717_sum__up__index__split,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [F2: nat > A,M: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_atMost @ nat @ ( plus_plus @ nat @ M @ N2 ) ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_atMost @ nat @ M ) ) @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ ( plus_plus @ nat @ M @ N2 ) ) ) ) ) ) ).
% sum_up_index_split
thf(fact_2718_prod_OatMost__shift,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_ord_atMost @ nat @ N2 ) )
= ( times_times @ A @ ( G @ ( zero_zero @ nat ) )
@ ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ).
% prod.atMost_shift
thf(fact_2719_atLeast1__atMost__eq__remove0,axiom,
! [N2: nat] :
( ( set_or1337092689740270186AtMost @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
= ( minus_minus @ ( set @ nat ) @ ( set_ord_atMost @ nat @ N2 ) @ ( insert2 @ nat @ ( zero_zero @ nat ) @ ( bot_bot @ ( set @ nat ) ) ) ) ) ).
% atLeast1_atMost_eq_remove0
thf(fact_2720_gbinomial__parallel__sum,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( gbinomial @ A @ ( plus_plus @ A @ A3 @ ( semiring_1_of_nat @ A @ K2 ) ) @ K2 )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( gbinomial @ A @ ( plus_plus @ A @ ( plus_plus @ A @ A3 @ ( semiring_1_of_nat @ A @ N2 ) ) @ ( one_one @ A ) ) @ N2 ) ) ) ).
% gbinomial_parallel_sum
thf(fact_2721_sum_Otriangle__reindex__eq,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ ( product_prod @ nat @ nat ) @ A @ ( product_case_prod @ nat @ nat @ A @ G )
@ ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [I5: nat,J3: nat] : ( ord_less_eq @ nat @ ( plus_plus @ nat @ I5 @ J3 ) @ N2 ) ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ I5 @ ( minus_minus @ nat @ K2 @ I5 ) )
@ ( set_ord_atMost @ nat @ K2 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) ) ).
% sum.triangle_reindex_eq
thf(fact_2722_prod_Otriangle__reindex__eq,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ ( product_prod @ nat @ nat ) @ A @ ( product_case_prod @ nat @ nat @ A @ G )
@ ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [I5: nat,J3: nat] : ( ord_less_eq @ nat @ ( plus_plus @ nat @ I5 @ J3 ) @ N2 ) ) ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [K2: nat] :
( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ I5 @ ( minus_minus @ nat @ K2 @ I5 ) )
@ ( set_ord_atMost @ nat @ K2 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) ) ).
% prod.triangle_reindex_eq
thf(fact_2723_sum__gp__basic,axiom,
! [A: $tType] :
( ( ( monoid_mult @ A )
& ( comm_ring @ A ) )
=> ! [X: A,N2: nat] :
( ( times_times @ A @ ( minus_minus @ A @ ( one_one @ A ) @ X ) @ ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ ( set_ord_atMost @ nat @ N2 ) ) )
= ( minus_minus @ A @ ( one_one @ A ) @ ( power_power @ A @ X @ ( suc @ N2 ) ) ) ) ) ).
% sum_gp_basic
thf(fact_2724_polyfun__finite__roots,axiom,
! [A: $tType] :
( ( ( real_V8999393235501362500lgebra @ A )
& ( idom @ A ) )
=> ! [C2: nat > A,N2: nat] :
( ( finite_finite @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ X2 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( zero_zero @ A ) ) ) )
= ( ? [I5: nat] :
( ( ord_less_eq @ nat @ I5 @ N2 )
& ( ( C2 @ I5 )
!= ( zero_zero @ A ) ) ) ) ) ) ).
% polyfun_finite_roots
thf(fact_2725_polyfun__roots__finite,axiom,
! [A: $tType] :
( ( ( real_V8999393235501362500lgebra @ A )
& ( idom @ A ) )
=> ! [C2: nat > A,K: nat,N2: nat] :
( ( ( C2 @ K )
!= ( zero_zero @ A ) )
=> ( ( ord_less_eq @ nat @ K @ N2 )
=> ( finite_finite @ A
@ ( collect @ A
@ ^ [Z6: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ Z6 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% polyfun_roots_finite
thf(fact_2726_polyfun__linear__factor__root,axiom,
! [A: $tType] :
( ( idom @ A )
=> ! [C2: nat > A,A3: A,N2: nat] :
( ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ A3 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( zero_zero @ A ) )
=> ~ ! [B5: nat > A] :
~ ! [Z4: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ Z4 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( times_times @ A @ ( minus_minus @ A @ Z4 @ A3 )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( B5 @ I5 ) @ ( power_power @ A @ Z4 @ I5 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ) ).
% polyfun_linear_factor_root
thf(fact_2727_polyfun__linear__factor,axiom,
! [A: $tType] :
( ( idom @ A )
=> ! [C2: nat > A,N2: nat,A3: A] :
? [B5: nat > A] :
! [Z4: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ Z4 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( plus_plus @ A
@ ( times_times @ A @ ( minus_minus @ A @ Z4 @ A3 )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( B5 @ I5 ) @ ( power_power @ A @ Z4 @ I5 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ A3 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) ) ) ).
% polyfun_linear_factor
thf(fact_2728_sum__power__shift,axiom,
! [A: $tType] :
( ( ( monoid_mult @ A )
& ( comm_ring @ A ) )
=> ! [M: nat,N2: nat,X: A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( times_times @ A @ ( power_power @ A @ X @ M ) @ ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ ( set_ord_atMost @ nat @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ) ) ) ).
% sum_power_shift
thf(fact_2729_sum_Otriangle__reindex,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ ( product_prod @ nat @ nat ) @ A @ ( product_case_prod @ nat @ nat @ A @ G )
@ ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [I5: nat,J3: nat] : ( ord_less @ nat @ ( plus_plus @ nat @ I5 @ J3 ) @ N2 ) ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ I5 @ ( minus_minus @ nat @ K2 @ I5 ) )
@ ( set_ord_atMost @ nat @ K2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ).
% sum.triangle_reindex
thf(fact_2730_prod_Otriangle__reindex,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ ( product_prod @ nat @ nat ) @ A @ ( product_case_prod @ nat @ nat @ A @ G )
@ ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [I5: nat,J3: nat] : ( ord_less @ nat @ ( plus_plus @ nat @ I5 @ J3 ) @ N2 ) ) ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [K2: nat] :
( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ I5 @ ( minus_minus @ nat @ K2 @ I5 ) )
@ ( set_ord_atMost @ nat @ K2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ).
% prod.triangle_reindex
thf(fact_2731_sum_Oin__pairs__0,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_ord_atMost @ nat @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( plus_plus @ A @ ( G @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) ) @ ( G @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) ) ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) ) ).
% sum.in_pairs_0
thf(fact_2732_polynomial__product,axiom,
! [A: $tType] :
( ( idom @ A )
=> ! [M: nat,A3: nat > A,N2: nat,B2: nat > A,X: A] :
( ! [I3: nat] :
( ( ord_less @ nat @ M @ I3 )
=> ( ( A3 @ I3 )
= ( zero_zero @ A ) ) )
=> ( ! [J2: nat] :
( ( ord_less @ nat @ N2 @ J2 )
=> ( ( B2 @ J2 )
= ( zero_zero @ A ) ) )
=> ( ( times_times @ A
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( A3 @ I5 ) @ ( power_power @ A @ X @ I5 ) )
@ ( set_ord_atMost @ nat @ M ) )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [J3: nat] : ( times_times @ A @ ( B2 @ J3 ) @ ( power_power @ A @ X @ J3 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [R4: nat] :
( times_times @ A
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( times_times @ A @ ( A3 @ K2 ) @ ( B2 @ ( minus_minus @ nat @ R4 @ K2 ) ) )
@ ( set_ord_atMost @ nat @ R4 ) )
@ ( power_power @ A @ X @ R4 ) )
@ ( set_ord_atMost @ nat @ ( plus_plus @ nat @ M @ N2 ) ) ) ) ) ) ) ).
% polynomial_product
thf(fact_2733_prod_Oin__pairs__0,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_ord_atMost @ nat @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( G @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) ) @ ( G @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) ) ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) ) ).
% prod.in_pairs_0
thf(fact_2734_polyfun__eq__const,axiom,
! [A: $tType] :
( ( ( real_V8999393235501362500lgebra @ A )
& ( idom @ A ) )
=> ! [C2: nat > A,N2: nat,K: A] :
( ( ! [X2: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ X2 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= K ) )
= ( ( ( C2 @ ( zero_zero @ nat ) )
= K )
& ! [X2: nat] :
( ( member2 @ nat @ X2 @ ( set_or1337092689740270186AtMost @ nat @ ( one_one @ nat ) @ N2 ) )
=> ( ( C2 @ X2 )
= ( zero_zero @ A ) ) ) ) ) ) ).
% polyfun_eq_const
thf(fact_2735_polynomial__product__nat,axiom,
! [M: nat,A3: nat > nat,N2: nat,B2: nat > nat,X: nat] :
( ! [I3: nat] :
( ( ord_less @ nat @ M @ I3 )
=> ( ( A3 @ I3 )
= ( zero_zero @ nat ) ) )
=> ( ! [J2: nat] :
( ( ord_less @ nat @ N2 @ J2 )
=> ( ( B2 @ J2 )
= ( zero_zero @ nat ) ) )
=> ( ( times_times @ nat
@ ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [I5: nat] : ( times_times @ nat @ ( A3 @ I5 ) @ ( power_power @ nat @ X @ I5 ) )
@ ( set_ord_atMost @ nat @ M ) )
@ ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [J3: nat] : ( times_times @ nat @ ( B2 @ J3 ) @ ( power_power @ nat @ X @ J3 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) )
= ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [R4: nat] :
( times_times @ nat
@ ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [K2: nat] : ( times_times @ nat @ ( A3 @ K2 ) @ ( B2 @ ( minus_minus @ nat @ R4 @ K2 ) ) )
@ ( set_ord_atMost @ nat @ R4 ) )
@ ( power_power @ nat @ X @ R4 ) )
@ ( set_ord_atMost @ nat @ ( plus_plus @ nat @ M @ N2 ) ) ) ) ) ) ).
% polynomial_product_nat
thf(fact_2736_floor__add,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Y: A] :
( ( ( ord_less @ A @ ( plus_plus @ A @ ( archimedean_frac @ A @ X ) @ ( archimedean_frac @ A @ Y ) ) @ ( one_one @ A ) )
=> ( ( archim6421214686448440834_floor @ A @ ( plus_plus @ A @ X @ Y ) )
= ( plus_plus @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( archim6421214686448440834_floor @ A @ Y ) ) ) )
& ( ~ ( ord_less @ A @ ( plus_plus @ A @ ( archimedean_frac @ A @ X ) @ ( archimedean_frac @ A @ Y ) ) @ ( one_one @ A ) )
=> ( ( archim6421214686448440834_floor @ A @ ( plus_plus @ A @ X @ Y ) )
= ( plus_plus @ int @ ( plus_plus @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( archim6421214686448440834_floor @ A @ Y ) ) @ ( one_one @ int ) ) ) ) ) ) ).
% floor_add
thf(fact_2737_sum_Ozero__middle,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [P4: nat,K: nat,G: nat > A,H2: nat > A] :
( ( ord_less_eq @ nat @ ( one_one @ nat ) @ P4 )
=> ( ( ord_less_eq @ nat @ K @ P4 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [J3: nat] : ( if @ A @ ( ord_less @ nat @ J3 @ K ) @ ( G @ J3 ) @ ( if @ A @ ( J3 = K ) @ ( zero_zero @ A ) @ ( H2 @ ( minus_minus @ nat @ J3 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) )
@ ( set_ord_atMost @ nat @ P4 ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [J3: nat] : ( if @ A @ ( ord_less @ nat @ J3 @ K ) @ ( G @ J3 ) @ ( H2 @ J3 ) )
@ ( set_ord_atMost @ nat @ ( minus_minus @ nat @ P4 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ) ) ) ).
% sum.zero_middle
thf(fact_2738_prod_Ozero__middle,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [P4: nat,K: nat,G: nat > A,H2: nat > A] :
( ( ord_less_eq @ nat @ ( one_one @ nat ) @ P4 )
=> ( ( ord_less_eq @ nat @ K @ P4 )
=> ( ( groups7121269368397514597t_prod @ nat @ A
@ ^ [J3: nat] : ( if @ A @ ( ord_less @ nat @ J3 @ K ) @ ( G @ J3 ) @ ( if @ A @ ( J3 = K ) @ ( one_one @ A ) @ ( H2 @ ( minus_minus @ nat @ J3 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) )
@ ( set_ord_atMost @ nat @ P4 ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [J3: nat] : ( if @ A @ ( ord_less @ nat @ J3 @ K ) @ ( G @ J3 ) @ ( H2 @ J3 ) )
@ ( set_ord_atMost @ nat @ ( minus_minus @ nat @ P4 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ) ) ) ).
% prod.zero_middle
thf(fact_2739_gbinomial__partial__sum__poly,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [M: nat,A3: A,X: A,Y: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( times_times @ A @ ( times_times @ A @ ( gbinomial @ A @ ( plus_plus @ A @ ( semiring_1_of_nat @ A @ M ) @ A3 ) @ K2 ) @ ( power_power @ A @ X @ K2 ) ) @ ( power_power @ A @ Y @ ( minus_minus @ nat @ M @ K2 ) ) )
@ ( set_ord_atMost @ nat @ M ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( times_times @ A @ ( times_times @ A @ ( gbinomial @ A @ ( uminus_uminus @ A @ A3 ) @ K2 ) @ ( power_power @ A @ ( uminus_uminus @ A @ X ) @ K2 ) ) @ ( power_power @ A @ ( plus_plus @ A @ X @ Y ) @ ( minus_minus @ nat @ M @ K2 ) ) )
@ ( set_ord_atMost @ nat @ M ) ) ) ) ).
% gbinomial_partial_sum_poly
thf(fact_2740_root__polyfun,axiom,
! [A: $tType] :
( ( idom @ A )
=> ! [N2: nat,Z: A,A3: A] :
( ( ord_less_eq @ nat @ ( one_one @ nat ) @ N2 )
=> ( ( ( power_power @ A @ Z @ N2 )
= A3 )
= ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] :
( times_times @ A
@ ( if @ A
@ ( I5
= ( zero_zero @ nat ) )
@ ( uminus_uminus @ A @ A3 )
@ ( if @ A @ ( I5 = N2 ) @ ( one_one @ A ) @ ( zero_zero @ A ) ) )
@ ( power_power @ A @ Z @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( zero_zero @ A ) ) ) ) ) ).
% root_polyfun
thf(fact_2741_sum__gp0,axiom,
! [A: $tType] :
( ( ( division_ring @ A )
& ( comm_ring @ A ) )
=> ! [X: A,N2: nat] :
( ( ( X
= ( one_one @ A ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ ( set_ord_atMost @ nat @ N2 ) )
= ( semiring_1_of_nat @ A @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) ) ) )
& ( ( X
!= ( one_one @ A ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ ( power_power @ A @ X ) @ ( set_ord_atMost @ nat @ N2 ) )
= ( divide_divide @ A @ ( minus_minus @ A @ ( one_one @ A ) @ ( power_power @ A @ X @ ( suc @ N2 ) ) ) @ ( minus_minus @ A @ ( one_one @ A ) @ X ) ) ) ) ) ) ).
% sum_gp0
thf(fact_2742_gbinomial__sum__nat__pow2,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( divide_divide @ A @ ( gbinomial @ A @ ( semiring_1_of_nat @ A @ ( plus_plus @ nat @ M @ K2 ) ) @ K2 ) @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ K2 ) )
@ ( set_ord_atMost @ nat @ M ) )
= ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) ) ) ).
% gbinomial_sum_nat_pow2
thf(fact_2743_gbinomial__partial__sum__poly__xpos,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [M: nat,A3: A,X: A,Y: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( times_times @ A @ ( times_times @ A @ ( gbinomial @ A @ ( plus_plus @ A @ ( semiring_1_of_nat @ A @ M ) @ A3 ) @ K2 ) @ ( power_power @ A @ X @ K2 ) ) @ ( power_power @ A @ Y @ ( minus_minus @ nat @ M @ K2 ) ) )
@ ( set_ord_atMost @ nat @ M ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( times_times @ A @ ( times_times @ A @ ( gbinomial @ A @ ( minus_minus @ A @ ( plus_plus @ A @ ( semiring_1_of_nat @ A @ K2 ) @ A3 ) @ ( one_one @ A ) ) @ K2 ) @ ( power_power @ A @ X @ K2 ) ) @ ( power_power @ A @ ( plus_plus @ A @ X @ Y ) @ ( minus_minus @ nat @ M @ K2 ) ) )
@ ( set_ord_atMost @ nat @ M ) ) ) ) ).
% gbinomial_partial_sum_poly_xpos
thf(fact_2744_polyfun__diff__alt,axiom,
! [A: $tType] :
( ( idom @ A )
=> ! [N2: nat,A3: nat > A,X: A,Y: A] :
( ( ord_less_eq @ nat @ ( one_one @ nat ) @ N2 )
=> ( ( minus_minus @ A
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( A3 @ I5 ) @ ( power_power @ A @ X @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( A3 @ I5 ) @ ( power_power @ A @ Y @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) )
= ( times_times @ A @ ( minus_minus @ A @ X @ Y )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [J3: nat] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( times_times @ A @ ( times_times @ A @ ( A3 @ ( plus_plus @ nat @ ( plus_plus @ nat @ J3 @ K2 ) @ ( one_one @ nat ) ) ) @ ( power_power @ A @ Y @ K2 ) ) @ ( power_power @ A @ X @ J3 ) )
@ ( set_ord_lessThan @ nat @ ( minus_minus @ nat @ N2 @ J3 ) ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ) ).
% polyfun_diff_alt
thf(fact_2745_polyfun__extremal__lemma,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [E3: real,C2: nat > A,N2: nat] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E3 )
=> ? [M8: real] :
! [Z4: A] :
( ( ord_less_eq @ real @ M8 @ ( real_V7770717601297561774m_norm @ A @ Z4 ) )
=> ( ord_less_eq @ real
@ ( real_V7770717601297561774m_norm @ A
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ Z4 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) )
@ ( times_times @ real @ E3 @ ( power_power @ real @ ( real_V7770717601297561774m_norm @ A @ Z4 ) @ ( suc @ N2 ) ) ) ) ) ) ) ).
% polyfun_extremal_lemma
thf(fact_2746_polyfun__diff,axiom,
! [A: $tType] :
( ( idom @ A )
=> ! [N2: nat,A3: nat > A,X: A,Y: A] :
( ( ord_less_eq @ nat @ ( one_one @ nat ) @ N2 )
=> ( ( minus_minus @ A
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( A3 @ I5 ) @ ( power_power @ A @ X @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( A3 @ I5 ) @ ( power_power @ A @ Y @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) )
= ( times_times @ A @ ( minus_minus @ A @ X @ Y )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [J3: nat] :
( times_times @ A
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( A3 @ I5 ) @ ( power_power @ A @ Y @ ( minus_minus @ nat @ ( minus_minus @ nat @ I5 @ J3 ) @ ( one_one @ nat ) ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( suc @ J3 ) @ N2 ) )
@ ( power_power @ A @ X @ J3 ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ) ) ).
% polyfun_diff
thf(fact_2747_arsinh__def,axiom,
! [A: $tType] :
( ( ln @ A )
=> ( ( arsinh @ A )
= ( ^ [X2: A] : ( ln_ln @ A @ ( plus_plus @ A @ X2 @ ( powr @ A @ ( plus_plus @ A @ ( power_power @ A @ X2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ A ) ) @ ( real_Vector_of_real @ A @ ( divide_divide @ real @ ( one_one @ real ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ).
% arsinh_def
thf(fact_2748_sin__cos__npi,axiom,
! [N2: nat] :
( ( sin @ real @ ( divide_divide @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) @ pi ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) )
= ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ N2 ) ) ).
% sin_cos_npi
thf(fact_2749_cos__pi__eq__zero,axiom,
! [M: nat] :
( ( cos @ real @ ( divide_divide @ real @ ( times_times @ real @ pi @ ( semiring_1_of_nat @ real @ ( suc @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) ) ) ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) )
= ( zero_zero @ real ) ) ).
% cos_pi_eq_zero
thf(fact_2750_choose__even__sum,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( if @ A @ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 ) @ ( semiring_1_of_nat @ A @ ( binomial @ N2 @ I5 ) ) @ ( zero_zero @ A ) )
@ ( set_ord_atMost @ nat @ N2 ) ) )
= ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ).
% choose_even_sum
thf(fact_2751_choose__odd__sum,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] :
( if @ A
@ ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ I5 )
@ ( semiring_1_of_nat @ A @ ( binomial @ N2 @ I5 ) )
@ ( zero_zero @ A ) )
@ ( set_ord_atMost @ nat @ N2 ) ) )
= ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ).
% choose_odd_sum
thf(fact_2752_central__binomial__lower__bound,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less_eq @ real @ ( divide_divide @ real @ ( power_power @ real @ ( numeral_numeral @ real @ ( bit0 @ ( bit0 @ one2 ) ) ) @ N2 ) @ ( times_times @ real @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) @ ( semiring_1_of_nat @ real @ N2 ) ) ) @ ( semiring_1_of_nat @ real @ ( binomial @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ N2 ) ) ) ) ).
% central_binomial_lower_bound
thf(fact_2753_gbinomial__code,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ( ( gbinomial @ A )
= ( ^ [A5: A,K2: nat] :
( if @ A
@ ( K2
= ( zero_zero @ nat ) )
@ ( one_one @ A )
@ ( divide_divide @ A
@ ( set_fo6178422350223883121st_nat @ A
@ ^ [L2: nat] : ( times_times @ A @ ( minus_minus @ A @ A5 @ ( semiring_1_of_nat @ A @ L2 ) ) )
@ ( zero_zero @ nat )
@ ( minus_minus @ nat @ K2 @ ( one_one @ nat ) )
@ ( one_one @ A ) )
@ ( semiring_char_0_fact @ A @ K2 ) ) ) ) ) ) ).
% gbinomial_code
thf(fact_2754_sin__zero,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ( ( sin @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% sin_zero
thf(fact_2755_binomial__Suc__n,axiom,
! [N2: nat] :
( ( binomial @ ( suc @ N2 ) @ N2 )
= ( suc @ N2 ) ) ).
% binomial_Suc_n
thf(fact_2756_cos__zero,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ( ( cos @ A @ ( zero_zero @ A ) )
= ( one_one @ A ) ) ) ).
% cos_zero
thf(fact_2757_fact__0,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ( ( semiring_char_0_fact @ A @ ( zero_zero @ nat ) )
= ( one_one @ A ) ) ) ).
% fact_0
thf(fact_2758_binomial__1,axiom,
! [N2: nat] :
( ( binomial @ N2 @ ( suc @ ( zero_zero @ nat ) ) )
= N2 ) ).
% binomial_1
thf(fact_2759_binomial__0__Suc,axiom,
! [K: nat] :
( ( binomial @ ( zero_zero @ nat ) @ ( suc @ K ) )
= ( zero_zero @ nat ) ) ).
% binomial_0_Suc
thf(fact_2760_binomial__eq__0__iff,axiom,
! [N2: nat,K: nat] :
( ( ( binomial @ N2 @ K )
= ( zero_zero @ nat ) )
= ( ord_less @ nat @ N2 @ K ) ) ).
% binomial_eq_0_iff
thf(fact_2761_binomial__Suc__Suc,axiom,
! [N2: nat,K: nat] :
( ( binomial @ ( suc @ N2 ) @ ( suc @ K ) )
= ( plus_plus @ nat @ ( binomial @ N2 @ K ) @ ( binomial @ N2 @ ( suc @ K ) ) ) ) ).
% binomial_Suc_Suc
thf(fact_2762_binomial__n__0,axiom,
! [N2: nat] :
( ( binomial @ N2 @ ( zero_zero @ nat ) )
= ( one_one @ nat ) ) ).
% binomial_n_0
thf(fact_2763_fact__Suc__0,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ( ( semiring_char_0_fact @ A @ ( suc @ ( zero_zero @ nat ) ) )
= ( one_one @ A ) ) ) ).
% fact_Suc_0
thf(fact_2764_fact__Suc,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ! [N2: nat] :
( ( semiring_char_0_fact @ A @ ( suc @ N2 ) )
= ( times_times @ A @ ( semiring_1_of_nat @ A @ ( suc @ N2 ) ) @ ( semiring_char_0_fact @ A @ N2 ) ) ) ) ).
% fact_Suc
thf(fact_2765_zero__less__binomial__iff,axiom,
! [N2: nat,K: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( binomial @ N2 @ K ) )
= ( ord_less_eq @ nat @ K @ N2 ) ) ).
% zero_less_binomial_iff
thf(fact_2766_sin__of__real__pi,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ( ( sin @ A @ ( real_Vector_of_real @ A @ pi ) )
= ( zero_zero @ A ) ) ) ).
% sin_of_real_pi
thf(fact_2767_sin__cos__squared__add3,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( plus_plus @ A @ ( times_times @ A @ ( cos @ A @ X ) @ ( cos @ A @ X ) ) @ ( times_times @ A @ ( sin @ A @ X ) @ ( sin @ A @ X ) ) )
= ( one_one @ A ) ) ) ).
% sin_cos_squared_add3
thf(fact_2768_sin__cos__squared__add,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( plus_plus @ A @ ( power_power @ A @ ( sin @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ ( cos @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
= ( one_one @ A ) ) ) ).
% sin_cos_squared_add
thf(fact_2769_sin__cos__squared__add2,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( plus_plus @ A @ ( power_power @ A @ ( cos @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ ( sin @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
= ( one_one @ A ) ) ) ).
% sin_cos_squared_add2
thf(fact_2770_cos__of__real__pi__half,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V7773925162809079976_field @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ( ( cos @ A @ ( divide_divide @ A @ ( real_Vector_of_real @ A @ pi ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) )
= ( zero_zero @ A ) ) ) ).
% cos_of_real_pi_half
thf(fact_2771_cos__one__sin__zero,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ( cos @ A @ X )
= ( one_one @ A ) )
=> ( ( sin @ A @ X )
= ( zero_zero @ A ) ) ) ) ).
% cos_one_sin_zero
thf(fact_2772_sin__add,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( ( sin @ A @ ( plus_plus @ A @ X @ Y ) )
= ( plus_plus @ A @ ( times_times @ A @ ( sin @ A @ X ) @ ( cos @ A @ Y ) ) @ ( times_times @ A @ ( cos @ A @ X ) @ ( sin @ A @ Y ) ) ) ) ) ).
% sin_add
thf(fact_2773_fact__mono__nat,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ord_less_eq @ nat @ ( semiring_char_0_fact @ nat @ M ) @ ( semiring_char_0_fact @ nat @ N2 ) ) ) ).
% fact_mono_nat
thf(fact_2774_fact__ge__self,axiom,
! [N2: nat] : ( ord_less_eq @ nat @ N2 @ ( semiring_char_0_fact @ nat @ N2 ) ) ).
% fact_ge_self
thf(fact_2775_fact__nonzero,axiom,
! [A: $tType] :
( ( ( semiring_char_0 @ A )
& ( semiri3467727345109120633visors @ A ) )
=> ! [N2: nat] :
( ( semiring_char_0_fact @ A @ N2 )
!= ( zero_zero @ A ) ) ) ).
% fact_nonzero
thf(fact_2776_cos__diff,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( ( cos @ A @ ( minus_minus @ A @ X @ Y ) )
= ( plus_plus @ A @ ( times_times @ A @ ( cos @ A @ X ) @ ( cos @ A @ Y ) ) @ ( times_times @ A @ ( sin @ A @ X ) @ ( sin @ A @ Y ) ) ) ) ) ).
% cos_diff
thf(fact_2777_cos__add,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( ( cos @ A @ ( plus_plus @ A @ X @ Y ) )
= ( minus_minus @ A @ ( times_times @ A @ ( cos @ A @ X ) @ ( cos @ A @ Y ) ) @ ( times_times @ A @ ( sin @ A @ X ) @ ( sin @ A @ Y ) ) ) ) ) ).
% cos_add
thf(fact_2778_sin__zero__norm__cos__one,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ( sin @ A @ X )
= ( zero_zero @ A ) )
=> ( ( real_V7770717601297561774m_norm @ A @ ( cos @ A @ X ) )
= ( one_one @ real ) ) ) ) ).
% sin_zero_norm_cos_one
thf(fact_2779_binomial__fact__lemma,axiom,
! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( times_times @ nat @ ( times_times @ nat @ ( semiring_char_0_fact @ nat @ K ) @ ( semiring_char_0_fact @ nat @ ( minus_minus @ nat @ N2 @ K ) ) ) @ ( binomial @ N2 @ K ) )
= ( semiring_char_0_fact @ nat @ N2 ) ) ) ).
% binomial_fact_lemma
thf(fact_2780_binomial__altdef__nat,axiom,
! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( binomial @ N2 @ K )
= ( divide_divide @ nat @ ( semiring_char_0_fact @ nat @ N2 ) @ ( times_times @ nat @ ( semiring_char_0_fact @ nat @ K ) @ ( semiring_char_0_fact @ nat @ ( minus_minus @ nat @ N2 @ K ) ) ) ) ) ) ).
% binomial_altdef_nat
thf(fact_2781_binomial__eq__0,axiom,
! [N2: nat,K: nat] :
( ( ord_less @ nat @ N2 @ K )
=> ( ( binomial @ N2 @ K )
= ( zero_zero @ nat ) ) ) ).
% binomial_eq_0
thf(fact_2782_Suc__times__binomial__eq,axiom,
! [N2: nat,K: nat] :
( ( times_times @ nat @ ( suc @ N2 ) @ ( binomial @ N2 @ K ) )
= ( times_times @ nat @ ( binomial @ ( suc @ N2 ) @ ( suc @ K ) ) @ ( suc @ K ) ) ) ).
% Suc_times_binomial_eq
thf(fact_2783_Suc__times__binomial,axiom,
! [K: nat,N2: nat] :
( ( times_times @ nat @ ( suc @ K ) @ ( binomial @ ( suc @ N2 ) @ ( suc @ K ) ) )
= ( times_times @ nat @ ( suc @ N2 ) @ ( binomial @ N2 @ K ) ) ) ).
% Suc_times_binomial
thf(fact_2784_fact__less__mono__nat,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ( ord_less @ nat @ M @ N2 )
=> ( ord_less @ nat @ ( semiring_char_0_fact @ nat @ M ) @ ( semiring_char_0_fact @ nat @ N2 ) ) ) ) ).
% fact_less_mono_nat
thf(fact_2785_binomial__symmetric,axiom,
! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( binomial @ N2 @ K )
= ( binomial @ N2 @ ( minus_minus @ nat @ N2 @ K ) ) ) ) ).
% binomial_symmetric
thf(fact_2786_choose__mult__lemma,axiom,
! [M: nat,R2: nat,K: nat] :
( ( times_times @ nat @ ( binomial @ ( plus_plus @ nat @ ( plus_plus @ nat @ M @ R2 ) @ K ) @ ( plus_plus @ nat @ M @ K ) ) @ ( binomial @ ( plus_plus @ nat @ M @ K ) @ K ) )
= ( times_times @ nat @ ( binomial @ ( plus_plus @ nat @ ( plus_plus @ nat @ M @ R2 ) @ K ) @ K ) @ ( binomial @ ( plus_plus @ nat @ M @ R2 ) @ M ) ) ) ).
% choose_mult_lemma
thf(fact_2787_binomial__le__pow,axiom,
! [R2: nat,N2: nat] :
( ( ord_less_eq @ nat @ R2 @ N2 )
=> ( ord_less_eq @ nat @ ( binomial @ N2 @ R2 ) @ ( power_power @ nat @ N2 @ R2 ) ) ) ).
% binomial_le_pow
thf(fact_2788_fact__ge__zero,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( semiring_char_0_fact @ A @ N2 ) ) ) ).
% fact_ge_zero
thf(fact_2789_fact__gt__zero,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat] : ( ord_less @ A @ ( zero_zero @ A ) @ ( semiring_char_0_fact @ A @ N2 ) ) ) ).
% fact_gt_zero
thf(fact_2790_fact__not__neg,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat] :
~ ( ord_less @ A @ ( semiring_char_0_fact @ A @ N2 ) @ ( zero_zero @ A ) ) ) ).
% fact_not_neg
thf(fact_2791_fact__ge__1,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat] : ( ord_less_eq @ A @ ( one_one @ A ) @ ( semiring_char_0_fact @ A @ N2 ) ) ) ).
% fact_ge_1
thf(fact_2792_fact__mono,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ord_less_eq @ A @ ( semiring_char_0_fact @ A @ M ) @ ( semiring_char_0_fact @ A @ N2 ) ) ) ) ).
% fact_mono
thf(fact_2793_fact__dvd,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat,M: nat] :
( ( ord_less_eq @ nat @ N2 @ M )
=> ( dvd_dvd @ A @ ( semiring_char_0_fact @ A @ N2 ) @ ( semiring_char_0_fact @ A @ M ) ) ) ) ).
% fact_dvd
thf(fact_2794_fact__binomial,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( times_times @ A @ ( semiring_char_0_fact @ A @ K ) @ ( semiring_1_of_nat @ A @ ( binomial @ N2 @ K ) ) )
= ( divide_divide @ A @ ( semiring_char_0_fact @ A @ N2 ) @ ( semiring_char_0_fact @ A @ ( minus_minus @ nat @ N2 @ K ) ) ) ) ) ) ).
% fact_binomial
thf(fact_2795_binomial__fact,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( semiring_1_of_nat @ A @ ( binomial @ N2 @ K ) )
= ( divide_divide @ A @ ( semiring_char_0_fact @ A @ N2 ) @ ( times_times @ A @ ( semiring_char_0_fact @ A @ K ) @ ( semiring_char_0_fact @ A @ ( minus_minus @ nat @ N2 @ K ) ) ) ) ) ) ) ).
% binomial_fact
thf(fact_2796_zero__less__binomial,axiom,
! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ ( binomial @ N2 @ K ) ) ) ).
% zero_less_binomial
thf(fact_2797_Suc__times__binomial__add,axiom,
! [A3: nat,B2: nat] :
( ( times_times @ nat @ ( suc @ A3 ) @ ( binomial @ ( suc @ ( plus_plus @ nat @ A3 @ B2 ) ) @ ( suc @ A3 ) ) )
= ( times_times @ nat @ ( suc @ B2 ) @ ( binomial @ ( suc @ ( plus_plus @ nat @ A3 @ B2 ) ) @ A3 ) ) ) ).
% Suc_times_binomial_add
thf(fact_2798_fact__ge__Suc__0__nat,axiom,
! [N2: nat] : ( ord_less_eq @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( semiring_char_0_fact @ nat @ N2 ) ) ).
% fact_ge_Suc_0_nat
thf(fact_2799_choose__mult,axiom,
! [K: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ M )
=> ( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( times_times @ nat @ ( binomial @ N2 @ M ) @ ( binomial @ M @ K ) )
= ( times_times @ nat @ ( binomial @ N2 @ K ) @ ( binomial @ ( minus_minus @ nat @ N2 @ K ) @ ( minus_minus @ nat @ M @ K ) ) ) ) ) ) ).
% choose_mult
thf(fact_2800_binomial__Suc__Suc__eq__times,axiom,
! [N2: nat,K: nat] :
( ( binomial @ ( suc @ N2 ) @ ( suc @ K ) )
= ( divide_divide @ nat @ ( times_times @ nat @ ( suc @ N2 ) @ ( binomial @ N2 @ K ) ) @ ( suc @ K ) ) ) ).
% binomial_Suc_Suc_eq_times
thf(fact_2801_dvd__fact,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( one_one @ nat ) @ M )
=> ( ( ord_less_eq @ nat @ M @ N2 )
=> ( dvd_dvd @ nat @ M @ ( semiring_char_0_fact @ nat @ N2 ) ) ) ) ).
% dvd_fact
thf(fact_2802_fact__less__mono,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ( ord_less @ nat @ M @ N2 )
=> ( ord_less @ A @ ( semiring_char_0_fact @ A @ M ) @ ( semiring_char_0_fact @ A @ N2 ) ) ) ) ) ).
% fact_less_mono
thf(fact_2803_cos__diff__cos,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [W2: A,Z: A] :
( ( minus_minus @ A @ ( cos @ A @ W2 ) @ ( cos @ A @ Z ) )
= ( times_times @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( sin @ A @ ( divide_divide @ A @ ( plus_plus @ A @ W2 @ Z ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) @ ( sin @ A @ ( divide_divide @ A @ ( minus_minus @ A @ Z @ W2 ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ).
% cos_diff_cos
thf(fact_2804_sin__diff__sin,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [W2: A,Z: A] :
( ( minus_minus @ A @ ( sin @ A @ W2 ) @ ( sin @ A @ Z ) )
= ( times_times @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( sin @ A @ ( divide_divide @ A @ ( minus_minus @ A @ W2 @ Z ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) @ ( cos @ A @ ( divide_divide @ A @ ( plus_plus @ A @ W2 @ Z ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ).
% sin_diff_sin
thf(fact_2805_sin__plus__sin,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [W2: A,Z: A] :
( ( plus_plus @ A @ ( sin @ A @ W2 ) @ ( sin @ A @ Z ) )
= ( times_times @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( sin @ A @ ( divide_divide @ A @ ( plus_plus @ A @ W2 @ Z ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) @ ( cos @ A @ ( divide_divide @ A @ ( minus_minus @ A @ W2 @ Z ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ).
% sin_plus_sin
thf(fact_2806_cos__times__sin,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [W2: A,Z: A] :
( ( times_times @ A @ ( cos @ A @ W2 ) @ ( sin @ A @ Z ) )
= ( divide_divide @ A @ ( minus_minus @ A @ ( sin @ A @ ( plus_plus @ A @ W2 @ Z ) ) @ ( sin @ A @ ( minus_minus @ A @ W2 @ Z ) ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% cos_times_sin
thf(fact_2807_sin__times__cos,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [W2: A,Z: A] :
( ( times_times @ A @ ( sin @ A @ W2 ) @ ( cos @ A @ Z ) )
= ( divide_divide @ A @ ( plus_plus @ A @ ( sin @ A @ ( plus_plus @ A @ W2 @ Z ) ) @ ( sin @ A @ ( minus_minus @ A @ W2 @ Z ) ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% sin_times_cos
thf(fact_2808_sin__times__sin,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [W2: A,Z: A] :
( ( times_times @ A @ ( sin @ A @ W2 ) @ ( sin @ A @ Z ) )
= ( divide_divide @ A @ ( minus_minus @ A @ ( cos @ A @ ( minus_minus @ A @ W2 @ Z ) ) @ ( cos @ A @ ( plus_plus @ A @ W2 @ Z ) ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% sin_times_sin
thf(fact_2809_fact__fact__dvd__fact,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [K: nat,N2: nat] : ( dvd_dvd @ A @ ( times_times @ A @ ( semiring_char_0_fact @ A @ K ) @ ( semiring_char_0_fact @ A @ N2 ) ) @ ( semiring_char_0_fact @ A @ ( plus_plus @ nat @ K @ N2 ) ) ) ) ).
% fact_fact_dvd_fact
thf(fact_2810_fact__mod,axiom,
! [A: $tType] :
( ( ( linordered_semidom @ A )
& ( semidom_modulo @ A ) )
=> ! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( modulo_modulo @ A @ ( semiring_char_0_fact @ A @ N2 ) @ ( semiring_char_0_fact @ A @ M ) )
= ( zero_zero @ A ) ) ) ) ).
% fact_mod
thf(fact_2811_fact__le__power,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [N2: nat] : ( ord_less_eq @ A @ ( semiring_char_0_fact @ A @ N2 ) @ ( semiring_1_of_nat @ A @ ( power_power @ nat @ N2 @ N2 ) ) ) ) ).
% fact_le_power
thf(fact_2812_sum__choose__upper,axiom,
! [M: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [K2: nat] : ( binomial @ K2 @ M )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( binomial @ ( suc @ N2 ) @ ( suc @ M ) ) ) ).
% sum_choose_upper
thf(fact_2813_minus__sin__cos__eq,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( uminus_uminus @ A @ ( sin @ A @ X ) )
= ( cos @ A @ ( plus_plus @ A @ X @ ( divide_divide @ A @ ( real_Vector_of_real @ A @ pi ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ).
% minus_sin_cos_eq
thf(fact_2814_binomial__absorption,axiom,
! [K: nat,N2: nat] :
( ( times_times @ nat @ ( suc @ K ) @ ( binomial @ N2 @ ( suc @ K ) ) )
= ( times_times @ nat @ N2 @ ( binomial @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ K ) ) ) ).
% binomial_absorption
thf(fact_2815_fact__diff__Suc,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ N2 @ ( suc @ M ) )
=> ( ( semiring_char_0_fact @ nat @ ( minus_minus @ nat @ ( suc @ M ) @ N2 ) )
= ( times_times @ nat @ ( minus_minus @ nat @ ( suc @ M ) @ N2 ) @ ( semiring_char_0_fact @ nat @ ( minus_minus @ nat @ M @ N2 ) ) ) ) ) ).
% fact_diff_Suc
thf(fact_2816_fact__div__fact__le__pow,axiom,
! [R2: nat,N2: nat] :
( ( ord_less_eq @ nat @ R2 @ N2 )
=> ( ord_less_eq @ nat @ ( divide_divide @ nat @ ( semiring_char_0_fact @ nat @ N2 ) @ ( semiring_char_0_fact @ nat @ ( minus_minus @ nat @ N2 @ R2 ) ) ) @ ( power_power @ nat @ N2 @ R2 ) ) ) ).
% fact_div_fact_le_pow
thf(fact_2817_choose__dvd,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( dvd_dvd @ A @ ( times_times @ A @ ( semiring_char_0_fact @ A @ K ) @ ( semiring_char_0_fact @ A @ ( minus_minus @ nat @ N2 @ K ) ) ) @ ( semiring_char_0_fact @ A @ N2 ) ) ) ) ).
% choose_dvd
thf(fact_2818_fact__eq__fact__times,axiom,
! [N2: nat,M: nat] :
( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( semiring_char_0_fact @ nat @ M )
= ( times_times @ nat @ ( semiring_char_0_fact @ nat @ N2 )
@ ( groups7121269368397514597t_prod @ nat @ nat
@ ^ [X2: nat] : X2
@ ( set_or1337092689740270186AtMost @ nat @ ( suc @ N2 ) @ M ) ) ) ) ) ).
% fact_eq_fact_times
thf(fact_2819_sin__expansion__lemma,axiom,
! [X: real,M: nat] :
( ( sin @ real @ ( plus_plus @ real @ X @ ( divide_divide @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ ( suc @ M ) ) @ pi ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) ) )
= ( cos @ real @ ( plus_plus @ real @ X @ ( divide_divide @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ M ) @ pi ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) ) ) ) ).
% sin_expansion_lemma
thf(fact_2820_sum__choose__lower,axiom,
! [R2: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [K2: nat] : ( binomial @ ( plus_plus @ nat @ R2 @ K2 ) @ K2 )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( binomial @ ( suc @ ( plus_plus @ nat @ R2 @ N2 ) ) @ N2 ) ) ).
% sum_choose_lower
thf(fact_2821_choose__rising__sum_I1_J,axiom,
! [N2: nat,M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [J3: nat] : ( binomial @ ( plus_plus @ nat @ N2 @ J3 ) @ N2 )
@ ( set_ord_atMost @ nat @ M ) )
= ( binomial @ ( plus_plus @ nat @ ( plus_plus @ nat @ N2 @ M ) @ ( one_one @ nat ) ) @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) ) ) ).
% choose_rising_sum(1)
thf(fact_2822_choose__rising__sum_I2_J,axiom,
! [N2: nat,M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [J3: nat] : ( binomial @ ( plus_plus @ nat @ N2 @ J3 ) @ N2 )
@ ( set_ord_atMost @ nat @ M ) )
= ( binomial @ ( plus_plus @ nat @ ( plus_plus @ nat @ N2 @ M ) @ ( one_one @ nat ) ) @ M ) ) ).
% choose_rising_sum(2)
thf(fact_2823_binomial__code,axiom,
( binomial
= ( ^ [N: nat,K2: nat] : ( if @ nat @ ( ord_less @ nat @ N @ K2 ) @ ( zero_zero @ nat ) @ ( if @ nat @ ( ord_less @ nat @ N @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ K2 ) ) @ ( binomial @ N @ ( minus_minus @ nat @ N @ K2 ) ) @ ( divide_divide @ nat @ ( set_fo6178422350223883121st_nat @ nat @ ( times_times @ nat ) @ ( plus_plus @ nat @ ( minus_minus @ nat @ N @ K2 ) @ ( one_one @ nat ) ) @ N @ ( one_one @ nat ) ) @ ( semiring_char_0_fact @ nat @ K2 ) ) ) ) ) ) ).
% binomial_code
thf(fact_2824_binomial__ge__n__over__k__pow__k,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ord_less_eq @ A @ ( power_power @ A @ ( divide_divide @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( semiring_1_of_nat @ A @ K ) ) @ K ) @ ( semiring_1_of_nat @ A @ ( binomial @ N2 @ K ) ) ) ) ) ).
% binomial_ge_n_over_k_pow_k
thf(fact_2825_binomial__maximum_H,axiom,
! [N2: nat,K: nat] : ( ord_less_eq @ nat @ ( binomial @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ K ) @ ( binomial @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ N2 ) ) ).
% binomial_maximum'
thf(fact_2826_binomial__mono,axiom,
! [K: nat,K7: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ K7 )
=> ( ( ord_less_eq @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ K7 ) @ N2 )
=> ( ord_less_eq @ nat @ ( binomial @ N2 @ K ) @ ( binomial @ N2 @ K7 ) ) ) ) ).
% binomial_mono
thf(fact_2827_binomial__antimono,axiom,
! [K: nat,K7: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ K7 )
=> ( ( ord_less_eq @ nat @ ( divide_divide @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ K )
=> ( ( ord_less_eq @ nat @ K7 @ N2 )
=> ( ord_less_eq @ nat @ ( binomial @ N2 @ K7 ) @ ( binomial @ N2 @ K ) ) ) ) ) ).
% binomial_antimono
thf(fact_2828_binomial__maximum,axiom,
! [N2: nat,K: nat] : ( ord_less_eq @ nat @ ( binomial @ N2 @ K ) @ ( binomial @ N2 @ ( divide_divide @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ).
% binomial_maximum
thf(fact_2829_binomial__le__pow2,axiom,
! [N2: nat,K: nat] : ( ord_less_eq @ nat @ ( binomial @ N2 @ K ) @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ).
% binomial_le_pow2
thf(fact_2830_choose__reduce__nat,axiom,
! [N2: nat,K: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ( binomial @ N2 @ K )
= ( plus_plus @ nat @ ( binomial @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ ( minus_minus @ nat @ K @ ( one_one @ nat ) ) ) @ ( binomial @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ K ) ) ) ) ) ).
% choose_reduce_nat
thf(fact_2831_times__binomial__minus1__eq,axiom,
! [K: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ( times_times @ nat @ K @ ( binomial @ N2 @ K ) )
= ( times_times @ nat @ N2 @ ( binomial @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ ( minus_minus @ nat @ K @ ( one_one @ nat ) ) ) ) ) ) ).
% times_binomial_minus1_eq
thf(fact_2832_cos__expansion__lemma,axiom,
! [X: real,M: nat] :
( ( cos @ real @ ( plus_plus @ real @ X @ ( divide_divide @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ ( suc @ M ) ) @ pi ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) ) )
= ( uminus_uminus @ real @ ( sin @ real @ ( plus_plus @ real @ X @ ( divide_divide @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ M ) @ pi ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) ) ) ) ) ).
% cos_expansion_lemma
thf(fact_2833_fact__div__fact,axiom,
! [N2: nat,M: nat] :
( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( divide_divide @ nat @ ( semiring_char_0_fact @ nat @ M ) @ ( semiring_char_0_fact @ nat @ N2 ) )
= ( groups7121269368397514597t_prod @ nat @ nat
@ ^ [X2: nat] : X2
@ ( set_or1337092689740270186AtMost @ nat @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) @ M ) ) ) ) ).
% fact_div_fact
thf(fact_2834_sum__choose__diagonal,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [K2: nat] : ( binomial @ ( minus_minus @ nat @ N2 @ K2 ) @ ( minus_minus @ nat @ M @ K2 ) )
@ ( set_ord_atMost @ nat @ M ) )
= ( binomial @ ( suc @ N2 ) @ M ) ) ) ).
% sum_choose_diagonal
thf(fact_2835_vandermonde,axiom,
! [M: nat,N2: nat,R2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [K2: nat] : ( times_times @ nat @ ( binomial @ M @ K2 ) @ ( binomial @ N2 @ ( minus_minus @ nat @ R2 @ K2 ) ) )
@ ( set_ord_atMost @ nat @ R2 ) )
= ( binomial @ ( plus_plus @ nat @ M @ N2 ) @ R2 ) ) ).
% vandermonde
thf(fact_2836_binomial__less__binomial__Suc,axiom,
! [K: nat,N2: nat] :
( ( ord_less @ nat @ K @ ( divide_divide @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
=> ( ord_less @ nat @ ( binomial @ N2 @ K ) @ ( binomial @ N2 @ ( suc @ K ) ) ) ) ).
% binomial_less_binomial_Suc
thf(fact_2837_binomial__strict__mono,axiom,
! [K: nat,K7: nat,N2: nat] :
( ( ord_less @ nat @ K @ K7 )
=> ( ( ord_less_eq @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ K7 ) @ N2 )
=> ( ord_less @ nat @ ( binomial @ N2 @ K ) @ ( binomial @ N2 @ K7 ) ) ) ) ).
% binomial_strict_mono
thf(fact_2838_binomial__strict__antimono,axiom,
! [K: nat,K7: nat,N2: nat] :
( ( ord_less @ nat @ K @ K7 )
=> ( ( ord_less_eq @ nat @ N2 @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ K ) )
=> ( ( ord_less_eq @ nat @ K7 @ N2 )
=> ( ord_less @ nat @ ( binomial @ N2 @ K7 ) @ ( binomial @ N2 @ K ) ) ) ) ) ).
% binomial_strict_antimono
thf(fact_2839_central__binomial__odd,axiom,
! [N2: nat] :
( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( binomial @ N2 @ ( suc @ ( divide_divide @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
= ( binomial @ N2 @ ( divide_divide @ nat @ N2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ).
% central_binomial_odd
thf(fact_2840_binomial__addition__formula,axiom,
! [N2: nat,K: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( binomial @ N2 @ ( suc @ K ) )
= ( plus_plus @ nat @ ( binomial @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ ( suc @ K ) ) @ ( binomial @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ K ) ) ) ) ).
% binomial_addition_formula
thf(fact_2841_sin__pi__divide__n__ge__0,axiom,
! [N2: nat] :
( ( N2
!= ( zero_zero @ nat ) )
=> ( ord_less_eq @ real @ ( zero_zero @ real ) @ ( sin @ real @ ( divide_divide @ real @ pi @ ( semiring_1_of_nat @ real @ N2 ) ) ) ) ) ).
% sin_pi_divide_n_ge_0
thf(fact_2842_sin__paired,axiom,
! [X: real] :
( sums @ real
@ ^ [N: nat] : ( times_times @ real @ ( divide_divide @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ N ) @ ( semiring_char_0_fact @ real @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) @ ( one_one @ nat ) ) ) ) @ ( power_power @ real @ X @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) @ ( one_one @ nat ) ) ) )
@ ( sin @ real @ X ) ) ).
% sin_paired
thf(fact_2843_fact__num__eq__if,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ( ( semiring_char_0_fact @ A )
= ( ^ [M2: nat] :
( if @ A
@ ( M2
= ( zero_zero @ nat ) )
@ ( one_one @ A )
@ ( times_times @ A @ ( semiring_1_of_nat @ A @ M2 ) @ ( semiring_char_0_fact @ A @ ( minus_minus @ nat @ M2 @ ( one_one @ nat ) ) ) ) ) ) ) ) ).
% fact_num_eq_if
thf(fact_2844_fact__reduce,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( semiring_char_0_fact @ A @ N2 )
= ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( semiring_char_0_fact @ A @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) ) ) ) ) ) ).
% fact_reduce
thf(fact_2845_cos__plus__cos,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [W2: A,Z: A] :
( ( plus_plus @ A @ ( cos @ A @ W2 ) @ ( cos @ A @ Z ) )
= ( times_times @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( cos @ A @ ( divide_divide @ A @ ( plus_plus @ A @ W2 @ Z ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) @ ( cos @ A @ ( divide_divide @ A @ ( minus_minus @ A @ W2 @ Z ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ).
% cos_plus_cos
thf(fact_2846_cos__times__cos,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [W2: A,Z: A] :
( ( times_times @ A @ ( cos @ A @ W2 ) @ ( cos @ A @ Z ) )
= ( divide_divide @ A @ ( plus_plus @ A @ ( cos @ A @ ( minus_minus @ A @ W2 @ Z ) ) @ ( cos @ A @ ( plus_plus @ A @ W2 @ Z ) ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% cos_times_cos
thf(fact_2847_binomial,axiom,
! [A3: nat,B2: nat,N2: nat] :
( ( power_power @ nat @ ( plus_plus @ nat @ A3 @ B2 ) @ N2 )
= ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [K2: nat] : ( times_times @ nat @ ( times_times @ nat @ ( semiring_1_of_nat @ nat @ ( binomial @ N2 @ K2 ) ) @ ( power_power @ nat @ A3 @ K2 ) ) @ ( power_power @ nat @ B2 @ ( minus_minus @ nat @ N2 @ K2 ) ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) ).
% binomial
thf(fact_2848_binomial__ring,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ! [A3: A,B2: A,N2: nat] :
( ( power_power @ A @ ( plus_plus @ A @ A3 @ B2 ) @ N2 )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( times_times @ A @ ( times_times @ A @ ( semiring_1_of_nat @ A @ ( binomial @ N2 @ K2 ) ) @ ( power_power @ A @ A3 @ K2 ) ) @ ( power_power @ A @ B2 @ ( minus_minus @ nat @ N2 @ K2 ) ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) ) ).
% binomial_ring
thf(fact_2849_pochhammer__binomial__sum,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [A3: A,B2: A,N2: nat] :
( ( comm_s3205402744901411588hammer @ A @ ( plus_plus @ A @ A3 @ B2 ) @ N2 )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( times_times @ A @ ( times_times @ A @ ( semiring_1_of_nat @ A @ ( binomial @ N2 @ K2 ) ) @ ( comm_s3205402744901411588hammer @ A @ A3 @ K2 ) ) @ ( comm_s3205402744901411588hammer @ A @ B2 @ ( minus_minus @ nat @ N2 @ K2 ) ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) ) ).
% pochhammer_binomial_sum
thf(fact_2850_gbinomial__pochhammer_H,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ( ( gbinomial @ A )
= ( ^ [A5: A,K2: nat] : ( divide_divide @ A @ ( comm_s3205402744901411588hammer @ A @ ( plus_plus @ A @ ( minus_minus @ A @ A5 @ ( semiring_1_of_nat @ A @ K2 ) ) @ ( one_one @ A ) ) @ K2 ) @ ( semiring_char_0_fact @ A @ K2 ) ) ) ) ) ).
% gbinomial_pochhammer'
thf(fact_2851_Maclaurin__zero,axiom,
! [A: $tType] :
( ( zero @ A )
=> ! [X: real,N2: nat,Diff: nat > A > real] :
( ( X
= ( zero_zero @ real ) )
=> ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ M2 @ ( zero_zero @ A ) ) @ ( semiring_char_0_fact @ real @ M2 ) ) @ ( power_power @ real @ X @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
= ( Diff @ ( zero_zero @ nat ) @ ( zero_zero @ A ) ) ) ) ) ) ).
% Maclaurin_zero
thf(fact_2852_Maclaurin__cos__expansion2,axiom,
! [X: real,N2: nat] :
( ( ord_less @ real @ ( zero_zero @ real ) @ X )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ? [T7: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ T7 )
& ( ord_less @ real @ T7 @ X )
& ( ( cos @ real @ X )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( cos_coeff @ M2 ) @ ( power_power @ real @ X @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( cos @ real @ ( plus_plus @ real @ T7 @ ( times_times @ real @ ( times_times @ real @ ( divide_divide @ real @ ( one_one @ real ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) @ ( semiring_1_of_nat @ real @ N2 ) ) @ pi ) ) ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ X @ N2 ) ) ) ) ) ) ) ).
% Maclaurin_cos_expansion2
thf(fact_2853_Maclaurin__minus__cos__expansion,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ X @ ( zero_zero @ real ) )
=> ? [T7: real] :
( ( ord_less @ real @ X @ T7 )
& ( ord_less @ real @ T7 @ ( zero_zero @ real ) )
& ( ( cos @ real @ X )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( cos_coeff @ M2 ) @ ( power_power @ real @ X @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( cos @ real @ ( plus_plus @ real @ T7 @ ( times_times @ real @ ( times_times @ real @ ( divide_divide @ real @ ( one_one @ real ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) @ ( semiring_1_of_nat @ real @ N2 ) ) @ pi ) ) ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ X @ N2 ) ) ) ) ) ) ) ).
% Maclaurin_minus_cos_expansion
thf(fact_2854_sin__pi__divide__n__gt__0,axiom,
! [N2: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ord_less @ real @ ( zero_zero @ real ) @ ( sin @ real @ ( divide_divide @ real @ pi @ ( semiring_1_of_nat @ real @ N2 ) ) ) ) ) ).
% sin_pi_divide_n_gt_0
thf(fact_2855_choose__alternating__linear__sum,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [N2: nat] :
( ( N2
!= ( one_one @ nat ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( times_times @ A @ ( power_power @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ I5 ) @ ( semiring_1_of_nat @ A @ I5 ) ) @ ( semiring_1_of_nat @ A @ ( binomial @ N2 @ I5 ) ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( zero_zero @ A ) ) ) ) ).
% choose_alternating_linear_sum
thf(fact_2856_gbinomial__Suc,axiom,
! [A: $tType] :
( ( ( semiring_char_0 @ A )
& ( semidom_divide @ A ) )
=> ! [A3: A,K: nat] :
( ( gbinomial @ A @ A3 @ ( suc @ K ) )
= ( divide_divide @ A
@ ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( minus_minus @ A @ A3 @ ( semiring_1_of_nat @ A @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ K ) )
@ ( semiring_char_0_fact @ A @ ( suc @ K ) ) ) ) ) ).
% gbinomial_Suc
thf(fact_2857_binomial__r__part__sum,axiom,
! [M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ nat @ ( binomial @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) @ ( one_one @ nat ) ) ) @ ( set_ord_atMost @ nat @ M ) )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M ) ) ) ).
% binomial_r_part_sum
thf(fact_2858_choose__alternating__sum,axiom,
! [A: $tType] :
( ( comm_ring_1 @ A )
=> ! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( power_power @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ I5 ) @ ( semiring_1_of_nat @ A @ ( binomial @ N2 @ I5 ) ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( zero_zero @ A ) ) ) ) ).
% choose_alternating_sum
thf(fact_2859_Maclaurin__sin__expansion3,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ X )
=> ? [T7: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ T7 )
& ( ord_less @ real @ T7 @ X )
& ( ( sin @ real @ X )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( sin_coeff @ M2 ) @ ( power_power @ real @ X @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( sin @ real @ ( plus_plus @ real @ T7 @ ( times_times @ real @ ( times_times @ real @ ( divide_divide @ real @ ( one_one @ real ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) @ ( semiring_1_of_nat @ real @ N2 ) ) @ pi ) ) ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ X @ N2 ) ) ) ) ) ) ) ).
% Maclaurin_sin_expansion3
thf(fact_2860_sin__x__sin__y,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( sums @ A
@ ^ [P6: nat] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [N: nat] :
( if @ A
@ ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ P6 )
& ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) )
@ ( times_times @ A @ ( real_V8093663219630862766scaleR @ A @ ( uminus_uminus @ real @ ( divide_divide @ real @ ( ring_1_of_int @ real @ ( times_times @ int @ ( power_power @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( divide_divide @ nat @ P6 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( semiring_1_of_nat @ int @ ( binomial @ P6 @ N ) ) ) ) @ ( semiring_char_0_fact @ real @ P6 ) ) ) @ ( power_power @ A @ X @ N ) ) @ ( power_power @ A @ Y @ ( minus_minus @ nat @ P6 @ N ) ) )
@ ( zero_zero @ A ) )
@ ( set_ord_atMost @ nat @ P6 ) )
@ ( times_times @ A @ ( sin @ A @ X ) @ ( sin @ A @ Y ) ) ) ) ).
% sin_x_sin_y
thf(fact_2861_sums__cos__x__plus__y,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( sums @ A
@ ^ [P6: nat] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [N: nat] : ( if @ A @ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ P6 ) @ ( times_times @ A @ ( real_V8093663219630862766scaleR @ A @ ( divide_divide @ real @ ( ring_1_of_int @ real @ ( times_times @ int @ ( power_power @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( divide_divide @ nat @ P6 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( semiring_1_of_nat @ int @ ( binomial @ P6 @ N ) ) ) ) @ ( semiring_char_0_fact @ real @ P6 ) ) @ ( power_power @ A @ X @ N ) ) @ ( power_power @ A @ Y @ ( minus_minus @ nat @ P6 @ N ) ) ) @ ( zero_zero @ A ) )
@ ( set_ord_atMost @ nat @ P6 ) )
@ ( cos @ A @ ( plus_plus @ A @ X @ Y ) ) ) ) ).
% sums_cos_x_plus_y
thf(fact_2862_cos__x__cos__y,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( sums @ A
@ ^ [P6: nat] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [N: nat] :
( if @ A
@ ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ P6 )
& ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) )
@ ( times_times @ A @ ( real_V8093663219630862766scaleR @ A @ ( divide_divide @ real @ ( ring_1_of_int @ real @ ( times_times @ int @ ( power_power @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( divide_divide @ nat @ P6 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( semiring_1_of_nat @ int @ ( binomial @ P6 @ N ) ) ) ) @ ( semiring_char_0_fact @ real @ P6 ) ) @ ( power_power @ A @ X @ N ) ) @ ( power_power @ A @ Y @ ( minus_minus @ nat @ P6 @ N ) ) )
@ ( zero_zero @ A ) )
@ ( set_ord_atMost @ nat @ P6 ) )
@ ( times_times @ A @ ( cos @ A @ X ) @ ( cos @ A @ Y ) ) ) ) ).
% cos_x_cos_y
thf(fact_2863_sin__coeff__def,axiom,
( sin_coeff
= ( ^ [N: nat] : ( if @ real @ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) @ ( zero_zero @ real ) @ ( divide_divide @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ ( divide_divide @ nat @ ( minus_minus @ nat @ N @ ( suc @ ( zero_zero @ nat ) ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( semiring_char_0_fact @ real @ N ) ) ) ) ) ).
% sin_coeff_def
thf(fact_2864_tan__double,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ( cos @ A @ X )
!= ( zero_zero @ A ) )
=> ( ( ( cos @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ X ) )
!= ( zero_zero @ A ) )
=> ( ( tan @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ X ) )
= ( divide_divide @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( tan @ A @ X ) ) @ ( minus_minus @ A @ ( one_one @ A ) @ ( power_power @ A @ ( tan @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ).
% tan_double
thf(fact_2865_of__nat__id,axiom,
( ( semiring_1_of_nat @ nat )
= ( ^ [N: nat] : N ) ) ).
% of_nat_id
thf(fact_2866_scaleR__zero__right,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A3: real] :
( ( real_V8093663219630862766scaleR @ A @ A3 @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% scaleR_zero_right
thf(fact_2867_scaleR__cancel__right,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A3: real,X: A,B2: real] :
( ( ( real_V8093663219630862766scaleR @ A @ A3 @ X )
= ( real_V8093663219630862766scaleR @ A @ B2 @ X ) )
= ( ( A3 = B2 )
| ( X
= ( zero_zero @ A ) ) ) ) ) ).
% scaleR_cancel_right
thf(fact_2868_tan__zero,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ( ( tan @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% tan_zero
thf(fact_2869_scaleR__zero__left,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: A] :
( ( real_V8093663219630862766scaleR @ A @ ( zero_zero @ real ) @ X )
= ( zero_zero @ A ) ) ) ).
% scaleR_zero_left
thf(fact_2870_scaleR__eq__0__iff,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A3: real,X: A] :
( ( ( real_V8093663219630862766scaleR @ A @ A3 @ X )
= ( zero_zero @ A ) )
= ( ( A3
= ( zero_zero @ real ) )
| ( X
= ( zero_zero @ A ) ) ) ) ) ).
% scaleR_eq_0_iff
thf(fact_2871_scaleR__eq__iff,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [B2: A,U: real,A3: A] :
( ( ( plus_plus @ A @ B2 @ ( real_V8093663219630862766scaleR @ A @ U @ A3 ) )
= ( plus_plus @ A @ A3 @ ( real_V8093663219630862766scaleR @ A @ U @ B2 ) ) )
= ( ( A3 = B2 )
| ( U
= ( one_one @ real ) ) ) ) ) ).
% scaleR_eq_iff
thf(fact_2872_sin__coeff__0,axiom,
( ( sin_coeff @ ( zero_zero @ nat ) )
= ( zero_zero @ real ) ) ).
% sin_coeff_0
thf(fact_2873_scaleR__collapse,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [U: real,A3: A] :
( ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ ( minus_minus @ real @ ( one_one @ real ) @ U ) @ A3 ) @ ( real_V8093663219630862766scaleR @ A @ U @ A3 ) )
= A3 ) ) ).
% scaleR_collapse
thf(fact_2874_scaleR__half__double,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A3: A] :
( ( real_V8093663219630862766scaleR @ A @ ( divide_divide @ real @ ( one_one @ real ) @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) @ ( plus_plus @ A @ A3 @ A3 ) )
= A3 ) ) ).
% scaleR_half_double
thf(fact_2875_scaleR__right__imp__eq,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: A,A3: real,B2: real] :
( ( X
!= ( zero_zero @ A ) )
=> ( ( ( real_V8093663219630862766scaleR @ A @ A3 @ X )
= ( real_V8093663219630862766scaleR @ A @ B2 @ X ) )
=> ( A3 = B2 ) ) ) ) ).
% scaleR_right_imp_eq
thf(fact_2876_scaleR__right__distrib,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A3: real,X: A,Y: A] :
( ( real_V8093663219630862766scaleR @ A @ A3 @ ( plus_plus @ A @ X @ Y ) )
= ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) @ ( real_V8093663219630862766scaleR @ A @ A3 @ Y ) ) ) ) ).
% scaleR_right_distrib
thf(fact_2877_scaleR__left__distrib,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A3: real,B2: real,X: A] :
( ( real_V8093663219630862766scaleR @ A @ ( plus_plus @ real @ A3 @ B2 ) @ X )
= ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) @ ( real_V8093663219630862766scaleR @ A @ B2 @ X ) ) ) ) ).
% scaleR_left_distrib
thf(fact_2878_scaleR__left_Oadd,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: real,Y: real,Xa2: A] :
( ( real_V8093663219630862766scaleR @ A @ ( plus_plus @ real @ X @ Y ) @ Xa2 )
= ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ X @ Xa2 ) @ ( real_V8093663219630862766scaleR @ A @ Y @ Xa2 ) ) ) ) ).
% scaleR_left.add
thf(fact_2879_scaleR__right__mono__neg,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [B2: real,A3: real,C2: A] :
( ( ord_less_eq @ real @ B2 @ A3 )
=> ( ( ord_less_eq @ A @ C2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ C2 ) @ ( real_V8093663219630862766scaleR @ A @ B2 @ C2 ) ) ) ) ) ).
% scaleR_right_mono_neg
thf(fact_2880_scaleR__right__mono,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,B2: real,X: A] :
( ( ord_less_eq @ real @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) @ ( real_V8093663219630862766scaleR @ A @ B2 @ X ) ) ) ) ) ).
% scaleR_right_mono
thf(fact_2881_scaleR__le__cancel__left__pos,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,A3: A,B2: A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ C2 )
=> ( ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ ( real_V8093663219630862766scaleR @ A @ C2 @ B2 ) )
= ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ).
% scaleR_le_cancel_left_pos
thf(fact_2882_scaleR__le__cancel__left__neg,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,A3: A,B2: A] :
( ( ord_less @ real @ C2 @ ( zero_zero @ real ) )
=> ( ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ ( real_V8093663219630862766scaleR @ A @ C2 @ B2 ) )
= ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ).
% scaleR_le_cancel_left_neg
thf(fact_2883_scaleR__le__cancel__left,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,A3: A,B2: A] :
( ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ ( real_V8093663219630862766scaleR @ A @ C2 @ B2 ) )
= ( ( ( ord_less @ real @ ( zero_zero @ real ) @ C2 )
=> ( ord_less_eq @ A @ A3 @ B2 ) )
& ( ( ord_less @ real @ C2 @ ( zero_zero @ real ) )
=> ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ) ).
% scaleR_le_cancel_left
thf(fact_2884_scaleR__left__mono__neg,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [B2: A,A3: A,C2: real] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( ord_less_eq @ real @ C2 @ ( zero_zero @ real ) )
=> ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ ( real_V8093663219630862766scaleR @ A @ C2 @ B2 ) ) ) ) ) ).
% scaleR_left_mono_neg
thf(fact_2885_scaleR__left__mono,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [X: A,Y: A,A3: real] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_less_eq @ real @ ( zero_zero @ real ) @ A3 )
=> ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) @ ( real_V8093663219630862766scaleR @ A @ A3 @ Y ) ) ) ) ) ).
% scaleR_left_mono
thf(fact_2886_vector__fraction__eq__iff,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [U: real,V2: real,A3: A,X: A] :
( ( ( real_V8093663219630862766scaleR @ A @ ( divide_divide @ real @ U @ V2 ) @ A3 )
= X )
= ( ( ( V2
= ( zero_zero @ real ) )
=> ( X
= ( zero_zero @ A ) ) )
& ( ( V2
!= ( zero_zero @ real ) )
=> ( ( real_V8093663219630862766scaleR @ A @ U @ A3 )
= ( real_V8093663219630862766scaleR @ A @ V2 @ X ) ) ) ) ) ) ).
% vector_fraction_eq_iff
thf(fact_2887_eq__vector__fraction__iff,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: A,U: real,V2: real,A3: A] :
( ( X
= ( real_V8093663219630862766scaleR @ A @ ( divide_divide @ real @ U @ V2 ) @ A3 ) )
= ( ( ( V2
= ( zero_zero @ real ) )
=> ( X
= ( zero_zero @ A ) ) )
& ( ( V2
!= ( zero_zero @ real ) )
=> ( ( real_V8093663219630862766scaleR @ A @ V2 @ X )
= ( real_V8093663219630862766scaleR @ A @ U @ A3 ) ) ) ) ) ) ).
% eq_vector_fraction_iff
thf(fact_2888_Real__Vector__Spaces_Ole__add__iff1,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,E3: A,C2: A,B2: real,D2: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ E3 ) @ C2 ) @ ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ B2 @ E3 ) @ D2 ) )
= ( ord_less_eq @ A @ ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ ( minus_minus @ real @ A3 @ B2 ) @ E3 ) @ C2 ) @ D2 ) ) ) ).
% Real_Vector_Spaces.le_add_iff1
thf(fact_2889_Real__Vector__Spaces_Ole__add__iff2,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,E3: A,C2: A,B2: real,D2: A] :
( ( ord_less_eq @ A @ ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ E3 ) @ C2 ) @ ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ B2 @ E3 ) @ D2 ) )
= ( ord_less_eq @ A @ C2 @ ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ ( minus_minus @ real @ B2 @ A3 ) @ E3 ) @ D2 ) ) ) ) ).
% Real_Vector_Spaces.le_add_iff2
thf(fact_2890_zero__le__scaleR__iff,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( real_V8093663219630862766scaleR @ A @ A3 @ B2 ) )
= ( ( ( ord_less @ real @ ( zero_zero @ real ) @ A3 )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 ) )
| ( ( ord_less @ real @ A3 @ ( zero_zero @ real ) )
& ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) ) )
| ( A3
= ( zero_zero @ real ) ) ) ) ) ).
% zero_le_scaleR_iff
thf(fact_2891_scaleR__le__0__iff,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,B2: A] :
( ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ B2 ) @ ( zero_zero @ A ) )
= ( ( ( ord_less @ real @ ( zero_zero @ real ) @ A3 )
& ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) ) )
| ( ( ord_less @ real @ A3 @ ( zero_zero @ real ) )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 ) )
| ( A3
= ( zero_zero @ real ) ) ) ) ) ).
% scaleR_le_0_iff
thf(fact_2892_scaleR__nonpos__nonpos,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,B2: A] :
( ( ord_less_eq @ real @ A3 @ ( zero_zero @ real ) )
=> ( ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( real_V8093663219630862766scaleR @ A @ A3 @ B2 ) ) ) ) ) ).
% scaleR_nonpos_nonpos
thf(fact_2893_scaleR__nonpos__nonneg,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,X: A] :
( ( ord_less_eq @ real @ A3 @ ( zero_zero @ real ) )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) @ ( zero_zero @ A ) ) ) ) ) ).
% scaleR_nonpos_nonneg
thf(fact_2894_scaleR__nonneg__nonpos,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,X: A] :
( ( ord_less_eq @ real @ ( zero_zero @ real ) @ A3 )
=> ( ( ord_less_eq @ A @ X @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) @ ( zero_zero @ A ) ) ) ) ) ).
% scaleR_nonneg_nonpos
thf(fact_2895_scaleR__nonneg__nonneg,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,X: A] :
( ( ord_less_eq @ real @ ( zero_zero @ real ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) ) ) ) ) ).
% scaleR_nonneg_nonneg
thf(fact_2896_split__scaleR__pos__le,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,B2: A] :
( ( ( ( ord_less_eq @ real @ ( zero_zero @ real ) @ A3 )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 ) )
| ( ( ord_less_eq @ real @ A3 @ ( zero_zero @ real ) )
& ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) ) ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( real_V8093663219630862766scaleR @ A @ A3 @ B2 ) ) ) ) ).
% split_scaleR_pos_le
thf(fact_2897_split__scaleR__neg__le,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,X: A] :
( ( ( ( ord_less_eq @ real @ ( zero_zero @ real ) @ A3 )
& ( ord_less_eq @ A @ X @ ( zero_zero @ A ) ) )
| ( ( ord_less_eq @ real @ A3 @ ( zero_zero @ real ) )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ X ) ) )
=> ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) @ ( zero_zero @ A ) ) ) ) ).
% split_scaleR_neg_le
thf(fact_2898_scaleR__mono_H,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,B2: real,C2: A,D2: A] :
( ( ord_less_eq @ real @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ D2 )
=> ( ( ord_less_eq @ real @ ( zero_zero @ real ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ C2 )
=> ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ C2 ) @ ( real_V8093663219630862766scaleR @ A @ B2 @ D2 ) ) ) ) ) ) ) ).
% scaleR_mono'
thf(fact_2899_scaleR__mono,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [A3: real,B2: real,X: A,Y: A] :
( ( ord_less_eq @ real @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_less_eq @ real @ ( zero_zero @ real ) @ B2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) @ ( real_V8093663219630862766scaleR @ A @ B2 @ Y ) ) ) ) ) ) ) ).
% scaleR_mono
thf(fact_2900_scaleR__left__le__one__le,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [X: A,A3: real] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less_eq @ real @ A3 @ ( one_one @ real ) )
=> ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) @ X ) ) ) ) ).
% scaleR_left_le_one_le
thf(fact_2901_scaleR__2,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: A] :
( ( real_V8093663219630862766scaleR @ A @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) @ X )
= ( plus_plus @ A @ X @ X ) ) ) ).
% scaleR_2
thf(fact_2902_sin__coeff__Suc,axiom,
! [N2: nat] :
( ( sin_coeff @ ( suc @ N2 ) )
= ( divide_divide @ real @ ( cos_coeff @ N2 ) @ ( semiring_1_of_nat @ real @ ( suc @ N2 ) ) ) ) ).
% sin_coeff_Suc
thf(fact_2903_add__tan__eq,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( ( ( cos @ A @ X )
!= ( zero_zero @ A ) )
=> ( ( ( cos @ A @ Y )
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( tan @ A @ X ) @ ( tan @ A @ Y ) )
= ( divide_divide @ A @ ( sin @ A @ ( plus_plus @ A @ X @ Y ) ) @ ( times_times @ A @ ( cos @ A @ X ) @ ( cos @ A @ Y ) ) ) ) ) ) ) ).
% add_tan_eq
thf(fact_2904_lemma__tan__add1,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( ( ( cos @ A @ X )
!= ( zero_zero @ A ) )
=> ( ( ( cos @ A @ Y )
!= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( tan @ A @ X ) @ ( tan @ A @ Y ) ) )
= ( divide_divide @ A @ ( cos @ A @ ( plus_plus @ A @ X @ Y ) ) @ ( times_times @ A @ ( cos @ A @ X ) @ ( cos @ A @ Y ) ) ) ) ) ) ) ).
% lemma_tan_add1
thf(fact_2905_tan__diff,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( ( ( cos @ A @ X )
!= ( zero_zero @ A ) )
=> ( ( ( cos @ A @ Y )
!= ( zero_zero @ A ) )
=> ( ( ( cos @ A @ ( minus_minus @ A @ X @ Y ) )
!= ( zero_zero @ A ) )
=> ( ( tan @ A @ ( minus_minus @ A @ X @ Y ) )
= ( divide_divide @ A @ ( minus_minus @ A @ ( tan @ A @ X ) @ ( tan @ A @ Y ) ) @ ( plus_plus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( tan @ A @ X ) @ ( tan @ A @ Y ) ) ) ) ) ) ) ) ) ).
% tan_diff
thf(fact_2906_tan__add,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( ( ( cos @ A @ X )
!= ( zero_zero @ A ) )
=> ( ( ( cos @ A @ Y )
!= ( zero_zero @ A ) )
=> ( ( ( cos @ A @ ( plus_plus @ A @ X @ Y ) )
!= ( zero_zero @ A ) )
=> ( ( tan @ A @ ( plus_plus @ A @ X @ Y ) )
= ( divide_divide @ A @ ( plus_plus @ A @ ( tan @ A @ X ) @ ( tan @ A @ Y ) ) @ ( minus_minus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( tan @ A @ X ) @ ( tan @ A @ Y ) ) ) ) ) ) ) ) ) ).
% tan_add
thf(fact_2907_cos__coeff__Suc,axiom,
! [N2: nat] :
( ( cos_coeff @ ( suc @ N2 ) )
= ( divide_divide @ real @ ( uminus_uminus @ real @ ( sin_coeff @ N2 ) ) @ ( semiring_1_of_nat @ real @ ( suc @ N2 ) ) ) ) ).
% cos_coeff_Suc
thf(fact_2908_tan__half,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ( ( tan @ A )
= ( ^ [X2: A] : ( divide_divide @ A @ ( sin @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ X2 ) ) @ ( plus_plus @ A @ ( cos @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ X2 ) ) @ ( one_one @ A ) ) ) ) ) ) ).
% tan_half
thf(fact_2909_sum__pos__lt__pair,axiom,
! [F2: nat > real,K: nat] :
( ( summable @ real @ F2 )
=> ( ! [D3: nat] : ( ord_less @ real @ ( zero_zero @ real ) @ ( plus_plus @ real @ ( F2 @ ( plus_plus @ nat @ K @ ( times_times @ nat @ ( suc @ ( suc @ ( zero_zero @ nat ) ) ) @ D3 ) ) ) @ ( F2 @ ( plus_plus @ nat @ K @ ( plus_plus @ nat @ ( times_times @ nat @ ( suc @ ( suc @ ( zero_zero @ nat ) ) ) @ D3 ) @ ( one_one @ nat ) ) ) ) ) )
=> ( ord_less @ real @ ( groups7311177749621191930dd_sum @ nat @ real @ F2 @ ( set_ord_lessThan @ nat @ K ) ) @ ( suminf @ real @ F2 ) ) ) ) ).
% sum_pos_lt_pair
thf(fact_2910_modulo__int__unfold,axiom,
! [L: int,K: int,N2: nat,M: nat] :
( ( ( ( ( sgn_sgn @ int @ L )
= ( zero_zero @ int ) )
| ( ( sgn_sgn @ int @ K )
= ( zero_zero @ int ) )
| ( N2
= ( zero_zero @ nat ) ) )
=> ( ( modulo_modulo @ int @ ( times_times @ int @ ( sgn_sgn @ int @ K ) @ ( semiring_1_of_nat @ int @ M ) ) @ ( times_times @ int @ ( sgn_sgn @ int @ L ) @ ( semiring_1_of_nat @ int @ N2 ) ) )
= ( times_times @ int @ ( sgn_sgn @ int @ K ) @ ( semiring_1_of_nat @ int @ M ) ) ) )
& ( ~ ( ( ( sgn_sgn @ int @ L )
= ( zero_zero @ int ) )
| ( ( sgn_sgn @ int @ K )
= ( zero_zero @ int ) )
| ( N2
= ( zero_zero @ nat ) ) )
=> ( ( ( ( sgn_sgn @ int @ K )
= ( sgn_sgn @ int @ L ) )
=> ( ( modulo_modulo @ int @ ( times_times @ int @ ( sgn_sgn @ int @ K ) @ ( semiring_1_of_nat @ int @ M ) ) @ ( times_times @ int @ ( sgn_sgn @ int @ L ) @ ( semiring_1_of_nat @ int @ N2 ) ) )
= ( times_times @ int @ ( sgn_sgn @ int @ L ) @ ( semiring_1_of_nat @ int @ ( modulo_modulo @ nat @ M @ N2 ) ) ) ) )
& ( ( ( sgn_sgn @ int @ K )
!= ( sgn_sgn @ int @ L ) )
=> ( ( modulo_modulo @ int @ ( times_times @ int @ ( sgn_sgn @ int @ K ) @ ( semiring_1_of_nat @ int @ M ) ) @ ( times_times @ int @ ( sgn_sgn @ int @ L ) @ ( semiring_1_of_nat @ int @ N2 ) ) )
= ( times_times @ int @ ( sgn_sgn @ int @ L )
@ ( minus_minus @ int
@ ( semiring_1_of_nat @ int
@ ( times_times @ nat @ N2
@ ( zero_neq_one_of_bool @ nat
@ ~ ( dvd_dvd @ nat @ N2 @ M ) ) ) )
@ ( semiring_1_of_nat @ int @ ( modulo_modulo @ nat @ M @ N2 ) ) ) ) ) ) ) ) ) ).
% modulo_int_unfold
thf(fact_2911_divide__int__unfold,axiom,
! [L: int,K: int,N2: nat,M: nat] :
( ( ( ( ( sgn_sgn @ int @ L )
= ( zero_zero @ int ) )
| ( ( sgn_sgn @ int @ K )
= ( zero_zero @ int ) )
| ( N2
= ( zero_zero @ nat ) ) )
=> ( ( divide_divide @ int @ ( times_times @ int @ ( sgn_sgn @ int @ K ) @ ( semiring_1_of_nat @ int @ M ) ) @ ( times_times @ int @ ( sgn_sgn @ int @ L ) @ ( semiring_1_of_nat @ int @ N2 ) ) )
= ( zero_zero @ int ) ) )
& ( ~ ( ( ( sgn_sgn @ int @ L )
= ( zero_zero @ int ) )
| ( ( sgn_sgn @ int @ K )
= ( zero_zero @ int ) )
| ( N2
= ( zero_zero @ nat ) ) )
=> ( ( ( ( sgn_sgn @ int @ K )
= ( sgn_sgn @ int @ L ) )
=> ( ( divide_divide @ int @ ( times_times @ int @ ( sgn_sgn @ int @ K ) @ ( semiring_1_of_nat @ int @ M ) ) @ ( times_times @ int @ ( sgn_sgn @ int @ L ) @ ( semiring_1_of_nat @ int @ N2 ) ) )
= ( semiring_1_of_nat @ int @ ( divide_divide @ nat @ M @ N2 ) ) ) )
& ( ( ( sgn_sgn @ int @ K )
!= ( sgn_sgn @ int @ L ) )
=> ( ( divide_divide @ int @ ( times_times @ int @ ( sgn_sgn @ int @ K ) @ ( semiring_1_of_nat @ int @ M ) ) @ ( times_times @ int @ ( sgn_sgn @ int @ L ) @ ( semiring_1_of_nat @ int @ N2 ) ) )
= ( uminus_uminus @ int
@ ( semiring_1_of_nat @ int
@ ( plus_plus @ nat @ ( divide_divide @ nat @ M @ N2 )
@ ( zero_neq_one_of_bool @ nat
@ ~ ( dvd_dvd @ nat @ N2 @ M ) ) ) ) ) ) ) ) ) ) ).
% divide_int_unfold
thf(fact_2912_xor__Suc__0__eq,axiom,
! [N2: nat] :
( ( bit_se5824344971392196577ns_xor @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) )
= ( minus_minus @ nat @ ( plus_plus @ nat @ N2 @ ( zero_neq_one_of_bool @ nat @ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) )
@ ( zero_neq_one_of_bool @ nat
@ ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ).
% xor_Suc_0_eq
thf(fact_2913_Suc__0__xor__eq,axiom,
! [N2: nat] :
( ( bit_se5824344971392196577ns_xor @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
= ( minus_minus @ nat @ ( plus_plus @ nat @ N2 @ ( zero_neq_one_of_bool @ nat @ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) )
@ ( zero_neq_one_of_bool @ nat
@ ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ).
% Suc_0_xor_eq
thf(fact_2914_sgn__sgn,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A] :
( ( sgn_sgn @ A @ ( sgn_sgn @ A @ A3 ) )
= ( sgn_sgn @ A @ A3 ) ) ) ).
% sgn_sgn
thf(fact_2915_sgn__0,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ( ( sgn_sgn @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% sgn_0
thf(fact_2916_sgn__zero,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ( ( sgn_sgn @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% sgn_zero
thf(fact_2917_sgn__1,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ( ( sgn_sgn @ A @ ( one_one @ A ) )
= ( one_one @ A ) ) ) ).
% sgn_1
thf(fact_2918_bit_Oxor__self,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [X: A] :
( ( bit_se5824344971392196577ns_xor @ A @ X @ X )
= ( zero_zero @ A ) ) ) ).
% bit.xor_self
thf(fact_2919_xor__self__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se5824344971392196577ns_xor @ A @ A3 @ A3 )
= ( zero_zero @ A ) ) ) ).
% xor_self_eq
thf(fact_2920_xor_Oleft__neutral,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se5824344971392196577ns_xor @ A @ ( zero_zero @ A ) @ A3 )
= A3 ) ) ).
% xor.left_neutral
thf(fact_2921_xor_Oright__neutral,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se5824344971392196577ns_xor @ A @ A3 @ ( zero_zero @ A ) )
= A3 ) ) ).
% xor.right_neutral
thf(fact_2922_sgn__divide,axiom,
! [A: $tType] :
( ( field_abs_sgn @ A )
=> ! [A3: A,B2: A] :
( ( sgn_sgn @ A @ ( divide_divide @ A @ A3 @ B2 ) )
= ( divide_divide @ A @ ( sgn_sgn @ A @ A3 ) @ ( sgn_sgn @ A @ B2 ) ) ) ) ).
% sgn_divide
thf(fact_2923_idom__abs__sgn__class_Osgn__minus,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A] :
( ( sgn_sgn @ A @ ( uminus_uminus @ A @ A3 ) )
= ( uminus_uminus @ A @ ( sgn_sgn @ A @ A3 ) ) ) ) ).
% idom_abs_sgn_class.sgn_minus
thf(fact_2924_summable__single,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [I: nat,F2: nat > A] :
( summable @ A
@ ^ [R4: nat] : ( if @ A @ ( R4 = I ) @ ( F2 @ R4 ) @ ( zero_zero @ A ) ) ) ) ).
% summable_single
thf(fact_2925_summable__zero,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ( summable @ A
@ ^ [N: nat] : ( zero_zero @ A ) ) ) ).
% summable_zero
thf(fact_2926_summable__iff__shift,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,K: nat] :
( ( summable @ A
@ ^ [N: nat] : ( F2 @ ( plus_plus @ nat @ N @ K ) ) )
= ( summable @ A @ F2 ) ) ) ).
% summable_iff_shift
thf(fact_2927_sgn__less,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( sgn_sgn @ A @ A3 ) @ ( zero_zero @ A ) )
= ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% sgn_less
thf(fact_2928_sgn__greater,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( sgn_sgn @ A @ A3 ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% sgn_greater
thf(fact_2929_divide__sgn,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( divide_divide @ A @ A3 @ ( sgn_sgn @ A @ B2 ) )
= ( times_times @ A @ A3 @ ( sgn_sgn @ A @ B2 ) ) ) ) ).
% divide_sgn
thf(fact_2930_summable__cmult__iff,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [C2: A,F2: nat > A] :
( ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ C2 @ ( F2 @ N ) ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( summable @ A @ F2 ) ) ) ) ).
% summable_cmult_iff
thf(fact_2931_summable__divide__iff,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: nat > A,C2: A] :
( ( summable @ A
@ ^ [N: nat] : ( divide_divide @ A @ ( F2 @ N ) @ C2 ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( summable @ A @ F2 ) ) ) ) ).
% summable_divide_iff
thf(fact_2932_summable__If__finite,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [P2: nat > $o,F2: nat > A] :
( ( finite_finite @ nat @ ( collect @ nat @ P2 ) )
=> ( summable @ A
@ ^ [R4: nat] : ( if @ A @ ( P2 @ R4 ) @ ( F2 @ R4 ) @ ( zero_zero @ A ) ) ) ) ) ).
% summable_If_finite
thf(fact_2933_summable__If__finite__set,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [A4: set @ nat,F2: nat > A] :
( ( finite_finite @ nat @ A4 )
=> ( summable @ A
@ ^ [R4: nat] : ( if @ A @ ( member2 @ nat @ R4 @ A4 ) @ ( F2 @ R4 ) @ ( zero_zero @ A ) ) ) ) ) ).
% summable_If_finite_set
thf(fact_2934_sgn__pos,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( sgn_sgn @ A @ A3 )
= ( one_one @ A ) ) ) ) ).
% sgn_pos
thf(fact_2935_sgn__mult__self__eq,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( times_times @ A @ ( sgn_sgn @ A @ A3 ) @ ( sgn_sgn @ A @ A3 ) )
= ( zero_neq_one_of_bool @ A
@ ( A3
!= ( zero_zero @ A ) ) ) ) ) ).
% sgn_mult_self_eq
thf(fact_2936_sgn__mult__dvd__iff,axiom,
! [R2: int,L: int,K: int] :
( ( dvd_dvd @ int @ ( times_times @ int @ ( sgn_sgn @ int @ R2 ) @ L ) @ K )
= ( ( dvd_dvd @ int @ L @ K )
& ( ( R2
= ( zero_zero @ int ) )
=> ( K
= ( zero_zero @ int ) ) ) ) ) ).
% sgn_mult_dvd_iff
thf(fact_2937_mult__sgn__dvd__iff,axiom,
! [L: int,R2: int,K: int] :
( ( dvd_dvd @ int @ ( times_times @ int @ L @ ( sgn_sgn @ int @ R2 ) ) @ K )
= ( ( dvd_dvd @ int @ L @ K )
& ( ( R2
= ( zero_zero @ int ) )
=> ( K
= ( zero_zero @ int ) ) ) ) ) ).
% mult_sgn_dvd_iff
thf(fact_2938_dvd__sgn__mult__iff,axiom,
! [L: int,R2: int,K: int] :
( ( dvd_dvd @ int @ L @ ( times_times @ int @ ( sgn_sgn @ int @ R2 ) @ K ) )
= ( ( dvd_dvd @ int @ L @ K )
| ( R2
= ( zero_zero @ int ) ) ) ) ).
% dvd_sgn_mult_iff
thf(fact_2939_dvd__mult__sgn__iff,axiom,
! [L: int,K: int,R2: int] :
( ( dvd_dvd @ int @ L @ ( times_times @ int @ K @ ( sgn_sgn @ int @ R2 ) ) )
= ( ( dvd_dvd @ int @ L @ K )
| ( R2
= ( zero_zero @ int ) ) ) ) ).
% dvd_mult_sgn_iff
thf(fact_2940_sgn__neg,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( sgn_sgn @ A @ A3 )
= ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ) ).
% sgn_neg
thf(fact_2941_sgn__of__nat,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: nat] :
( ( sgn_sgn @ A @ ( semiring_1_of_nat @ A @ N2 ) )
= ( zero_neq_one_of_bool @ A @ ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% sgn_of_nat
thf(fact_2942_xor__nat__numerals_I1_J,axiom,
! [Y: num] :
( ( bit_se5824344971392196577ns_xor @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( numeral_numeral @ nat @ ( bit0 @ Y ) ) )
= ( numeral_numeral @ nat @ ( bit1 @ Y ) ) ) ).
% xor_nat_numerals(1)
thf(fact_2943_xor__nat__numerals_I2_J,axiom,
! [Y: num] :
( ( bit_se5824344971392196577ns_xor @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( numeral_numeral @ nat @ ( bit1 @ Y ) ) )
= ( numeral_numeral @ nat @ ( bit0 @ Y ) ) ) ).
% xor_nat_numerals(2)
thf(fact_2944_xor__nat__numerals_I3_J,axiom,
! [X: num] :
( ( bit_se5824344971392196577ns_xor @ nat @ ( numeral_numeral @ nat @ ( bit0 @ X ) ) @ ( suc @ ( zero_zero @ nat ) ) )
= ( numeral_numeral @ nat @ ( bit1 @ X ) ) ) ).
% xor_nat_numerals(3)
thf(fact_2945_xor__nat__numerals_I4_J,axiom,
! [X: num] :
( ( bit_se5824344971392196577ns_xor @ nat @ ( numeral_numeral @ nat @ ( bit1 @ X ) ) @ ( suc @ ( zero_zero @ nat ) ) )
= ( numeral_numeral @ nat @ ( bit0 @ X ) ) ) ).
% xor_nat_numerals(4)
thf(fact_2946_xor__numerals_I6_J,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [X: num,Y: num] :
( ( bit_se5824344971392196577ns_xor @ A @ ( numeral_numeral @ A @ ( bit1 @ X ) ) @ ( numeral_numeral @ A @ ( bit0 @ Y ) ) )
= ( plus_plus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se5824344971392196577ns_xor @ A @ ( numeral_numeral @ A @ X ) @ ( numeral_numeral @ A @ Y ) ) ) ) ) ) ).
% xor_numerals(6)
thf(fact_2947_xor__numerals_I4_J,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [X: num,Y: num] :
( ( bit_se5824344971392196577ns_xor @ A @ ( numeral_numeral @ A @ ( bit0 @ X ) ) @ ( numeral_numeral @ A @ ( bit1 @ Y ) ) )
= ( plus_plus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se5824344971392196577ns_xor @ A @ ( numeral_numeral @ A @ X ) @ ( numeral_numeral @ A @ Y ) ) ) ) ) ) ).
% xor_numerals(4)
thf(fact_2948_sgn__zero__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X: A] :
( ( ( sgn_sgn @ A @ X )
= ( zero_zero @ A ) )
= ( X
= ( zero_zero @ A ) ) ) ) ).
% sgn_zero_iff
thf(fact_2949_sgn__eq__0__iff,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A] :
( ( ( sgn_sgn @ A @ A3 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% sgn_eq_0_iff
thf(fact_2950_sgn__0__0,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( ( sgn_sgn @ A @ A3 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% sgn_0_0
thf(fact_2951_sgn__mult,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A,B2: A] :
( ( sgn_sgn @ A @ ( times_times @ A @ A3 @ B2 ) )
= ( times_times @ A @ ( sgn_sgn @ A @ A3 ) @ ( sgn_sgn @ A @ B2 ) ) ) ) ).
% sgn_mult
thf(fact_2952_same__sgn__sgn__add,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [B2: A,A3: A] :
( ( ( sgn_sgn @ A @ B2 )
= ( sgn_sgn @ A @ A3 ) )
=> ( ( sgn_sgn @ A @ ( plus_plus @ A @ A3 @ B2 ) )
= ( sgn_sgn @ A @ A3 ) ) ) ) ).
% same_sgn_sgn_add
thf(fact_2953_summable__const__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [C2: A] :
( ( summable @ A
@ ^ [Uu3: nat] : C2 )
= ( C2
= ( zero_zero @ A ) ) ) ) ).
% summable_const_iff
thf(fact_2954_summable__comparison__test_H,axiom,
! [A: $tType] :
( ( real_Vector_banach @ A )
=> ! [G: nat > real,N7: nat,F2: nat > A] :
( ( summable @ real @ G )
=> ( ! [N3: nat] :
( ( ord_less_eq @ nat @ N7 @ N3 )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( F2 @ N3 ) ) @ ( G @ N3 ) ) )
=> ( summable @ A @ F2 ) ) ) ) ).
% summable_comparison_test'
thf(fact_2955_summable__comparison__test,axiom,
! [A: $tType] :
( ( real_Vector_banach @ A )
=> ! [F2: nat > A,G: nat > real] :
( ? [N8: nat] :
! [N3: nat] :
( ( ord_less_eq @ nat @ N8 @ N3 )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( F2 @ N3 ) ) @ ( G @ N3 ) ) )
=> ( ( summable @ real @ G )
=> ( summable @ A @ F2 ) ) ) ) ).
% summable_comparison_test
thf(fact_2956_summable__add,axiom,
! [A: $tType] :
( ( ( topolo5987344860129210374id_add @ A )
& ( topological_t2_space @ A ) )
=> ! [F2: nat > A,G: nat > A] :
( ( summable @ A @ F2 )
=> ( ( summable @ A @ G )
=> ( summable @ A
@ ^ [N: nat] : ( plus_plus @ A @ ( F2 @ N ) @ ( G @ N ) ) ) ) ) ) ).
% summable_add
thf(fact_2957_summable__Suc__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A] :
( ( summable @ A
@ ^ [N: nat] : ( F2 @ ( suc @ N ) ) )
= ( summable @ A @ F2 ) ) ) ).
% summable_Suc_iff
thf(fact_2958_summable__ignore__initial__segment,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,K: nat] :
( ( summable @ A @ F2 )
=> ( summable @ A
@ ^ [N: nat] : ( F2 @ ( plus_plus @ nat @ N @ K ) ) ) ) ) ).
% summable_ignore_initial_segment
thf(fact_2959_suminf__le,axiom,
! [A: $tType] :
( ( ( ordere6911136660526730532id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A,G: nat > A] :
( ! [N3: nat] : ( ord_less_eq @ A @ ( F2 @ N3 ) @ ( G @ N3 ) )
=> ( ( summable @ A @ F2 )
=> ( ( summable @ A @ G )
=> ( ord_less_eq @ A @ ( suminf @ A @ F2 ) @ ( suminf @ A @ G ) ) ) ) ) ) ).
% suminf_le
thf(fact_2960_summable__finite,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [N7: set @ nat,F2: nat > A] :
( ( finite_finite @ nat @ N7 )
=> ( ! [N3: nat] :
( ~ ( member2 @ nat @ N3 @ N7 )
=> ( ( F2 @ N3 )
= ( zero_zero @ A ) ) )
=> ( summable @ A @ F2 ) ) ) ) ).
% summable_finite
thf(fact_2961_sgn__not__eq__imp,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [B2: A,A3: A] :
( ( ( sgn_sgn @ A @ B2 )
!= ( sgn_sgn @ A @ A3 ) )
=> ( ( ( sgn_sgn @ A @ A3 )
!= ( zero_zero @ A ) )
=> ( ( ( sgn_sgn @ A @ B2 )
!= ( zero_zero @ A ) )
=> ( ( sgn_sgn @ A @ A3 )
= ( uminus_uminus @ A @ ( sgn_sgn @ A @ B2 ) ) ) ) ) ) ) ).
% sgn_not_eq_imp
thf(fact_2962_sgn__minus__1,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ( ( sgn_sgn @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% sgn_minus_1
thf(fact_2963_int__sgnE,axiom,
! [K: int] :
~ ! [N3: nat,L4: int] :
( K
!= ( times_times @ int @ ( sgn_sgn @ int @ L4 ) @ ( semiring_1_of_nat @ int @ N3 ) ) ) ).
% int_sgnE
thf(fact_2964_summable__mult__D,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [C2: A,F2: nat > A] :
( ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ C2 @ ( F2 @ N ) ) )
=> ( ( C2
!= ( zero_zero @ A ) )
=> ( summable @ A @ F2 ) ) ) ) ).
% summable_mult_D
thf(fact_2965_summable__zero__power,axiom,
! [A: $tType] :
( ( ( comm_ring_1 @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ( summable @ A @ ( power_power @ A @ ( zero_zero @ A ) ) ) ) ).
% summable_zero_power
thf(fact_2966_suminf__add,axiom,
! [A: $tType] :
( ( ( topolo5987344860129210374id_add @ A )
& ( topological_t2_space @ A ) )
=> ! [F2: nat > A,G: nat > A] :
( ( summable @ A @ F2 )
=> ( ( summable @ A @ G )
=> ( ( plus_plus @ A @ ( suminf @ A @ F2 ) @ ( suminf @ A @ G ) )
= ( suminf @ A
@ ^ [N: nat] : ( plus_plus @ A @ ( F2 @ N ) @ ( G @ N ) ) ) ) ) ) ) ).
% suminf_add
thf(fact_2967_suminf__nonneg,axiom,
! [A: $tType] :
( ( ( ordere6911136660526730532id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A] :
( ( summable @ A @ F2 )
=> ( ! [N3: nat] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ N3 ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( suminf @ A @ F2 ) ) ) ) ) ).
% suminf_nonneg
thf(fact_2968_suminf__eq__zero__iff,axiom,
! [A: $tType] :
( ( ( ordere6911136660526730532id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A] :
( ( summable @ A @ F2 )
=> ( ! [N3: nat] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ N3 ) )
=> ( ( ( suminf @ A @ F2 )
= ( zero_zero @ A ) )
= ( ! [N: nat] :
( ( F2 @ N )
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% suminf_eq_zero_iff
thf(fact_2969_suminf__pos,axiom,
! [A: $tType] :
( ( ( ordere6911136660526730532id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A] :
( ( summable @ A @ F2 )
=> ( ! [N3: nat] : ( ord_less @ A @ ( zero_zero @ A ) @ ( F2 @ N3 ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( suminf @ A @ F2 ) ) ) ) ) ).
% suminf_pos
thf(fact_2970_sgn__1__pos,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( ( sgn_sgn @ A @ A3 )
= ( one_one @ A ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% sgn_1_pos
thf(fact_2971_summable__zero__power_H,axiom,
! [A: $tType] :
( ( ( ring_1 @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [F2: nat > A] :
( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ N ) @ ( power_power @ A @ ( zero_zero @ A ) @ N ) ) ) ) ).
% summable_zero_power'
thf(fact_2972_summable__0__powser,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [F2: nat > A] :
( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ N ) @ ( power_power @ A @ ( zero_zero @ A ) @ N ) ) ) ) ).
% summable_0_powser
thf(fact_2973_powser__split__head_I3_J,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V8999393235501362500lgebra @ A ) )
=> ! [F2: nat > A,Z: A] :
( ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ N ) @ ( power_power @ A @ Z @ N ) ) )
=> ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ ( suc @ N ) ) @ ( power_power @ A @ Z @ N ) ) ) ) ) ).
% powser_split_head(3)
thf(fact_2974_summable__powser__split__head,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [F2: nat > A,Z: A] :
( ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ ( suc @ N ) ) @ ( power_power @ A @ Z @ N ) ) )
= ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ N ) @ ( power_power @ A @ Z @ N ) ) ) ) ) ).
% summable_powser_split_head
thf(fact_2975_summable__powser__ignore__initial__segment,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [F2: nat > A,M: nat,Z: A] :
( ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ ( plus_plus @ nat @ N @ M ) ) @ ( power_power @ A @ Z @ N ) ) )
= ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ N ) @ ( power_power @ A @ Z @ N ) ) ) ) ) ).
% summable_powser_ignore_initial_segment
thf(fact_2976_summable__norm__comparison__test,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,G: nat > real] :
( ? [N8: nat] :
! [N3: nat] :
( ( ord_less_eq @ nat @ N8 @ N3 )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( F2 @ N3 ) ) @ ( G @ N3 ) ) )
=> ( ( summable @ real @ G )
=> ( summable @ real
@ ^ [N: nat] : ( real_V7770717601297561774m_norm @ A @ ( F2 @ N ) ) ) ) ) ) ).
% summable_norm_comparison_test
thf(fact_2977_suminf__pos2,axiom,
! [A: $tType] :
( ( ( ordere6911136660526730532id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A,I: nat] :
( ( summable @ A @ F2 )
=> ( ! [N3: nat] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ N3 ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ ( F2 @ I ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( suminf @ A @ F2 ) ) ) ) ) ) ).
% suminf_pos2
thf(fact_2978_suminf__pos__iff,axiom,
! [A: $tType] :
( ( ( ordere6911136660526730532id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A] :
( ( summable @ A @ F2 )
=> ( ! [N3: nat] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ N3 ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ ( suminf @ A @ F2 ) )
= ( ? [I5: nat] : ( ord_less @ A @ ( zero_zero @ A ) @ ( F2 @ I5 ) ) ) ) ) ) ) ).
% suminf_pos_iff
thf(fact_2979_suminf__le__const,axiom,
! [A: $tType] :
( ( ( ordere6911136660526730532id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A,X: A] :
( ( summable @ A @ F2 )
=> ( ! [N3: nat] : ( ord_less_eq @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_lessThan @ nat @ N3 ) ) @ X )
=> ( ord_less_eq @ A @ ( suminf @ A @ F2 ) @ X ) ) ) ) ).
% suminf_le_const
thf(fact_2980_sgn__1__neg,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( ( sgn_sgn @ A @ A3 )
= ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% sgn_1_neg
thf(fact_2981_sgn__if,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ( ( sgn_sgn @ A )
= ( ^ [X2: A] :
( if @ A
@ ( X2
= ( zero_zero @ A ) )
@ ( zero_zero @ A )
@ ( if @ A @ ( ord_less @ A @ ( zero_zero @ A ) @ X2 ) @ ( one_one @ A ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ) ) ) ).
% sgn_if
thf(fact_2982_zsgn__def,axiom,
( ( sgn_sgn @ int )
= ( ^ [I5: int] :
( if @ int
@ ( I5
= ( zero_zero @ int ) )
@ ( zero_zero @ int )
@ ( if @ int @ ( ord_less @ int @ ( zero_zero @ int ) @ I5 ) @ ( one_one @ int ) @ ( uminus_uminus @ int @ ( one_one @ int ) ) ) ) ) ) ).
% zsgn_def
thf(fact_2983_summableI__nonneg__bounded,axiom,
! [A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( ordere6911136660526730532id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A,X: A] :
( ! [N3: nat] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ N3 ) )
=> ( ! [N3: nat] : ( ord_less_eq @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_lessThan @ nat @ N3 ) ) @ X )
=> ( summable @ A @ F2 ) ) ) ) ).
% summableI_nonneg_bounded
thf(fact_2984_norm__sgn,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X: A] :
( ( ( X
= ( zero_zero @ A ) )
=> ( ( real_V7770717601297561774m_norm @ A @ ( sgn_sgn @ A @ X ) )
= ( zero_zero @ real ) ) )
& ( ( X
!= ( zero_zero @ A ) )
=> ( ( real_V7770717601297561774m_norm @ A @ ( sgn_sgn @ A @ X ) )
= ( one_one @ real ) ) ) ) ) ).
% norm_sgn
thf(fact_2985_bounded__imp__summable,axiom,
! [A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( linord2810124833399127020strict @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [A3: nat > A,B3: A] :
( ! [N3: nat] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( A3 @ N3 ) )
=> ( ! [N3: nat] : ( ord_less_eq @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ A3 @ ( set_ord_atMost @ nat @ N3 ) ) @ B3 )
=> ( summable @ A @ A3 ) ) ) ) ).
% bounded_imp_summable
thf(fact_2986_suminf__split__head,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A] :
( ( summable @ A @ F2 )
=> ( ( suminf @ A
@ ^ [N: nat] : ( F2 @ ( suc @ N ) ) )
= ( minus_minus @ A @ ( suminf @ A @ F2 ) @ ( F2 @ ( zero_zero @ nat ) ) ) ) ) ) ).
% suminf_split_head
thf(fact_2987_sum__le__suminf,axiom,
! [A: $tType] :
( ( ( ordere6911136660526730532id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A,I6: set @ nat] :
( ( summable @ A @ F2 )
=> ( ( finite_finite @ nat @ I6 )
=> ( ! [N3: nat] :
( ( member2 @ nat @ N3 @ ( uminus_uminus @ ( set @ nat ) @ I6 ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ N3 ) ) )
=> ( ord_less_eq @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ I6 ) @ ( suminf @ A @ F2 ) ) ) ) ) ) ).
% sum_le_suminf
thf(fact_2988_suminf__split__initial__segment,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,K: nat] :
( ( summable @ A @ F2 )
=> ( ( suminf @ A @ F2 )
= ( plus_plus @ A
@ ( suminf @ A
@ ^ [N: nat] : ( F2 @ ( plus_plus @ nat @ N @ K ) ) )
@ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_lessThan @ nat @ K ) ) ) ) ) ) ).
% suminf_split_initial_segment
thf(fact_2989_suminf__minus__initial__segment,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,K: nat] :
( ( summable @ A @ F2 )
=> ( ( suminf @ A
@ ^ [N: nat] : ( F2 @ ( plus_plus @ nat @ N @ K ) ) )
= ( minus_minus @ A @ ( suminf @ A @ F2 ) @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_lessThan @ nat @ K ) ) ) ) ) ) ).
% suminf_minus_initial_segment
thf(fact_2990_sum__less__suminf,axiom,
! [A: $tType] :
( ( ( ordere8940638589300402666id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A,N2: nat] :
( ( summable @ A @ F2 )
=> ( ! [M3: nat] :
( ( ord_less_eq @ nat @ N2 @ M3 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( F2 @ M3 ) ) )
=> ( ord_less @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_lessThan @ nat @ N2 ) ) @ ( suminf @ A @ F2 ) ) ) ) ) ).
% sum_less_suminf
thf(fact_2991_powser__split__head_I1_J,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V8999393235501362500lgebra @ A ) )
=> ! [F2: nat > A,Z: A] :
( ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ N ) @ ( power_power @ A @ Z @ N ) ) )
=> ( ( suminf @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ N ) @ ( power_power @ A @ Z @ N ) ) )
= ( plus_plus @ A @ ( F2 @ ( zero_zero @ nat ) )
@ ( times_times @ A
@ ( suminf @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ ( suc @ N ) ) @ ( power_power @ A @ Z @ N ) ) )
@ Z ) ) ) ) ) ).
% powser_split_head(1)
thf(fact_2992_powser__split__head_I2_J,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V8999393235501362500lgebra @ A ) )
=> ! [F2: nat > A,Z: A] :
( ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ N ) @ ( power_power @ A @ Z @ N ) ) )
=> ( ( times_times @ A
@ ( suminf @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ ( suc @ N ) ) @ ( power_power @ A @ Z @ N ) ) )
@ Z )
= ( minus_minus @ A
@ ( suminf @ A
@ ^ [N: nat] : ( times_times @ A @ ( F2 @ N ) @ ( power_power @ A @ Z @ N ) ) )
@ ( F2 @ ( zero_zero @ nat ) ) ) ) ) ) ).
% powser_split_head(2)
thf(fact_2993_summable__partial__sum__bound,axiom,
! [A: $tType] :
( ( real_Vector_banach @ A )
=> ! [F2: nat > A,E3: real] :
( ( summable @ A @ F2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ E3 )
=> ~ ! [N9: nat] :
~ ! [M4: nat] :
( ( ord_less_eq @ nat @ N9 @ M4 )
=> ! [N5: nat] : ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or1337092689740270186AtMost @ nat @ M4 @ N5 ) ) ) @ E3 ) ) ) ) ) ).
% summable_partial_sum_bound
thf(fact_2994_suminf__exist__split,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [R2: real,F2: nat > A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ R2 )
=> ( ( summable @ A @ F2 )
=> ? [N9: nat] :
! [N5: nat] :
( ( ord_less_eq @ nat @ N9 @ N5 )
=> ( ord_less @ real
@ ( real_V7770717601297561774m_norm @ A
@ ( suminf @ A
@ ^ [I5: nat] : ( F2 @ ( plus_plus @ nat @ I5 @ N5 ) ) ) )
@ R2 ) ) ) ) ) ).
% suminf_exist_split
thf(fact_2995_summable__ratio__test,axiom,
! [A: $tType] :
( ( real_Vector_banach @ A )
=> ! [C2: real,N7: nat,F2: nat > A] :
( ( ord_less @ real @ C2 @ ( one_one @ real ) )
=> ( ! [N3: nat] :
( ( ord_less_eq @ nat @ N7 @ N3 )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( F2 @ ( suc @ N3 ) ) ) @ ( times_times @ real @ C2 @ ( real_V7770717601297561774m_norm @ A @ ( F2 @ N3 ) ) ) ) )
=> ( summable @ A @ F2 ) ) ) ) ).
% summable_ratio_test
thf(fact_2996_sum__less__suminf2,axiom,
! [A: $tType] :
( ( ( ordere8940638589300402666id_add @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: nat > A,N2: nat,I: nat] :
( ( summable @ A @ F2 )
=> ( ! [M3: nat] :
( ( ord_less_eq @ nat @ N2 @ M3 )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ M3 ) ) )
=> ( ( ord_less_eq @ nat @ N2 @ I )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ ( F2 @ I ) )
=> ( ord_less @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_ord_lessThan @ nat @ N2 ) ) @ ( suminf @ A @ F2 ) ) ) ) ) ) ) ).
% sum_less_suminf2
thf(fact_2997_xor__nat__unfold,axiom,
( ( bit_se5824344971392196577ns_xor @ nat )
= ( ^ [M2: nat,N: nat] :
( if @ nat
@ ( M2
= ( zero_zero @ nat ) )
@ N
@ ( if @ nat
@ ( N
= ( zero_zero @ nat ) )
@ M2
@ ( plus_plus @ nat @ ( modulo_modulo @ nat @ ( plus_plus @ nat @ ( modulo_modulo @ nat @ M2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( modulo_modulo @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( bit_se5824344971392196577ns_xor @ nat @ ( divide_divide @ nat @ M2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ).
% xor_nat_unfold
thf(fact_2998_xor__nat__rec,axiom,
( ( bit_se5824344971392196577ns_xor @ nat )
= ( ^ [M2: nat,N: nat] :
( plus_plus @ nat
@ ( zero_neq_one_of_bool @ nat
@ ( ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M2 ) )
!= ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) ) ) )
@ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( bit_se5824344971392196577ns_xor @ nat @ ( divide_divide @ nat @ M2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% xor_nat_rec
thf(fact_2999_one__xor__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se5824344971392196577ns_xor @ A @ ( one_one @ A ) @ A3 )
= ( minus_minus @ A @ ( plus_plus @ A @ A3 @ ( zero_neq_one_of_bool @ A @ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) )
@ ( zero_neq_one_of_bool @ A
@ ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) ) ) ) ).
% one_xor_eq
thf(fact_3000_xor__one__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se5824344971392196577ns_xor @ A @ A3 @ ( one_one @ A ) )
= ( minus_minus @ A @ ( plus_plus @ A @ A3 @ ( zero_neq_one_of_bool @ A @ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) )
@ ( zero_neq_one_of_bool @ A
@ ~ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) ) ) ) ).
% xor_one_eq
thf(fact_3001_summable__arctan__series,axiom,
! [X: real] :
( ( ord_less_eq @ real @ ( abs_abs @ real @ X ) @ ( one_one @ real ) )
=> ( summable @ real
@ ^ [K2: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ K2 ) @ ( times_times @ real @ ( divide_divide @ real @ ( one_one @ real ) @ ( semiring_1_of_nat @ real @ ( plus_plus @ nat @ ( times_times @ nat @ K2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) ) @ ( power_power @ real @ X @ ( plus_plus @ nat @ ( times_times @ nat @ K2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) ) ) ) ) ).
% summable_arctan_series
thf(fact_3002_diffs__equiv,axiom,
! [A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( ring_1 @ A ) )
=> ! [C2: nat > A,X: A] :
( ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( diffs @ A @ C2 @ N ) @ ( power_power @ A @ X @ N ) ) )
=> ( sums @ A
@ ^ [N: nat] : ( times_times @ A @ ( times_times @ A @ ( semiring_1_of_nat @ A @ N ) @ ( C2 @ N ) ) @ ( power_power @ A @ X @ ( minus_minus @ nat @ N @ ( suc @ ( zero_zero @ nat ) ) ) ) )
@ ( suminf @ A
@ ^ [N: nat] : ( times_times @ A @ ( diffs @ A @ C2 @ N ) @ ( power_power @ A @ X @ N ) ) ) ) ) ) ).
% diffs_equiv
thf(fact_3003_dbl__dec__simps_I2_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ( ( neg_numeral_dbl_dec @ A @ ( zero_zero @ A ) )
= ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% dbl_dec_simps(2)
thf(fact_3004_case__prod__Pair__iden,axiom,
! [B: $tType,A: $tType,P4: product_prod @ A @ B] :
( ( product_case_prod @ A @ B @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B ) @ P4 )
= P4 ) ).
% case_prod_Pair_iden
thf(fact_3005_the__elem__eq,axiom,
! [A: $tType,X: A] :
( ( the_elem @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= X ) ).
% the_elem_eq
thf(fact_3006_abs__abs,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A] :
( ( abs_abs @ A @ ( abs_abs @ A @ A3 ) )
= ( abs_abs @ A @ A3 ) ) ) ).
% abs_abs
thf(fact_3007_abs__idempotent,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
( ( abs_abs @ A @ ( abs_abs @ A @ A3 ) )
= ( abs_abs @ A @ A3 ) ) ) ).
% abs_idempotent
thf(fact_3008_abs__zero,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ( ( abs_abs @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% abs_zero
thf(fact_3009_abs__eq__0,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
( ( ( abs_abs @ A @ A3 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% abs_eq_0
thf(fact_3010_abs__0__eq,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
( ( ( zero_zero @ A )
= ( abs_abs @ A @ A3 ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% abs_0_eq
thf(fact_3011_abs__0,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ( ( abs_abs @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% abs_0
thf(fact_3012_abs__mult__self__eq,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( times_times @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ A3 ) )
= ( times_times @ A @ A3 @ A3 ) ) ) ).
% abs_mult_self_eq
thf(fact_3013_abs__1,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ( ( abs_abs @ A @ ( one_one @ A ) )
= ( one_one @ A ) ) ) ).
% abs_1
thf(fact_3014_abs__add__abs,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A] :
( ( abs_abs @ A @ ( plus_plus @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) )
= ( plus_plus @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) ) ) ).
% abs_add_abs
thf(fact_3015_abs__divide,axiom,
! [A: $tType] :
( ( field_abs_sgn @ A )
=> ! [A3: A,B2: A] :
( ( abs_abs @ A @ ( divide_divide @ A @ A3 @ B2 ) )
= ( divide_divide @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) ) ) ).
% abs_divide
thf(fact_3016_abs__minus,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A] :
( ( abs_abs @ A @ ( uminus_uminus @ A @ A3 ) )
= ( abs_abs @ A @ A3 ) ) ) ).
% abs_minus
thf(fact_3017_abs__minus__cancel,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
( ( abs_abs @ A @ ( uminus_uminus @ A @ A3 ) )
= ( abs_abs @ A @ A3 ) ) ) ).
% abs_minus_cancel
thf(fact_3018_abs__dvd__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: A,K: A] :
( ( dvd_dvd @ A @ ( abs_abs @ A @ M ) @ K )
= ( dvd_dvd @ A @ M @ K ) ) ) ).
% abs_dvd_iff
thf(fact_3019_dvd__abs__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [M: A,K: A] :
( ( dvd_dvd @ A @ M @ ( abs_abs @ A @ K ) )
= ( dvd_dvd @ A @ M @ K ) ) ) ).
% dvd_abs_iff
thf(fact_3020_abs__of__nat,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: nat] :
( ( abs_abs @ A @ ( semiring_1_of_nat @ A @ N2 ) )
= ( semiring_1_of_nat @ A @ N2 ) ) ) ).
% abs_of_nat
thf(fact_3021_of__int__abs,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: int] :
( ( ring_1_of_int @ A @ ( abs_abs @ int @ X ) )
= ( abs_abs @ A @ ( ring_1_of_int @ A @ X ) ) ) ) ).
% of_int_abs
thf(fact_3022_abs__bool__eq,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [P2: $o] :
( ( abs_abs @ A @ ( zero_neq_one_of_bool @ A @ P2 ) )
= ( zero_neq_one_of_bool @ A @ P2 ) ) ) ).
% abs_bool_eq
thf(fact_3023_abs__le__zero__iff,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( abs_abs @ A @ A3 ) @ ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% abs_le_zero_iff
thf(fact_3024_abs__le__self__iff,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( abs_abs @ A @ A3 ) @ A3 )
= ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% abs_le_self_iff
thf(fact_3025_abs__of__nonneg,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( abs_abs @ A @ A3 )
= A3 ) ) ) ).
% abs_of_nonneg
thf(fact_3026_zero__less__abs__iff,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( abs_abs @ A @ A3 ) )
= ( A3
!= ( zero_zero @ A ) ) ) ) ).
% zero_less_abs_iff
thf(fact_3027_sum__abs,axiom,
! [B: $tType,A: $tType] :
( ( ordere166539214618696060dd_abs @ B )
=> ! [F2: A > B,A4: set @ A] :
( ord_less_eq @ B @ ( abs_abs @ B @ ( groups7311177749621191930dd_sum @ A @ B @ F2 @ A4 ) )
@ ( groups7311177749621191930dd_sum @ A @ B
@ ^ [I5: A] : ( abs_abs @ B @ ( F2 @ I5 ) )
@ A4 ) ) ) ).
% sum_abs
thf(fact_3028_zero__le__divide__abs__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( divide_divide @ A @ A3 @ ( abs_abs @ A @ B2 ) ) )
= ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
| ( B2
= ( zero_zero @ A ) ) ) ) ) ).
% zero_le_divide_abs_iff
thf(fact_3029_divide__le__0__abs__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( divide_divide @ A @ A3 @ ( abs_abs @ A @ B2 ) ) @ ( zero_zero @ A ) )
= ( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
| ( B2
= ( zero_zero @ A ) ) ) ) ) ).
% divide_le_0_abs_iff
thf(fact_3030_abs__of__nonpos,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( abs_abs @ A @ A3 )
= ( uminus_uminus @ A @ A3 ) ) ) ) ).
% abs_of_nonpos
thf(fact_3031_abs__sgn__eq__1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( abs_abs @ A @ ( sgn_sgn @ A @ A3 ) )
= ( one_one @ A ) ) ) ) ).
% abs_sgn_eq_1
thf(fact_3032_idom__abs__sgn__class_Oabs__sgn,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A] :
( ( sgn_sgn @ A @ ( abs_abs @ A @ A3 ) )
= ( zero_neq_one_of_bool @ A
@ ( A3
!= ( zero_zero @ A ) ) ) ) ) ).
% idom_abs_sgn_class.abs_sgn
thf(fact_3033_sgn__abs,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A] :
( ( abs_abs @ A @ ( sgn_sgn @ A @ A3 ) )
= ( zero_neq_one_of_bool @ A
@ ( A3
!= ( zero_zero @ A ) ) ) ) ) ).
% sgn_abs
thf(fact_3034_sum__abs__ge__zero,axiom,
! [B: $tType,A: $tType] :
( ( ordere166539214618696060dd_abs @ B )
=> ! [F2: A > B,A4: set @ A] :
( ord_less_eq @ B @ ( zero_zero @ B )
@ ( groups7311177749621191930dd_sum @ A @ B
@ ^ [I5: A] : ( abs_abs @ B @ ( F2 @ I5 ) )
@ A4 ) ) ) ).
% sum_abs_ge_zero
thf(fact_3035_zero__less__power__abs__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,N2: nat] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( power_power @ A @ ( abs_abs @ A @ A3 ) @ N2 ) )
= ( ( A3
!= ( zero_zero @ A ) )
| ( N2
= ( zero_zero @ nat ) ) ) ) ) ).
% zero_less_power_abs_iff
thf(fact_3036_norm__of__real__add1,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [X: real] :
( ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ ( real_Vector_of_real @ A @ X ) @ ( one_one @ A ) ) )
= ( abs_abs @ real @ ( plus_plus @ real @ X @ ( one_one @ real ) ) ) ) ) ).
% norm_of_real_add1
thf(fact_3037_norm__of__real__addn,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [X: real,B2: num] :
( ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ ( real_Vector_of_real @ A @ X ) @ ( numeral_numeral @ A @ B2 ) ) )
= ( abs_abs @ real @ ( plus_plus @ real @ X @ ( numeral_numeral @ real @ B2 ) ) ) ) ) ).
% norm_of_real_addn
thf(fact_3038_dvd__if__abs__eq,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [L: A,K: A] :
( ( ( abs_abs @ A @ L )
= ( abs_abs @ A @ K ) )
=> ( dvd_dvd @ A @ L @ K ) ) ) ).
% dvd_if_abs_eq
thf(fact_3039_abs__le__D1,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( abs_abs @ A @ A3 ) @ B2 )
=> ( ord_less_eq @ A @ A3 @ B2 ) ) ) ).
% abs_le_D1
thf(fact_3040_abs__ge__self,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] : ( ord_less_eq @ A @ A3 @ ( abs_abs @ A @ A3 ) ) ) ).
% abs_ge_self
thf(fact_3041_abs__eq__0__iff,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A] :
( ( ( abs_abs @ A @ A3 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% abs_eq_0_iff
thf(fact_3042_abs__eq__iff,axiom,
! [A: $tType] :
( ( linordered_ring @ A )
=> ! [X: A,Y: A] :
( ( ( abs_abs @ A @ X )
= ( abs_abs @ A @ Y ) )
= ( ( X = Y )
| ( X
= ( uminus_uminus @ A @ Y ) ) ) ) ) ).
% abs_eq_iff
thf(fact_3043_abs__minus__commute,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A] :
( ( abs_abs @ A @ ( minus_minus @ A @ A3 @ B2 ) )
= ( abs_abs @ A @ ( minus_minus @ A @ B2 @ A3 ) ) ) ) ).
% abs_minus_commute
thf(fact_3044_abs__one,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ( ( abs_abs @ A @ ( one_one @ A ) )
= ( one_one @ A ) ) ) ).
% abs_one
thf(fact_3045_abs__mult,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A,B2: A] :
( ( abs_abs @ A @ ( times_times @ A @ A3 @ B2 ) )
= ( times_times @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) ) ) ).
% abs_mult
thf(fact_3046_sgn__power__injE,axiom,
! [A3: real,N2: nat,X: real,B2: real] :
( ( ( times_times @ real @ ( sgn_sgn @ real @ A3 ) @ ( power_power @ real @ ( abs_abs @ real @ A3 ) @ N2 ) )
= X )
=> ( ( X
= ( times_times @ real @ ( sgn_sgn @ real @ B2 ) @ ( power_power @ real @ ( abs_abs @ real @ B2 ) @ N2 ) ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( A3 = B2 ) ) ) ) ).
% sgn_power_injE
thf(fact_3047_abs__ge__zero,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( abs_abs @ A @ A3 ) ) ) ).
% abs_ge_zero
thf(fact_3048_abs__not__less__zero,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
~ ( ord_less @ A @ ( abs_abs @ A @ A3 ) @ ( zero_zero @ A ) ) ) ).
% abs_not_less_zero
thf(fact_3049_abs__of__pos,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( abs_abs @ A @ A3 )
= A3 ) ) ) ).
% abs_of_pos
thf(fact_3050_abs__triangle__ineq,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ A @ ( abs_abs @ A @ ( plus_plus @ A @ A3 @ B2 ) ) @ ( plus_plus @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) ) ) ).
% abs_triangle_ineq
thf(fact_3051_abs__mult__less,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,C2: A,B2: A,D2: A] :
( ( ord_less @ A @ ( abs_abs @ A @ A3 ) @ C2 )
=> ( ( ord_less @ A @ ( abs_abs @ A @ B2 ) @ D2 )
=> ( ord_less @ A @ ( times_times @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) @ ( times_times @ A @ C2 @ D2 ) ) ) ) ) ).
% abs_mult_less
thf(fact_3052_abs__triangle__ineq2,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ A @ ( minus_minus @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) @ ( abs_abs @ A @ ( minus_minus @ A @ A3 @ B2 ) ) ) ) ).
% abs_triangle_ineq2
thf(fact_3053_abs__triangle__ineq3,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ A @ ( abs_abs @ A @ ( minus_minus @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) ) @ ( abs_abs @ A @ ( minus_minus @ A @ A3 @ B2 ) ) ) ) ).
% abs_triangle_ineq3
thf(fact_3054_abs__triangle__ineq2__sym,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ A @ ( minus_minus @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) @ ( abs_abs @ A @ ( minus_minus @ A @ B2 @ A3 ) ) ) ) ).
% abs_triangle_ineq2_sym
thf(fact_3055_nonzero__abs__divide,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( abs_abs @ A @ ( divide_divide @ A @ A3 @ B2 ) )
= ( divide_divide @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) ) ) ) ).
% nonzero_abs_divide
thf(fact_3056_abs__ge__minus__self,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] : ( ord_less_eq @ A @ ( uminus_uminus @ A @ A3 ) @ ( abs_abs @ A @ A3 ) ) ) ).
% abs_ge_minus_self
thf(fact_3057_abs__le__iff,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( abs_abs @ A @ A3 ) @ B2 )
= ( ( ord_less_eq @ A @ A3 @ B2 )
& ( ord_less_eq @ A @ ( uminus_uminus @ A @ A3 ) @ B2 ) ) ) ) ).
% abs_le_iff
thf(fact_3058_abs__le__D2,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( abs_abs @ A @ A3 ) @ B2 )
=> ( ord_less_eq @ A @ ( uminus_uminus @ A @ A3 ) @ B2 ) ) ) ).
% abs_le_D2
thf(fact_3059_abs__leI,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ ( uminus_uminus @ A @ A3 ) @ B2 )
=> ( ord_less_eq @ A @ ( abs_abs @ A @ A3 ) @ B2 ) ) ) ) ).
% abs_leI
thf(fact_3060_abs__less__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( abs_abs @ A @ A3 ) @ B2 )
= ( ( ord_less @ A @ A3 @ B2 )
& ( ord_less @ A @ ( uminus_uminus @ A @ A3 ) @ B2 ) ) ) ) ).
% abs_less_iff
thf(fact_3061_linordered__idom__class_Oabs__sgn,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ( ( abs_abs @ A )
= ( ^ [K2: A] : ( times_times @ A @ K2 @ ( sgn_sgn @ A @ K2 ) ) ) ) ) ).
% linordered_idom_class.abs_sgn
thf(fact_3062_abs__mult__sgn,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A] :
( ( times_times @ A @ ( abs_abs @ A @ A3 ) @ ( sgn_sgn @ A @ A3 ) )
= A3 ) ) ).
% abs_mult_sgn
thf(fact_3063_sgn__mult__abs,axiom,
! [A: $tType] :
( ( idom_abs_sgn @ A )
=> ! [A3: A] :
( ( times_times @ A @ ( sgn_sgn @ A @ A3 ) @ ( abs_abs @ A @ A3 ) )
= A3 ) ) ).
% sgn_mult_abs
thf(fact_3064_mult__sgn__abs,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A] :
( ( times_times @ A @ ( sgn_sgn @ A @ X ) @ ( abs_abs @ A @ X ) )
= X ) ) ).
% mult_sgn_abs
thf(fact_3065_same__sgn__abs__add,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [B2: A,A3: A] :
( ( ( sgn_sgn @ A @ B2 )
= ( sgn_sgn @ A @ A3 ) )
=> ( ( abs_abs @ A @ ( plus_plus @ A @ A3 @ B2 ) )
= ( plus_plus @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) ) ) ) ).
% same_sgn_abs_add
thf(fact_3066_dense__eq0__I,axiom,
! [A: $tType] :
( ( ( ordere166539214618696060dd_abs @ A )
& ( dense_linorder @ A ) )
=> ! [X: A] :
( ! [E: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ E )
=> ( ord_less_eq @ A @ ( abs_abs @ A @ X ) @ E ) )
=> ( X
= ( zero_zero @ A ) ) ) ) ).
% dense_eq0_I
thf(fact_3067_abs__eq__mult,axiom,
! [A: $tType] :
( ( ordered_ring_abs @ A )
=> ! [A3: A,B2: A] :
( ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
| ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) )
& ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
| ( ord_less_eq @ A @ B2 @ ( zero_zero @ A ) ) ) )
=> ( ( abs_abs @ A @ ( times_times @ A @ A3 @ B2 ) )
= ( times_times @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) ) ) ) ).
% abs_eq_mult
thf(fact_3068_abs__mult__pos,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( times_times @ A @ ( abs_abs @ A @ Y ) @ X )
= ( abs_abs @ A @ ( times_times @ A @ Y @ X ) ) ) ) ) ).
% abs_mult_pos
thf(fact_3069_abs__minus__le__zero,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] : ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( abs_abs @ A @ A3 ) ) @ ( zero_zero @ A ) ) ) ).
% abs_minus_le_zero
thf(fact_3070_eq__abs__iff_H,axiom,
! [A: $tType] :
( ( linordered_ring @ A )
=> ! [A3: A,B2: A] :
( ( A3
= ( abs_abs @ A @ B2 ) )
= ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
& ( ( B2 = A3 )
| ( B2
= ( uminus_uminus @ A @ A3 ) ) ) ) ) ) ).
% eq_abs_iff'
thf(fact_3071_abs__eq__iff_H,axiom,
! [A: $tType] :
( ( linordered_ring @ A )
=> ! [A3: A,B2: A] :
( ( ( abs_abs @ A @ A3 )
= B2 )
= ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
& ( ( A3 = B2 )
| ( A3
= ( uminus_uminus @ A @ B2 ) ) ) ) ) ) ).
% abs_eq_iff'
thf(fact_3072_abs__div__pos,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [Y: A,X: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ Y )
=> ( ( divide_divide @ A @ ( abs_abs @ A @ X ) @ Y )
= ( abs_abs @ A @ ( divide_divide @ A @ X @ Y ) ) ) ) ) ).
% abs_div_pos
thf(fact_3073_zero__le__power__abs,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,N2: nat] : ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( power_power @ A @ ( abs_abs @ A @ A3 ) @ N2 ) ) ) ).
% zero_le_power_abs
thf(fact_3074_abs__of__neg,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( abs_abs @ A @ A3 )
= ( uminus_uminus @ A @ A3 ) ) ) ) ).
% abs_of_neg
thf(fact_3075_abs__if,axiom,
! [A: $tType] :
( ( abs_if @ A )
=> ( ( abs_abs @ A )
= ( ^ [A5: A] : ( if @ A @ ( ord_less @ A @ A5 @ ( zero_zero @ A ) ) @ ( uminus_uminus @ A @ A5 ) @ A5 ) ) ) ) ).
% abs_if
thf(fact_3076_abs__if__raw,axiom,
! [A: $tType] :
( ( abs_if @ A )
=> ( ( abs_abs @ A )
= ( ^ [A5: A] : ( if @ A @ ( ord_less @ A @ A5 @ ( zero_zero @ A ) ) @ ( uminus_uminus @ A @ A5 ) @ A5 ) ) ) ) ).
% abs_if_raw
thf(fact_3077_abs__triangle__ineq4,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ A @ ( abs_abs @ A @ ( minus_minus @ A @ A3 @ B2 ) ) @ ( plus_plus @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) ) ) ) ).
% abs_triangle_ineq4
thf(fact_3078_abs__diff__triangle__ineq,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] : ( ord_less_eq @ A @ ( abs_abs @ A @ ( minus_minus @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( plus_plus @ A @ C2 @ D2 ) ) ) @ ( plus_plus @ A @ ( abs_abs @ A @ ( minus_minus @ A @ A3 @ C2 ) ) @ ( abs_abs @ A @ ( minus_minus @ A @ B2 @ D2 ) ) ) ) ) ).
% abs_diff_triangle_ineq
thf(fact_3079_abs__diff__le__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,A3: A,R2: A] :
( ( ord_less_eq @ A @ ( abs_abs @ A @ ( minus_minus @ A @ X @ A3 ) ) @ R2 )
= ( ( ord_less_eq @ A @ ( minus_minus @ A @ A3 @ R2 ) @ X )
& ( ord_less_eq @ A @ X @ ( plus_plus @ A @ A3 @ R2 ) ) ) ) ) ).
% abs_diff_le_iff
thf(fact_3080_abs__diff__less__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,A3: A,R2: A] :
( ( ord_less @ A @ ( abs_abs @ A @ ( minus_minus @ A @ X @ A3 ) ) @ R2 )
= ( ( ord_less @ A @ ( minus_minus @ A @ A3 @ R2 ) @ X )
& ( ord_less @ A @ X @ ( plus_plus @ A @ A3 @ R2 ) ) ) ) ) ).
% abs_diff_less_iff
thf(fact_3081_abs__sgn__eq,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( ( A3
= ( zero_zero @ A ) )
=> ( ( abs_abs @ A @ ( sgn_sgn @ A @ A3 ) )
= ( zero_zero @ A ) ) )
& ( ( A3
!= ( zero_zero @ A ) )
=> ( ( abs_abs @ A @ ( sgn_sgn @ A @ A3 ) )
= ( one_one @ A ) ) ) ) ) ).
% abs_sgn_eq
thf(fact_3082_summable__rabs__comparison__test,axiom,
! [F2: nat > real,G: nat > real] :
( ? [N8: nat] :
! [N3: nat] :
( ( ord_less_eq @ nat @ N8 @ N3 )
=> ( ord_less_eq @ real @ ( abs_abs @ real @ ( F2 @ N3 ) ) @ ( G @ N3 ) ) )
=> ( ( summable @ real @ G )
=> ( summable @ real
@ ^ [N: nat] : ( abs_abs @ real @ ( F2 @ N ) ) ) ) ) ).
% summable_rabs_comparison_test
thf(fact_3083_abs__add__one__gt__zero,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A] : ( ord_less @ A @ ( zero_zero @ A ) @ ( plus_plus @ A @ ( one_one @ A ) @ ( abs_abs @ A @ X ) ) ) ) ).
% abs_add_one_gt_zero
thf(fact_3084_of__int__leD,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: int,X: A] :
( ( ord_less_eq @ A @ ( abs_abs @ A @ ( ring_1_of_int @ A @ N2 ) ) @ X )
=> ( ( N2
= ( zero_zero @ int ) )
| ( ord_less_eq @ A @ ( one_one @ A ) @ X ) ) ) ) ).
% of_int_leD
thf(fact_3085_of__int__lessD,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: int,X: A] :
( ( ord_less @ A @ ( abs_abs @ A @ ( ring_1_of_int @ A @ N2 ) ) @ X )
=> ( ( N2
= ( zero_zero @ int ) )
| ( ord_less @ A @ ( one_one @ A ) @ X ) ) ) ) ).
% of_int_lessD
thf(fact_3086_round__diff__minimal,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [Z: A,M: int] : ( ord_less_eq @ A @ ( abs_abs @ A @ ( minus_minus @ A @ Z @ ( ring_1_of_int @ A @ ( archimedean_round @ A @ Z ) ) ) ) @ ( abs_abs @ A @ ( minus_minus @ A @ Z @ ( ring_1_of_int @ A @ M ) ) ) ) ) ).
% round_diff_minimal
thf(fact_3087_diffs__def,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( ( diffs @ A )
= ( ^ [C3: nat > A,N: nat] : ( times_times @ A @ ( semiring_1_of_nat @ A @ ( suc @ N ) ) @ ( C3 @ ( suc @ N ) ) ) ) ) ) ).
% diffs_def
thf(fact_3088_fun__cong__unused__0,axiom,
! [A: $tType,B: $tType,C: $tType] :
( ( zero @ B )
=> ! [F2: ( A > B ) > C,G: C] :
( ( F2
= ( ^ [X2: A > B] : G ) )
=> ( ( F2
@ ^ [X2: A] : ( zero_zero @ B ) )
= G ) ) ) ).
% fun_cong_unused_0
thf(fact_3089_abs__le__square__iff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ ( abs_abs @ A @ X ) @ ( abs_abs @ A @ Y ) )
= ( ord_less_eq @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ).
% abs_le_square_iff
thf(fact_3090_power2__le__iff__abs__le,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ Y )
=> ( ( ord_less_eq @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ Y @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
= ( ord_less_eq @ A @ ( abs_abs @ A @ X ) @ Y ) ) ) ) ).
% power2_le_iff_abs_le
thf(fact_3091_abs__sqrt__wlog,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [P2: A > A > $o,X: A] :
( ! [X5: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X5 )
=> ( P2 @ X5 @ ( power_power @ A @ X5 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
=> ( P2 @ ( abs_abs @ A @ X ) @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ).
% abs_sqrt_wlog
thf(fact_3092_abs__square__le__1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A] :
( ( ord_less_eq @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ A ) )
= ( ord_less_eq @ A @ ( abs_abs @ A @ X ) @ ( one_one @ A ) ) ) ) ).
% abs_square_le_1
thf(fact_3093_abs__square__less__1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A] :
( ( ord_less @ A @ ( power_power @ A @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ A ) )
= ( ord_less @ A @ ( abs_abs @ A @ X ) @ ( one_one @ A ) ) ) ) ).
% abs_square_less_1
thf(fact_3094_power__mono__even,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: nat,A3: A,B2: A] :
( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( ord_less_eq @ A @ ( abs_abs @ A @ A3 ) @ ( abs_abs @ A @ B2 ) )
=> ( ord_less_eq @ A @ ( power_power @ A @ A3 @ N2 ) @ ( power_power @ A @ B2 @ N2 ) ) ) ) ) ).
% power_mono_even
thf(fact_3095_convex__sum__bound__le,axiom,
! [A: $tType,B: $tType] :
( ( linordered_idom @ B )
=> ! [I6: set @ A,X: A > B,A3: A > B,B2: B,Delta: B] :
( ! [I3: A] :
( ( member2 @ A @ I3 @ I6 )
=> ( ord_less_eq @ B @ ( zero_zero @ B ) @ ( X @ I3 ) ) )
=> ( ( ( groups7311177749621191930dd_sum @ A @ B @ X @ I6 )
= ( one_one @ B ) )
=> ( ! [I3: A] :
( ( member2 @ A @ I3 @ I6 )
=> ( ord_less_eq @ B @ ( abs_abs @ B @ ( minus_minus @ B @ ( A3 @ I3 ) @ B2 ) ) @ Delta ) )
=> ( ord_less_eq @ B
@ ( abs_abs @ B
@ ( minus_minus @ B
@ ( groups7311177749621191930dd_sum @ A @ B
@ ^ [I5: A] : ( times_times @ B @ ( A3 @ I5 ) @ ( X @ I5 ) )
@ I6 )
@ B2 ) )
@ Delta ) ) ) ) ) ).
% convex_sum_bound_le
thf(fact_3096_dbl__dec__def,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ( ( neg_numeral_dbl_dec @ A )
= ( ^ [X2: A] : ( minus_minus @ A @ ( plus_plus @ A @ X2 @ X2 ) @ ( one_one @ A ) ) ) ) ) ).
% dbl_dec_def
thf(fact_3097_of__int__round__abs__le,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] : ( ord_less_eq @ A @ ( abs_abs @ A @ ( minus_minus @ A @ ( ring_1_of_int @ A @ ( archimedean_round @ A @ X ) ) @ X ) ) @ ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ).
% of_int_round_abs_le
thf(fact_3098_round__unique_H,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,N2: int] :
( ( ord_less @ A @ ( abs_abs @ A @ ( minus_minus @ A @ X @ ( ring_1_of_int @ A @ N2 ) ) ) @ ( divide_divide @ A @ ( one_one @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) )
=> ( ( archimedean_round @ A @ X )
= N2 ) ) ) ).
% round_unique'
thf(fact_3099_monoseq__arctan__series,axiom,
! [X: real] :
( ( ord_less_eq @ real @ ( abs_abs @ real @ X ) @ ( one_one @ real ) )
=> ( topological_monoseq @ real
@ ^ [N: nat] : ( times_times @ real @ ( divide_divide @ real @ ( one_one @ real ) @ ( semiring_1_of_nat @ real @ ( plus_plus @ nat @ ( times_times @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) ) @ ( power_power @ real @ X @ ( plus_plus @ nat @ ( times_times @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) ) ) ) ).
% monoseq_arctan_series
thf(fact_3100_arctan__series,axiom,
! [X: real] :
( ( ord_less_eq @ real @ ( abs_abs @ real @ X ) @ ( one_one @ real ) )
=> ( ( arctan @ X )
= ( suminf @ real
@ ^ [K2: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ K2 ) @ ( times_times @ real @ ( divide_divide @ real @ ( one_one @ real ) @ ( semiring_1_of_nat @ real @ ( plus_plus @ nat @ ( times_times @ nat @ K2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) ) @ ( power_power @ real @ X @ ( plus_plus @ nat @ ( times_times @ nat @ K2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) ) ) ) ) ) ).
% arctan_series
thf(fact_3101_Maclaurin__exp__lt,axiom,
! [X: real,N2: nat] :
( ( X
!= ( zero_zero @ real ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ? [T7: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ ( abs_abs @ real @ T7 ) )
& ( ord_less @ real @ ( abs_abs @ real @ T7 ) @ ( abs_abs @ real @ X ) )
& ( ( exp @ real @ X )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( divide_divide @ real @ ( power_power @ real @ X @ M2 ) @ ( semiring_char_0_fact @ real @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( exp @ real @ T7 ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ X @ N2 ) ) ) ) ) ) ) ).
% Maclaurin_exp_lt
thf(fact_3102_exp__ge__one__minus__x__over__n__power__n,axiom,
! [X: real,N2: nat] :
( ( ord_less_eq @ real @ X @ ( semiring_1_of_nat @ real @ N2 ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less_eq @ real @ ( power_power @ real @ ( minus_minus @ real @ ( one_one @ real ) @ ( divide_divide @ real @ X @ ( semiring_1_of_nat @ real @ N2 ) ) ) @ N2 ) @ ( exp @ real @ ( uminus_uminus @ real @ X ) ) ) ) ) ).
% exp_ge_one_minus_x_over_n_power_n
thf(fact_3103_exp__ge__one__plus__x__over__n__power__n,axiom,
! [N2: nat,X: real] :
( ( ord_less_eq @ real @ ( uminus_uminus @ real @ ( semiring_1_of_nat @ real @ N2 ) ) @ X )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ord_less_eq @ real @ ( power_power @ real @ ( plus_plus @ real @ ( one_one @ real ) @ ( divide_divide @ real @ X @ ( semiring_1_of_nat @ real @ N2 ) ) ) @ N2 ) @ ( exp @ real @ X ) ) ) ) ).
% exp_ge_one_plus_x_over_n_power_n
thf(fact_3104_exp__zero,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ( ( exp @ A @ ( zero_zero @ A ) )
= ( one_one @ A ) ) ) ).
% exp_zero
thf(fact_3105_zdvd1__eq,axiom,
! [X: int] :
( ( dvd_dvd @ int @ X @ ( one_one @ int ) )
= ( ( abs_abs @ int @ X )
= ( one_one @ int ) ) ) ).
% zdvd1_eq
thf(fact_3106_zabs__less__one__iff,axiom,
! [Z: int] :
( ( ord_less @ int @ ( abs_abs @ int @ Z ) @ ( one_one @ int ) )
= ( Z
= ( zero_zero @ int ) ) ) ).
% zabs_less_one_iff
thf(fact_3107_exp__not__eq__zero,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ! [X: A] :
( ( exp @ A @ X )
!= ( zero_zero @ A ) ) ) ).
% exp_not_eq_zero
thf(fact_3108_zdvd__antisym__abs,axiom,
! [A3: int,B2: int] :
( ( dvd_dvd @ int @ A3 @ B2 )
=> ( ( dvd_dvd @ int @ B2 @ A3 )
=> ( ( abs_abs @ int @ A3 )
= ( abs_abs @ int @ B2 ) ) ) ) ).
% zdvd_antisym_abs
thf(fact_3109_exp__add__commuting,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ! [X: A,Y: A] :
( ( ( times_times @ A @ X @ Y )
= ( times_times @ A @ Y @ X ) )
=> ( ( exp @ A @ ( plus_plus @ A @ X @ Y ) )
= ( times_times @ A @ ( exp @ A @ X ) @ ( exp @ A @ Y ) ) ) ) ) ).
% exp_add_commuting
thf(fact_3110_mult__exp__exp,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( ( times_times @ A @ ( exp @ A @ X ) @ ( exp @ A @ Y ) )
= ( exp @ A @ ( plus_plus @ A @ X @ Y ) ) ) ) ).
% mult_exp_exp
thf(fact_3111_abs__zmult__eq__1,axiom,
! [M: int,N2: int] :
( ( ( abs_abs @ int @ ( times_times @ int @ M @ N2 ) )
= ( one_one @ int ) )
=> ( ( abs_abs @ int @ M )
= ( one_one @ int ) ) ) ).
% abs_zmult_eq_1
thf(fact_3112_zabs__def,axiom,
( ( abs_abs @ int )
= ( ^ [I5: int] : ( if @ int @ ( ord_less @ int @ I5 @ ( zero_zero @ int ) ) @ ( uminus_uminus @ int @ I5 ) @ I5 ) ) ) ).
% zabs_def
thf(fact_3113_dvd__imp__le__int,axiom,
! [I: int,D2: int] :
( ( I
!= ( zero_zero @ int ) )
=> ( ( dvd_dvd @ int @ D2 @ I )
=> ( ord_less_eq @ int @ ( abs_abs @ int @ D2 ) @ ( abs_abs @ int @ I ) ) ) ) ).
% dvd_imp_le_int
thf(fact_3114_zdvd__mult__cancel1,axiom,
! [M: int,N2: int] :
( ( M
!= ( zero_zero @ int ) )
=> ( ( dvd_dvd @ int @ ( times_times @ int @ M @ N2 ) @ M )
= ( ( abs_abs @ int @ N2 )
= ( one_one @ int ) ) ) ) ).
% zdvd_mult_cancel1
thf(fact_3115_powr__def,axiom,
! [A: $tType] :
( ( ln @ A )
=> ( ( powr @ A )
= ( ^ [X2: A,A5: A] :
( if @ A
@ ( X2
= ( zero_zero @ A ) )
@ ( zero_zero @ A )
@ ( exp @ A @ ( times_times @ A @ A5 @ ( ln_ln @ A @ X2 ) ) ) ) ) ) ) ).
% powr_def
thf(fact_3116_exp__divide__power__eq,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [N2: nat,X: A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( power_power @ A @ ( exp @ A @ ( divide_divide @ A @ X @ ( semiring_1_of_nat @ A @ N2 ) ) ) @ N2 )
= ( exp @ A @ X ) ) ) ) ).
% exp_divide_power_eq
thf(fact_3117_nat__intermed__int__val,axiom,
! [M: nat,N2: nat,F2: nat > int,K: int] :
( ! [I3: nat] :
( ( ( ord_less_eq @ nat @ M @ I3 )
& ( ord_less @ nat @ I3 @ N2 ) )
=> ( ord_less_eq @ int @ ( abs_abs @ int @ ( minus_minus @ int @ ( F2 @ ( suc @ I3 ) ) @ ( F2 @ I3 ) ) ) @ ( one_one @ int ) ) )
=> ( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( ord_less_eq @ int @ ( F2 @ M ) @ K )
=> ( ( ord_less_eq @ int @ K @ ( F2 @ N2 ) )
=> ? [I3: nat] :
( ( ord_less_eq @ nat @ M @ I3 )
& ( ord_less_eq @ nat @ I3 @ N2 )
& ( ( F2 @ I3 )
= K ) ) ) ) ) ) ).
% nat_intermed_int_val
thf(fact_3118_nat__ivt__aux,axiom,
! [N2: nat,F2: nat > int,K: int] :
( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ N2 )
=> ( ord_less_eq @ int @ ( abs_abs @ int @ ( minus_minus @ int @ ( F2 @ ( suc @ I3 ) ) @ ( F2 @ I3 ) ) ) @ ( one_one @ int ) ) )
=> ( ( ord_less_eq @ int @ ( F2 @ ( zero_zero @ nat ) ) @ K )
=> ( ( ord_less_eq @ int @ K @ ( F2 @ N2 ) )
=> ? [I3: nat] :
( ( ord_less_eq @ nat @ I3 @ N2 )
& ( ( F2 @ I3 )
= K ) ) ) ) ) ).
% nat_ivt_aux
thf(fact_3119_nat0__intermed__int__val,axiom,
! [N2: nat,F2: nat > int,K: int] :
( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ N2 )
=> ( ord_less_eq @ int @ ( abs_abs @ int @ ( minus_minus @ int @ ( F2 @ ( plus_plus @ nat @ I3 @ ( one_one @ nat ) ) ) @ ( F2 @ I3 ) ) ) @ ( one_one @ int ) ) )
=> ( ( ord_less_eq @ int @ ( F2 @ ( zero_zero @ nat ) ) @ K )
=> ( ( ord_less_eq @ int @ K @ ( F2 @ N2 ) )
=> ? [I3: nat] :
( ( ord_less_eq @ nat @ I3 @ N2 )
& ( ( F2 @ I3 )
= K ) ) ) ) ) ).
% nat0_intermed_int_val
thf(fact_3120_monoI1,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X7: nat > A] :
( ! [M3: nat,N3: nat] :
( ( ord_less_eq @ nat @ M3 @ N3 )
=> ( ord_less_eq @ A @ ( X7 @ M3 ) @ ( X7 @ N3 ) ) )
=> ( topological_monoseq @ A @ X7 ) ) ) ).
% monoI1
thf(fact_3121_monoI2,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X7: nat > A] :
( ! [M3: nat,N3: nat] :
( ( ord_less_eq @ nat @ M3 @ N3 )
=> ( ord_less_eq @ A @ ( X7 @ N3 ) @ ( X7 @ M3 ) ) )
=> ( topological_monoseq @ A @ X7 ) ) ) ).
% monoI2
thf(fact_3122_monoseq__def,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( topological_monoseq @ A )
= ( ^ [X8: nat > A] :
( ! [M2: nat,N: nat] :
( ( ord_less_eq @ nat @ M2 @ N )
=> ( ord_less_eq @ A @ ( X8 @ M2 ) @ ( X8 @ N ) ) )
| ! [M2: nat,N: nat] :
( ( ord_less_eq @ nat @ M2 @ N )
=> ( ord_less_eq @ A @ ( X8 @ N ) @ ( X8 @ M2 ) ) ) ) ) ) ) ).
% monoseq_def
thf(fact_3123_monoseq__Suc,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( topological_monoseq @ A )
= ( ^ [X8: nat > A] :
( ! [N: nat] : ( ord_less_eq @ A @ ( X8 @ N ) @ ( X8 @ ( suc @ N ) ) )
| ! [N: nat] : ( ord_less_eq @ A @ ( X8 @ ( suc @ N ) ) @ ( X8 @ N ) ) ) ) ) ) ).
% monoseq_Suc
thf(fact_3124_mono__SucI2,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X7: nat > A] :
( ! [N3: nat] : ( ord_less_eq @ A @ ( X7 @ ( suc @ N3 ) ) @ ( X7 @ N3 ) )
=> ( topological_monoseq @ A @ X7 ) ) ) ).
% mono_SucI2
thf(fact_3125_mono__SucI1,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X7: nat > A] :
( ! [N3: nat] : ( ord_less_eq @ A @ ( X7 @ N3 ) @ ( X7 @ ( suc @ N3 ) ) )
=> ( topological_monoseq @ A @ X7 ) ) ) ).
% mono_SucI1
thf(fact_3126_exp__first__two__terms,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ( ( exp @ A )
= ( ^ [X2: A] :
( plus_plus @ A @ ( plus_plus @ A @ ( one_one @ A ) @ X2 )
@ ( suminf @ A
@ ^ [N: nat] : ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ ( semiring_char_0_fact @ real @ ( plus_plus @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( power_power @ A @ X2 @ ( plus_plus @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ).
% exp_first_two_terms
thf(fact_3127_divide__int__def,axiom,
( ( divide_divide @ int )
= ( ^ [K2: int,L2: int] :
( if @ int
@ ( L2
= ( zero_zero @ int ) )
@ ( zero_zero @ int )
@ ( if @ int
@ ( ( sgn_sgn @ int @ K2 )
= ( sgn_sgn @ int @ L2 ) )
@ ( semiring_1_of_nat @ int @ ( divide_divide @ nat @ ( nat2 @ ( abs_abs @ int @ K2 ) ) @ ( nat2 @ ( abs_abs @ int @ L2 ) ) ) )
@ ( uminus_uminus @ int
@ ( semiring_1_of_nat @ int
@ ( plus_plus @ nat @ ( divide_divide @ nat @ ( nat2 @ ( abs_abs @ int @ K2 ) ) @ ( nat2 @ ( abs_abs @ int @ L2 ) ) )
@ ( zero_neq_one_of_bool @ nat
@ ~ ( dvd_dvd @ int @ L2 @ K2 ) ) ) ) ) ) ) ) ) ).
% divide_int_def
thf(fact_3128_exp__first__terms,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ! [K: nat] :
( ( exp @ A )
= ( ^ [X2: A] :
( plus_plus @ A
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [N: nat] : ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ ( semiring_char_0_fact @ real @ N ) ) @ ( power_power @ A @ X2 @ N ) )
@ ( set_ord_lessThan @ nat @ K ) )
@ ( suminf @ A
@ ^ [N: nat] : ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ ( semiring_char_0_fact @ real @ ( plus_plus @ nat @ N @ K ) ) ) @ ( power_power @ A @ X2 @ ( plus_plus @ nat @ N @ K ) ) ) ) ) ) ) ) ).
% exp_first_terms
thf(fact_3129_cosh__zero__iff,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ( cosh @ A @ X )
= ( zero_zero @ A ) )
= ( ( power_power @ A @ ( exp @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ) ).
% cosh_zero_iff
thf(fact_3130_bit__horner__sum__bit__iff,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [Bs: list @ $o,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( groups4207007520872428315er_sum @ $o @ A @ ( zero_neq_one_of_bool @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ Bs ) @ N2 )
= ( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ $o ) @ Bs ) )
& ( nth @ $o @ Bs @ N2 ) ) ) ) ).
% bit_horner_sum_bit_iff
thf(fact_3131_inverse__inverse__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( inverse_inverse @ A @ ( inverse_inverse @ A @ A3 ) )
= A3 ) ) ).
% inverse_inverse_eq
thf(fact_3132_inverse__eq__iff__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A] :
( ( ( inverse_inverse @ A @ A3 )
= ( inverse_inverse @ A @ B2 ) )
= ( A3 = B2 ) ) ) ).
% inverse_eq_iff_eq
thf(fact_3133_inverse__zero,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ( ( inverse_inverse @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% inverse_zero
thf(fact_3134_inverse__nonzero__iff__nonzero,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( ( inverse_inverse @ A @ A3 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% inverse_nonzero_iff_nonzero
thf(fact_3135_inverse__mult__distrib,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A] :
( ( inverse_inverse @ A @ ( times_times @ A @ A3 @ B2 ) )
= ( times_times @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) ) ) ) ).
% inverse_mult_distrib
thf(fact_3136_inverse__1,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ( ( inverse_inverse @ A @ ( one_one @ A ) )
= ( one_one @ A ) ) ) ).
% inverse_1
thf(fact_3137_inverse__eq__1__iff,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [X: A] :
( ( ( inverse_inverse @ A @ X )
= ( one_one @ A ) )
= ( X
= ( one_one @ A ) ) ) ) ).
% inverse_eq_1_iff
thf(fact_3138_inverse__divide,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A] :
( ( inverse_inverse @ A @ ( divide_divide @ A @ A3 @ B2 ) )
= ( divide_divide @ A @ B2 @ A3 ) ) ) ).
% inverse_divide
thf(fact_3139_inverse__minus__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( inverse_inverse @ A @ ( uminus_uminus @ A @ A3 ) )
= ( uminus_uminus @ A @ ( inverse_inverse @ A @ A3 ) ) ) ) ).
% inverse_minus_eq
thf(fact_3140_abs__inverse,axiom,
! [A: $tType] :
( ( field_abs_sgn @ A )
=> ! [A3: A] :
( ( abs_abs @ A @ ( inverse_inverse @ A @ A3 ) )
= ( inverse_inverse @ A @ ( abs_abs @ A @ A3 ) ) ) ) ).
% abs_inverse
thf(fact_3141_inverse__sgn,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( inverse_inverse @ A @ ( sgn_sgn @ A @ A3 ) )
= ( sgn_sgn @ A @ A3 ) ) ) ).
% inverse_sgn
thf(fact_3142_sgn__inverse,axiom,
! [A: $tType] :
( ( field_abs_sgn @ A )
=> ! [A3: A] :
( ( sgn_sgn @ A @ ( inverse_inverse @ A @ A3 ) )
= ( inverse_inverse @ A @ ( sgn_sgn @ A @ A3 ) ) ) ) ).
% sgn_inverse
thf(fact_3143_nat__int,axiom,
! [N2: nat] :
( ( nat2 @ ( semiring_1_of_nat @ int @ N2 ) )
= N2 ) ).
% nat_int
thf(fact_3144_inverse__nonnegative__iff__nonnegative,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( inverse_inverse @ A @ A3 ) )
= ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% inverse_nonnegative_iff_nonnegative
thf(fact_3145_inverse__nonpositive__iff__nonpositive,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( inverse_inverse @ A @ A3 ) @ ( zero_zero @ A ) )
= ( ord_less_eq @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% inverse_nonpositive_iff_nonpositive
thf(fact_3146_inverse__less__iff__less,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
= ( ord_less @ A @ B2 @ A3 ) ) ) ) ) ).
% inverse_less_iff_less
thf(fact_3147_inverse__less__iff__less__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
= ( ord_less @ A @ B2 @ A3 ) ) ) ) ) ).
% inverse_less_iff_less_neg
thf(fact_3148_inverse__negative__iff__negative,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( inverse_inverse @ A @ A3 ) @ ( zero_zero @ A ) )
= ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ).
% inverse_negative_iff_negative
thf(fact_3149_inverse__positive__iff__positive,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( inverse_inverse @ A @ A3 ) )
= ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ).
% inverse_positive_iff_positive
thf(fact_3150_cosh__0,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ( ( cosh @ A @ ( zero_zero @ A ) )
= ( one_one @ A ) ) ) ).
% cosh_0
thf(fact_3151_nat__numeral,axiom,
! [K: num] :
( ( nat2 @ ( numeral_numeral @ int @ K ) )
= ( numeral_numeral @ nat @ K ) ) ).
% nat_numeral
thf(fact_3152_nat__of__bool,axiom,
! [P2: $o] :
( ( nat2 @ ( zero_neq_one_of_bool @ int @ P2 ) )
= ( zero_neq_one_of_bool @ nat @ P2 ) ) ).
% nat_of_bool
thf(fact_3153_inverse__le__iff__le,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less_eq @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
= ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ) ).
% inverse_le_iff_le
thf(fact_3154_inverse__le__iff__le__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ( ord_less_eq @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
= ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ) ).
% inverse_le_iff_le_neg
thf(fact_3155_right__inverse,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( times_times @ A @ A3 @ ( inverse_inverse @ A @ A3 ) )
= ( one_one @ A ) ) ) ) ).
% right_inverse
thf(fact_3156_left__inverse,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( times_times @ A @ ( inverse_inverse @ A @ A3 ) @ A3 )
= ( one_one @ A ) ) ) ) ).
% left_inverse
thf(fact_3157_nat__1,axiom,
( ( nat2 @ ( one_one @ int ) )
= ( suc @ ( zero_zero @ nat ) ) ) ).
% nat_1
thf(fact_3158_nat__le__0,axiom,
! [Z: int] :
( ( ord_less_eq @ int @ Z @ ( zero_zero @ int ) )
=> ( ( nat2 @ Z )
= ( zero_zero @ nat ) ) ) ).
% nat_le_0
thf(fact_3159_nat__0__iff,axiom,
! [I: int] :
( ( ( nat2 @ I )
= ( zero_zero @ nat ) )
= ( ord_less_eq @ int @ I @ ( zero_zero @ int ) ) ) ).
% nat_0_iff
thf(fact_3160_zless__nat__conj,axiom,
! [W2: int,Z: int] :
( ( ord_less @ nat @ ( nat2 @ W2 ) @ ( nat2 @ Z ) )
= ( ( ord_less @ int @ ( zero_zero @ int ) @ Z )
& ( ord_less @ int @ W2 @ Z ) ) ) ).
% zless_nat_conj
thf(fact_3161_nat__neg__numeral,axiom,
! [K: num] :
( ( nat2 @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ K ) ) )
= ( zero_zero @ nat ) ) ).
% nat_neg_numeral
thf(fact_3162_nat__zminus__int,axiom,
! [N2: nat] :
( ( nat2 @ ( uminus_uminus @ int @ ( semiring_1_of_nat @ int @ N2 ) ) )
= ( zero_zero @ nat ) ) ).
% nat_zminus_int
thf(fact_3163_int__nat__eq,axiom,
! [Z: int] :
( ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( ( semiring_1_of_nat @ int @ ( nat2 @ Z ) )
= Z ) )
& ( ~ ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( ( semiring_1_of_nat @ int @ ( nat2 @ Z ) )
= ( zero_zero @ int ) ) ) ) ).
% int_nat_eq
thf(fact_3164_zero__less__nat__eq,axiom,
! [Z: int] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( nat2 @ Z ) )
= ( ord_less @ int @ ( zero_zero @ int ) @ Z ) ) ).
% zero_less_nat_eq
thf(fact_3165_of__nat__nat,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [Z: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( ( semiring_1_of_nat @ A @ ( nat2 @ Z ) )
= ( ring_1_of_int @ A @ Z ) ) ) ) ).
% of_nat_nat
thf(fact_3166_diff__nat__numeral,axiom,
! [V2: num,V4: num] :
( ( minus_minus @ nat @ ( numeral_numeral @ nat @ V2 ) @ ( numeral_numeral @ nat @ V4 ) )
= ( nat2 @ ( minus_minus @ int @ ( numeral_numeral @ int @ V2 ) @ ( numeral_numeral @ int @ V4 ) ) ) ) ).
% diff_nat_numeral
thf(fact_3167_numeral__power__eq__nat__cancel__iff,axiom,
! [X: num,N2: nat,Y: int] :
( ( ( power_power @ nat @ ( numeral_numeral @ nat @ X ) @ N2 )
= ( nat2 @ Y ) )
= ( ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 )
= Y ) ) ).
% numeral_power_eq_nat_cancel_iff
thf(fact_3168_nat__eq__numeral__power__cancel__iff,axiom,
! [Y: int,X: num,N2: nat] :
( ( ( nat2 @ Y )
= ( power_power @ nat @ ( numeral_numeral @ nat @ X ) @ N2 ) )
= ( Y
= ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 ) ) ) ).
% nat_eq_numeral_power_cancel_iff
thf(fact_3169_dvd__nat__abs__iff,axiom,
! [N2: nat,K: int] :
( ( dvd_dvd @ nat @ N2 @ ( nat2 @ ( abs_abs @ int @ K ) ) )
= ( dvd_dvd @ int @ ( semiring_1_of_nat @ int @ N2 ) @ K ) ) ).
% dvd_nat_abs_iff
thf(fact_3170_nat__abs__dvd__iff,axiom,
! [K: int,N2: nat] :
( ( dvd_dvd @ nat @ ( nat2 @ ( abs_abs @ int @ K ) ) @ N2 )
= ( dvd_dvd @ int @ K @ ( semiring_1_of_nat @ int @ N2 ) ) ) ).
% nat_abs_dvd_iff
thf(fact_3171_nat__ceiling__le__eq,axiom,
! [X: real,A3: nat] :
( ( ord_less_eq @ nat @ ( nat2 @ ( archimedean_ceiling @ real @ X ) ) @ A3 )
= ( ord_less_eq @ real @ X @ ( semiring_1_of_nat @ real @ A3 ) ) ) ).
% nat_ceiling_le_eq
thf(fact_3172_one__less__nat__eq,axiom,
! [Z: int] :
( ( ord_less @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( nat2 @ Z ) )
= ( ord_less @ int @ ( one_one @ int ) @ Z ) ) ).
% one_less_nat_eq
thf(fact_3173_nat__numeral__diff__1,axiom,
! [V2: num] :
( ( minus_minus @ nat @ ( numeral_numeral @ nat @ V2 ) @ ( one_one @ nat ) )
= ( nat2 @ ( minus_minus @ int @ ( numeral_numeral @ int @ V2 ) @ ( one_one @ int ) ) ) ) ).
% nat_numeral_diff_1
thf(fact_3174_nat__less__numeral__power__cancel__iff,axiom,
! [A3: int,X: num,N2: nat] :
( ( ord_less @ nat @ ( nat2 @ A3 ) @ ( power_power @ nat @ ( numeral_numeral @ nat @ X ) @ N2 ) )
= ( ord_less @ int @ A3 @ ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 ) ) ) ).
% nat_less_numeral_power_cancel_iff
thf(fact_3175_numeral__power__less__nat__cancel__iff,axiom,
! [X: num,N2: nat,A3: int] :
( ( ord_less @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ X ) @ N2 ) @ ( nat2 @ A3 ) )
= ( ord_less @ int @ ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 ) @ A3 ) ) ).
% numeral_power_less_nat_cancel_iff
thf(fact_3176_nat__le__numeral__power__cancel__iff,axiom,
! [A3: int,X: num,N2: nat] :
( ( ord_less_eq @ nat @ ( nat2 @ A3 ) @ ( power_power @ nat @ ( numeral_numeral @ nat @ X ) @ N2 ) )
= ( ord_less_eq @ int @ A3 @ ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 ) ) ) ).
% nat_le_numeral_power_cancel_iff
thf(fact_3177_numeral__power__le__nat__cancel__iff,axiom,
! [X: num,N2: nat,A3: int] :
( ( ord_less_eq @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ X ) @ N2 ) @ ( nat2 @ A3 ) )
= ( ord_less_eq @ int @ ( power_power @ int @ ( numeral_numeral @ int @ X ) @ N2 ) @ A3 ) ) ).
% numeral_power_le_nat_cancel_iff
thf(fact_3178_mult__commute__imp__mult__inverse__commute,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Y: A,X: A] :
( ( ( times_times @ A @ Y @ X )
= ( times_times @ A @ X @ Y ) )
=> ( ( times_times @ A @ ( inverse_inverse @ A @ Y ) @ X )
= ( times_times @ A @ X @ ( inverse_inverse @ A @ Y ) ) ) ) ) ).
% mult_commute_imp_mult_inverse_commute
thf(fact_3179_nonzero__norm__inverse,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( real_V7770717601297561774m_norm @ A @ ( inverse_inverse @ A @ A3 ) )
= ( inverse_inverse @ real @ ( real_V7770717601297561774m_norm @ A @ A3 ) ) ) ) ) ).
% nonzero_norm_inverse
thf(fact_3180_inverse__eq__imp__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A] :
( ( ( inverse_inverse @ A @ A3 )
= ( inverse_inverse @ A @ B2 ) )
=> ( A3 = B2 ) ) ) ).
% inverse_eq_imp_eq
thf(fact_3181_nonzero__imp__inverse__nonzero,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( inverse_inverse @ A @ A3 )
!= ( zero_zero @ A ) ) ) ) ).
% nonzero_imp_inverse_nonzero
thf(fact_3182_nonzero__inverse__inverse__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( inverse_inverse @ A @ ( inverse_inverse @ A @ A3 ) )
= A3 ) ) ) ).
% nonzero_inverse_inverse_eq
thf(fact_3183_nonzero__inverse__eq__imp__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A] :
( ( ( inverse_inverse @ A @ A3 )
= ( inverse_inverse @ A @ B2 ) )
=> ( ( A3
!= ( zero_zero @ A ) )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( A3 = B2 ) ) ) ) ) ).
% nonzero_inverse_eq_imp_eq
thf(fact_3184_inverse__zero__imp__zero,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( ( inverse_inverse @ A @ A3 )
= ( zero_zero @ A ) )
=> ( A3
= ( zero_zero @ A ) ) ) ) ).
% inverse_zero_imp_zero
thf(fact_3185_field__class_Ofield__inverse__zero,axiom,
! [A: $tType] :
( ( field @ A )
=> ( ( inverse_inverse @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% field_class.field_inverse_zero
thf(fact_3186_nonzero__inverse__scaleR__distrib,axiom,
! [A: $tType] :
( ( real_V5047593784448816457lgebra @ A )
=> ! [A3: real,X: A] :
( ( A3
!= ( zero_zero @ real ) )
=> ( ( X
!= ( zero_zero @ A ) )
=> ( ( inverse_inverse @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) )
= ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ A3 ) @ ( inverse_inverse @ A @ X ) ) ) ) ) ) ).
% nonzero_inverse_scaleR_distrib
thf(fact_3187_inverse__less__imp__less,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less @ A @ B2 @ A3 ) ) ) ) ).
% inverse_less_imp_less
thf(fact_3188_less__imp__inverse__less,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less @ A @ ( inverse_inverse @ A @ B2 ) @ ( inverse_inverse @ A @ A3 ) ) ) ) ) ).
% less_imp_inverse_less
thf(fact_3189_inverse__less__imp__less__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ B2 @ A3 ) ) ) ) ).
% inverse_less_imp_less_neg
thf(fact_3190_less__imp__inverse__less__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( inverse_inverse @ A @ B2 ) @ ( inverse_inverse @ A @ A3 ) ) ) ) ) ).
% less_imp_inverse_less_neg
thf(fact_3191_inverse__negative__imp__negative,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( inverse_inverse @ A @ A3 ) @ ( zero_zero @ A ) )
=> ( ( A3
!= ( zero_zero @ A ) )
=> ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ) ).
% inverse_negative_imp_negative
thf(fact_3192_inverse__positive__imp__positive,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( inverse_inverse @ A @ A3 ) )
=> ( ( A3
!= ( zero_zero @ A ) )
=> ( ord_less @ A @ ( zero_zero @ A ) @ A3 ) ) ) ) ).
% inverse_positive_imp_positive
thf(fact_3193_negative__imp__inverse__negative,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ A3 @ ( zero_zero @ A ) )
=> ( ord_less @ A @ ( inverse_inverse @ A @ A3 ) @ ( zero_zero @ A ) ) ) ) ).
% negative_imp_inverse_negative
thf(fact_3194_positive__imp__inverse__positive,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( inverse_inverse @ A @ A3 ) ) ) ) ).
% positive_imp_inverse_positive
thf(fact_3195_nonzero__inverse__mult__distrib,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ( inverse_inverse @ A @ ( times_times @ A @ A3 @ B2 ) )
= ( times_times @ A @ ( inverse_inverse @ A @ B2 ) @ ( inverse_inverse @ A @ A3 ) ) ) ) ) ) ).
% nonzero_inverse_mult_distrib
thf(fact_3196_nonzero__inverse__minus__eq,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( inverse_inverse @ A @ ( uminus_uminus @ A @ A3 ) )
= ( uminus_uminus @ A @ ( inverse_inverse @ A @ A3 ) ) ) ) ) ).
% nonzero_inverse_minus_eq
thf(fact_3197_inverse__unique,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A] :
( ( ( times_times @ A @ A3 @ B2 )
= ( one_one @ A ) )
=> ( ( inverse_inverse @ A @ A3 )
= B2 ) ) ) ).
% inverse_unique
thf(fact_3198_divide__inverse__commute,axiom,
! [A: $tType] :
( ( field @ A )
=> ( ( divide_divide @ A )
= ( ^ [A5: A,B4: A] : ( times_times @ A @ ( inverse_inverse @ A @ B4 ) @ A5 ) ) ) ) ).
% divide_inverse_commute
thf(fact_3199_divide__inverse,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ( ( divide_divide @ A )
= ( ^ [A5: A,B4: A] : ( times_times @ A @ A5 @ ( inverse_inverse @ A @ B4 ) ) ) ) ) ).
% divide_inverse
thf(fact_3200_field__class_Ofield__divide__inverse,axiom,
! [A: $tType] :
( ( field @ A )
=> ( ( divide_divide @ A )
= ( ^ [A5: A,B4: A] : ( times_times @ A @ A5 @ ( inverse_inverse @ A @ B4 ) ) ) ) ) ).
% field_class.field_divide_inverse
thf(fact_3201_inverse__eq__divide,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ( ( inverse_inverse @ A )
= ( divide_divide @ A @ ( one_one @ A ) ) ) ) ).
% inverse_eq_divide
thf(fact_3202_power__mult__power__inverse__commute,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,M: nat,N2: nat] :
( ( times_times @ A @ ( power_power @ A @ X @ M ) @ ( power_power @ A @ ( inverse_inverse @ A @ X ) @ N2 ) )
= ( times_times @ A @ ( power_power @ A @ ( inverse_inverse @ A @ X ) @ N2 ) @ ( power_power @ A @ X @ M ) ) ) ) ).
% power_mult_power_inverse_commute
thf(fact_3203_power__mult__inverse__distrib,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,M: nat] :
( ( times_times @ A @ ( power_power @ A @ X @ M ) @ ( inverse_inverse @ A @ X ) )
= ( times_times @ A @ ( inverse_inverse @ A @ X ) @ ( power_power @ A @ X @ M ) ) ) ) ).
% power_mult_inverse_distrib
thf(fact_3204_mult__inverse__of__nat__commute,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Xa2: nat,X: A] :
( ( times_times @ A @ ( inverse_inverse @ A @ ( semiring_1_of_nat @ A @ Xa2 ) ) @ X )
= ( times_times @ A @ X @ ( inverse_inverse @ A @ ( semiring_1_of_nat @ A @ Xa2 ) ) ) ) ) ).
% mult_inverse_of_nat_commute
thf(fact_3205_nonzero__abs__inverse,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( abs_abs @ A @ ( inverse_inverse @ A @ A3 ) )
= ( inverse_inverse @ A @ ( abs_abs @ A @ A3 ) ) ) ) ) ).
% nonzero_abs_inverse
thf(fact_3206_mult__inverse__of__int__commute,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [Xa2: int,X: A] :
( ( times_times @ A @ ( inverse_inverse @ A @ ( ring_1_of_int @ A @ Xa2 ) ) @ X )
= ( times_times @ A @ X @ ( inverse_inverse @ A @ ( ring_1_of_int @ A @ Xa2 ) ) ) ) ) ).
% mult_inverse_of_int_commute
thf(fact_3207_nat__zero__as__int,axiom,
( ( zero_zero @ nat )
= ( nat2 @ ( zero_zero @ int ) ) ) ).
% nat_zero_as_int
thf(fact_3208_nat__mono,axiom,
! [X: int,Y: int] :
( ( ord_less_eq @ int @ X @ Y )
=> ( ord_less_eq @ nat @ ( nat2 @ X ) @ ( nat2 @ Y ) ) ) ).
% nat_mono
thf(fact_3209_ex__nat,axiom,
( ( ^ [P3: nat > $o] :
? [X6: nat] : ( P3 @ X6 ) )
= ( ^ [P: nat > $o] :
? [X2: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ X2 )
& ( P @ ( nat2 @ X2 ) ) ) ) ) ).
% ex_nat
thf(fact_3210_all__nat,axiom,
( ( ^ [P3: nat > $o] :
! [X6: nat] : ( P3 @ X6 ) )
= ( ^ [P: nat > $o] :
! [X2: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ X2 )
=> ( P @ ( nat2 @ X2 ) ) ) ) ) ).
% all_nat
thf(fact_3211_eq__nat__nat__iff,axiom,
! [Z: int,Z8: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z8 )
=> ( ( ( nat2 @ Z )
= ( nat2 @ Z8 ) )
= ( Z = Z8 ) ) ) ) ).
% eq_nat_nat_iff
thf(fact_3212_inverse__le__imp__le,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ).
% inverse_le_imp_le
thf(fact_3213_le__imp__inverse__le,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ord_less_eq @ A @ ( inverse_inverse @ A @ B2 ) @ ( inverse_inverse @ A @ A3 ) ) ) ) ) ).
% le_imp_inverse_le
thf(fact_3214_inverse__le__imp__le__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ B2 @ A3 ) ) ) ) ).
% inverse_le_imp_le_neg
thf(fact_3215_le__imp__inverse__le__neg,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ B2 @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( inverse_inverse @ A @ B2 ) @ ( inverse_inverse @ A @ A3 ) ) ) ) ) ).
% le_imp_inverse_le_neg
thf(fact_3216_inverse__le__1__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A] :
( ( ord_less_eq @ A @ ( inverse_inverse @ A @ X ) @ ( one_one @ A ) )
= ( ( ord_less_eq @ A @ X @ ( zero_zero @ A ) )
| ( ord_less_eq @ A @ ( one_one @ A ) @ X ) ) ) ) ).
% inverse_le_1_iff
thf(fact_3217_one__less__inverse,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ A3 @ ( one_one @ A ) )
=> ( ord_less @ A @ ( one_one @ A ) @ ( inverse_inverse @ A @ A3 ) ) ) ) ) ).
% one_less_inverse
thf(fact_3218_one__less__inverse__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A] :
( ( ord_less @ A @ ( one_one @ A ) @ ( inverse_inverse @ A @ X ) )
= ( ( ord_less @ A @ ( zero_zero @ A ) @ X )
& ( ord_less @ A @ X @ ( one_one @ A ) ) ) ) ) ).
% one_less_inverse_iff
thf(fact_3219_field__class_Ofield__inverse,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( times_times @ A @ ( inverse_inverse @ A @ A3 ) @ A3 )
= ( one_one @ A ) ) ) ) ).
% field_class.field_inverse
thf(fact_3220_division__ring__inverse__add,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
= ( times_times @ A @ ( times_times @ A @ ( inverse_inverse @ A @ A3 ) @ ( plus_plus @ A @ A3 @ B2 ) ) @ ( inverse_inverse @ A @ B2 ) ) ) ) ) ) ).
% division_ring_inverse_add
thf(fact_3221_inverse__add,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
= ( times_times @ A @ ( times_times @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( inverse_inverse @ A @ A3 ) ) @ ( inverse_inverse @ A @ B2 ) ) ) ) ) ) ).
% inverse_add
thf(fact_3222_division__ring__inverse__diff,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
= ( times_times @ A @ ( times_times @ A @ ( inverse_inverse @ A @ A3 ) @ ( minus_minus @ A @ B2 @ A3 ) ) @ ( inverse_inverse @ A @ B2 ) ) ) ) ) ) ).
% division_ring_inverse_diff
thf(fact_3223_nonzero__inverse__eq__divide,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( inverse_inverse @ A @ A3 )
= ( divide_divide @ A @ ( one_one @ A ) @ A3 ) ) ) ) ).
% nonzero_inverse_eq_divide
thf(fact_3224_nat__mono__iff,axiom,
! [Z: int,W2: int] :
( ( ord_less @ int @ ( zero_zero @ int ) @ Z )
=> ( ( ord_less @ nat @ ( nat2 @ W2 ) @ ( nat2 @ Z ) )
= ( ord_less @ int @ W2 @ Z ) ) ) ).
% nat_mono_iff
thf(fact_3225_of__nat__ceiling,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [R2: A] : ( ord_less_eq @ A @ R2 @ ( semiring_1_of_nat @ A @ ( nat2 @ ( archimedean_ceiling @ A @ R2 ) ) ) ) ) ).
% of_nat_ceiling
thf(fact_3226_zless__nat__eq__int__zless,axiom,
! [M: nat,Z: int] :
( ( ord_less @ nat @ M @ ( nat2 @ Z ) )
= ( ord_less @ int @ ( semiring_1_of_nat @ int @ M ) @ Z ) ) ).
% zless_nat_eq_int_zless
thf(fact_3227_nat__le__iff,axiom,
! [X: int,N2: nat] :
( ( ord_less_eq @ nat @ ( nat2 @ X ) @ N2 )
= ( ord_less_eq @ int @ X @ ( semiring_1_of_nat @ int @ N2 ) ) ) ).
% nat_le_iff
thf(fact_3228_nat__0__le,axiom,
! [Z: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( ( semiring_1_of_nat @ int @ ( nat2 @ Z ) )
= Z ) ) ).
% nat_0_le
thf(fact_3229_int__eq__iff,axiom,
! [M: nat,Z: int] :
( ( ( semiring_1_of_nat @ int @ M )
= Z )
= ( ( M
= ( nat2 @ Z ) )
& ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z ) ) ) ).
% int_eq_iff
thf(fact_3230_nat__int__add,axiom,
! [A3: nat,B2: nat] :
( ( nat2 @ ( plus_plus @ int @ ( semiring_1_of_nat @ int @ A3 ) @ ( semiring_1_of_nat @ int @ B2 ) ) )
= ( plus_plus @ nat @ A3 @ B2 ) ) ).
% nat_int_add
thf(fact_3231_nat__abs__mult__distrib,axiom,
! [W2: int,Z: int] :
( ( nat2 @ ( abs_abs @ int @ ( times_times @ int @ W2 @ Z ) ) )
= ( times_times @ nat @ ( nat2 @ ( abs_abs @ int @ W2 ) ) @ ( nat2 @ ( abs_abs @ int @ Z ) ) ) ) ).
% nat_abs_mult_distrib
thf(fact_3232_nat__plus__as__int,axiom,
( ( plus_plus @ nat )
= ( ^ [A5: nat,B4: nat] : ( nat2 @ ( plus_plus @ int @ ( semiring_1_of_nat @ int @ A5 ) @ ( semiring_1_of_nat @ int @ B4 ) ) ) ) ) ).
% nat_plus_as_int
thf(fact_3233_cosh__def,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ( ( cosh @ A )
= ( ^ [X2: A] : ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) ) @ ( plus_plus @ A @ ( exp @ A @ X2 ) @ ( exp @ A @ ( uminus_uminus @ A @ X2 ) ) ) ) ) ) ) ).
% cosh_def
thf(fact_3234_inverse__le__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) )
=> ( ord_less_eq @ A @ B2 @ A3 ) )
& ( ( ord_less_eq @ A @ ( times_times @ A @ A3 @ B2 ) @ ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ) ).
% inverse_le_iff
thf(fact_3235_inverse__less__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
= ( ( ( ord_less @ A @ ( zero_zero @ A ) @ ( times_times @ A @ A3 @ B2 ) )
=> ( ord_less @ A @ B2 @ A3 ) )
& ( ( ord_less_eq @ A @ ( times_times @ A @ A3 @ B2 ) @ ( zero_zero @ A ) )
=> ( ord_less @ A @ A3 @ B2 ) ) ) ) ) ).
% inverse_less_iff
thf(fact_3236_one__le__inverse,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ A3 @ ( one_one @ A ) )
=> ( ord_less_eq @ A @ ( one_one @ A ) @ ( inverse_inverse @ A @ A3 ) ) ) ) ) ).
% one_le_inverse
thf(fact_3237_inverse__less__1__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A] :
( ( ord_less @ A @ ( inverse_inverse @ A @ X ) @ ( one_one @ A ) )
= ( ( ord_less_eq @ A @ X @ ( zero_zero @ A ) )
| ( ord_less @ A @ ( one_one @ A ) @ X ) ) ) ) ).
% inverse_less_1_iff
thf(fact_3238_one__le__inverse__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A] :
( ( ord_less_eq @ A @ ( one_one @ A ) @ ( inverse_inverse @ A @ X ) )
= ( ( ord_less @ A @ ( zero_zero @ A ) @ X )
& ( ord_less_eq @ A @ X @ ( one_one @ A ) ) ) ) ) ).
% one_le_inverse_iff
thf(fact_3239_inverse__diff__inverse,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ( minus_minus @ A @ ( inverse_inverse @ A @ A3 ) @ ( inverse_inverse @ A @ B2 ) )
= ( uminus_uminus @ A @ ( times_times @ A @ ( times_times @ A @ ( inverse_inverse @ A @ A3 ) @ ( minus_minus @ A @ A3 @ B2 ) ) @ ( inverse_inverse @ A @ B2 ) ) ) ) ) ) ) ).
% inverse_diff_inverse
thf(fact_3240_reals__Archimedean,axiom,
! [A: $tType] :
( ( archim462609752435547400_field @ A )
=> ! [X: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ X )
=> ? [N3: nat] : ( ord_less @ A @ ( inverse_inverse @ A @ ( semiring_1_of_nat @ A @ ( suc @ N3 ) ) ) @ X ) ) ) ).
% reals_Archimedean
thf(fact_3241_of__nat__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [R2: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ R2 )
=> ( ord_less_eq @ A @ ( semiring_1_of_nat @ A @ ( nat2 @ ( archim6421214686448440834_floor @ A @ R2 ) ) ) @ R2 ) ) ) ).
% of_nat_floor
thf(fact_3242_real__vector__eq__affinity,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [M: real,Y: A,X: A,C2: A] :
( ( M
!= ( zero_zero @ real ) )
=> ( ( Y
= ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ M @ X ) @ C2 ) )
= ( ( minus_minus @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ M ) @ Y ) @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ M ) @ C2 ) )
= X ) ) ) ) ).
% real_vector_eq_affinity
thf(fact_3243_real__vector__affinity__eq,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [M: real,X: A,C2: A,Y: A] :
( ( M
!= ( zero_zero @ real ) )
=> ( ( ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ M @ X ) @ C2 )
= Y )
= ( X
= ( minus_minus @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ M ) @ Y ) @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ M ) @ C2 ) ) ) ) ) ) ).
% real_vector_affinity_eq
thf(fact_3244_pos__divideR__le__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,B2: A,A3: A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ C2 )
=> ( ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) @ A3 )
= ( ord_less_eq @ A @ B2 @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) ) ) ) ) ).
% pos_divideR_le_eq
thf(fact_3245_pos__le__divideR__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,A3: A,B2: A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ C2 )
=> ( ( ord_less_eq @ A @ A3 @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) )
= ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ B2 ) ) ) ) ).
% pos_le_divideR_eq
thf(fact_3246_neg__divideR__le__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,B2: A,A3: A] :
( ( ord_less @ real @ C2 @ ( zero_zero @ real ) )
=> ( ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) @ A3 )
= ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ B2 ) ) ) ) ).
% neg_divideR_le_eq
thf(fact_3247_neg__le__divideR__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,A3: A,B2: A] :
( ( ord_less @ real @ C2 @ ( zero_zero @ real ) )
=> ( ( ord_less_eq @ A @ A3 @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) )
= ( ord_less_eq @ A @ B2 @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) ) ) ) ) ).
% neg_le_divideR_eq
thf(fact_3248_pos__divideR__less__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,B2: A,A3: A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ C2 )
=> ( ( ord_less @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) @ A3 )
= ( ord_less @ A @ B2 @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) ) ) ) ) ).
% pos_divideR_less_eq
thf(fact_3249_pos__less__divideR__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,A3: A,B2: A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ C2 )
=> ( ( ord_less @ A @ A3 @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) )
= ( ord_less @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ B2 ) ) ) ) ).
% pos_less_divideR_eq
thf(fact_3250_neg__divideR__less__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,B2: A,A3: A] :
( ( ord_less @ real @ C2 @ ( zero_zero @ real ) )
=> ( ( ord_less @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) @ A3 )
= ( ord_less @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ B2 ) ) ) ) ).
% neg_divideR_less_eq
thf(fact_3251_neg__less__divideR__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,A3: A,B2: A] :
( ( ord_less @ real @ C2 @ ( zero_zero @ real ) )
=> ( ( ord_less @ A @ A3 @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) )
= ( ord_less @ A @ B2 @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) ) ) ) ) ).
% neg_less_divideR_eq
thf(fact_3252_nat__less__eq__zless,axiom,
! [W2: int,Z: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ W2 )
=> ( ( ord_less @ nat @ ( nat2 @ W2 ) @ ( nat2 @ Z ) )
= ( ord_less @ int @ W2 @ Z ) ) ) ).
% nat_less_eq_zless
thf(fact_3253_nat__le__eq__zle,axiom,
! [W2: int,Z: int] :
( ( ( ord_less @ int @ ( zero_zero @ int ) @ W2 )
| ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z ) )
=> ( ( ord_less_eq @ nat @ ( nat2 @ W2 ) @ ( nat2 @ Z ) )
= ( ord_less_eq @ int @ W2 @ Z ) ) ) ).
% nat_le_eq_zle
thf(fact_3254_nat__eq__iff2,axiom,
! [M: nat,W2: int] :
( ( M
= ( nat2 @ W2 ) )
= ( ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ W2 )
=> ( W2
= ( semiring_1_of_nat @ int @ M ) ) )
& ( ~ ( ord_less_eq @ int @ ( zero_zero @ int ) @ W2 )
=> ( M
= ( zero_zero @ nat ) ) ) ) ) ).
% nat_eq_iff2
thf(fact_3255_nat__eq__iff,axiom,
! [W2: int,M: nat] :
( ( ( nat2 @ W2 )
= M )
= ( ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ W2 )
=> ( W2
= ( semiring_1_of_nat @ int @ M ) ) )
& ( ~ ( ord_less_eq @ int @ ( zero_zero @ int ) @ W2 )
=> ( M
= ( zero_zero @ nat ) ) ) ) ) ).
% nat_eq_iff
thf(fact_3256_split__nat,axiom,
! [P2: nat > $o,I: int] :
( ( P2 @ ( nat2 @ I ) )
= ( ! [N: nat] :
( ( I
= ( semiring_1_of_nat @ int @ N ) )
=> ( P2 @ N ) )
& ( ( ord_less @ int @ I @ ( zero_zero @ int ) )
=> ( P2 @ ( zero_zero @ nat ) ) ) ) ) ).
% split_nat
thf(fact_3257_le__mult__nat__floor,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ nat @ ( times_times @ nat @ ( nat2 @ ( archim6421214686448440834_floor @ A @ A3 ) ) @ ( nat2 @ ( archim6421214686448440834_floor @ A @ B2 ) ) ) @ ( nat2 @ ( archim6421214686448440834_floor @ A @ ( times_times @ A @ A3 @ B2 ) ) ) ) ) ).
% le_mult_nat_floor
thf(fact_3258_le__nat__iff,axiom,
! [K: int,N2: nat] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ K )
=> ( ( ord_less_eq @ nat @ N2 @ ( nat2 @ K ) )
= ( ord_less_eq @ int @ ( semiring_1_of_nat @ int @ N2 ) @ K ) ) ) ).
% le_nat_iff
thf(fact_3259_nat__add__distrib,axiom,
! [Z: int,Z8: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z8 )
=> ( ( nat2 @ ( plus_plus @ int @ Z @ Z8 ) )
= ( plus_plus @ nat @ ( nat2 @ Z ) @ ( nat2 @ Z8 ) ) ) ) ) ).
% nat_add_distrib
thf(fact_3260_nat__mult__distrib,axiom,
! [Z: int,Z8: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( ( nat2 @ ( times_times @ int @ Z @ Z8 ) )
= ( times_times @ nat @ ( nat2 @ Z ) @ ( nat2 @ Z8 ) ) ) ) ).
% nat_mult_distrib
thf(fact_3261_Suc__as__int,axiom,
( suc
= ( ^ [A5: nat] : ( nat2 @ ( plus_plus @ int @ ( semiring_1_of_nat @ int @ A5 ) @ ( one_one @ int ) ) ) ) ) ).
% Suc_as_int
thf(fact_3262_forall__pos__mono__1,axiom,
! [P2: real > $o,E3: real] :
( ! [D3: real,E: real] :
( ( ord_less @ real @ D3 @ E )
=> ( ( P2 @ D3 )
=> ( P2 @ E ) ) )
=> ( ! [N3: nat] : ( P2 @ ( inverse_inverse @ real @ ( semiring_1_of_nat @ real @ ( suc @ N3 ) ) ) )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ E3 )
=> ( P2 @ E3 ) ) ) ) ).
% forall_pos_mono_1
thf(fact_3263_real__arch__inverse,axiom,
! [E3: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E3 )
= ( ? [N: nat] :
( ( N
!= ( zero_zero @ nat ) )
& ( ord_less @ real @ ( zero_zero @ real ) @ ( inverse_inverse @ real @ ( semiring_1_of_nat @ real @ N ) ) )
& ( ord_less @ real @ ( inverse_inverse @ real @ ( semiring_1_of_nat @ real @ N ) ) @ E3 ) ) ) ) ).
% real_arch_inverse
thf(fact_3264_forall__pos__mono,axiom,
! [P2: real > $o,E3: real] :
( ! [D3: real,E: real] :
( ( ord_less @ real @ D3 @ E )
=> ( ( P2 @ D3 )
=> ( P2 @ E ) ) )
=> ( ! [N3: nat] :
( ( N3
!= ( zero_zero @ nat ) )
=> ( P2 @ ( inverse_inverse @ real @ ( semiring_1_of_nat @ real @ N3 ) ) ) )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ E3 )
=> ( P2 @ E3 ) ) ) ) ).
% forall_pos_mono
thf(fact_3265_nat__diff__distrib_H,axiom,
! [X: int,Y: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ X )
=> ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Y )
=> ( ( nat2 @ ( minus_minus @ int @ X @ Y ) )
= ( minus_minus @ nat @ ( nat2 @ X ) @ ( nat2 @ Y ) ) ) ) ) ).
% nat_diff_distrib'
thf(fact_3266_nat__diff__distrib,axiom,
! [Z8: int,Z: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z8 )
=> ( ( ord_less_eq @ int @ Z8 @ Z )
=> ( ( nat2 @ ( minus_minus @ int @ Z @ Z8 ) )
= ( minus_minus @ nat @ ( nat2 @ Z ) @ ( nat2 @ Z8 ) ) ) ) ) ).
% nat_diff_distrib
thf(fact_3267_nat__abs__triangle__ineq,axiom,
! [K: int,L: int] : ( ord_less_eq @ nat @ ( nat2 @ ( abs_abs @ int @ ( plus_plus @ int @ K @ L ) ) ) @ ( plus_plus @ nat @ ( nat2 @ ( abs_abs @ int @ K ) ) @ ( nat2 @ ( abs_abs @ int @ L ) ) ) ) ).
% nat_abs_triangle_ineq
thf(fact_3268_nat__floor__neg,axiom,
! [X: real] :
( ( ord_less_eq @ real @ X @ ( zero_zero @ real ) )
=> ( ( nat2 @ ( archim6421214686448440834_floor @ real @ X ) )
= ( zero_zero @ nat ) ) ) ).
% nat_floor_neg
thf(fact_3269_nat__power__eq,axiom,
! [Z: int,N2: nat] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( ( nat2 @ ( power_power @ int @ Z @ N2 ) )
= ( power_power @ nat @ ( nat2 @ Z ) @ N2 ) ) ) ).
% nat_power_eq
thf(fact_3270_floor__eq3,axiom,
! [N2: nat,X: real] :
( ( ord_less @ real @ ( semiring_1_of_nat @ real @ N2 ) @ X )
=> ( ( ord_less @ real @ X @ ( semiring_1_of_nat @ real @ ( suc @ N2 ) ) )
=> ( ( nat2 @ ( archim6421214686448440834_floor @ real @ X ) )
= N2 ) ) ) ).
% floor_eq3
thf(fact_3271_le__nat__floor,axiom,
! [X: nat,A3: real] :
( ( ord_less_eq @ real @ ( semiring_1_of_nat @ real @ X ) @ A3 )
=> ( ord_less_eq @ nat @ X @ ( nat2 @ ( archim6421214686448440834_floor @ real @ A3 ) ) ) ) ).
% le_nat_floor
thf(fact_3272_ex__inverse__of__nat__less,axiom,
! [A: $tType] :
( ( archim462609752435547400_field @ A )
=> ! [X: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ X )
=> ? [N3: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 )
& ( ord_less @ A @ ( inverse_inverse @ A @ ( semiring_1_of_nat @ A @ N3 ) ) @ X ) ) ) ) ).
% ex_inverse_of_nat_less
thf(fact_3273_power__diff__conv__inverse,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,M: nat,N2: nat] :
( ( X
!= ( zero_zero @ A ) )
=> ( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( power_power @ A @ X @ ( minus_minus @ nat @ N2 @ M ) )
= ( times_times @ A @ ( power_power @ A @ X @ N2 ) @ ( power_power @ A @ ( inverse_inverse @ A @ X ) @ M ) ) ) ) ) ) ).
% power_diff_conv_inverse
thf(fact_3274_nat__2,axiom,
( ( nat2 @ ( numeral_numeral @ int @ ( bit0 @ one2 ) ) )
= ( suc @ ( suc @ ( zero_zero @ nat ) ) ) ) ).
% nat_2
thf(fact_3275_cosh__converges,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ! [X: A] :
( sums @ A
@ ^ [N: nat] : ( if @ A @ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ ( semiring_char_0_fact @ real @ N ) ) @ ( power_power @ A @ X @ N ) ) @ ( zero_zero @ A ) )
@ ( cosh @ A @ X ) ) ) ).
% cosh_converges
thf(fact_3276_pos__le__minus__divideR__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,A3: A,B2: A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ C2 )
=> ( ( ord_less_eq @ A @ A3 @ ( uminus_uminus @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) ) )
= ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ ( uminus_uminus @ A @ B2 ) ) ) ) ) ).
% pos_le_minus_divideR_eq
thf(fact_3277_pos__minus__divideR__le__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,B2: A,A3: A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ C2 )
=> ( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) ) @ A3 )
= ( ord_less_eq @ A @ ( uminus_uminus @ A @ B2 ) @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) ) ) ) ) ).
% pos_minus_divideR_le_eq
thf(fact_3278_neg__le__minus__divideR__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,A3: A,B2: A] :
( ( ord_less @ real @ C2 @ ( zero_zero @ real ) )
=> ( ( ord_less_eq @ A @ A3 @ ( uminus_uminus @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) ) )
= ( ord_less_eq @ A @ ( uminus_uminus @ A @ B2 ) @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) ) ) ) ) ).
% neg_le_minus_divideR_eq
thf(fact_3279_neg__minus__divideR__le__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,B2: A,A3: A] :
( ( ord_less @ real @ C2 @ ( zero_zero @ real ) )
=> ( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) ) @ A3 )
= ( ord_less_eq @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ ( uminus_uminus @ A @ B2 ) ) ) ) ) ).
% neg_minus_divideR_le_eq
thf(fact_3280_pos__less__minus__divideR__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,A3: A,B2: A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ C2 )
=> ( ( ord_less @ A @ A3 @ ( uminus_uminus @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) ) )
= ( ord_less @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ ( uminus_uminus @ A @ B2 ) ) ) ) ) ).
% pos_less_minus_divideR_eq
thf(fact_3281_pos__minus__divideR__less__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,B2: A,A3: A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ C2 )
=> ( ( ord_less @ A @ ( uminus_uminus @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) ) @ A3 )
= ( ord_less @ A @ ( uminus_uminus @ A @ B2 ) @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) ) ) ) ) ).
% pos_minus_divideR_less_eq
thf(fact_3282_neg__less__minus__divideR__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,A3: A,B2: A] :
( ( ord_less @ real @ C2 @ ( zero_zero @ real ) )
=> ( ( ord_less @ A @ A3 @ ( uminus_uminus @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) ) )
= ( ord_less @ A @ ( uminus_uminus @ A @ B2 ) @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) ) ) ) ) ).
% neg_less_minus_divideR_eq
thf(fact_3283_neg__minus__divideR__less__eq,axiom,
! [A: $tType] :
( ( real_V5355595471888546746vector @ A )
=> ! [C2: real,B2: A,A3: A] :
( ( ord_less @ real @ C2 @ ( zero_zero @ real ) )
=> ( ( ord_less @ A @ ( uminus_uminus @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ C2 ) @ B2 ) ) @ A3 )
= ( ord_less @ A @ ( real_V8093663219630862766scaleR @ A @ C2 @ A3 ) @ ( uminus_uminus @ A @ B2 ) ) ) ) ) ).
% neg_minus_divideR_less_eq
thf(fact_3284_Suc__nat__eq__nat__zadd1,axiom,
! [Z: int] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( ( suc @ ( nat2 @ Z ) )
= ( nat2 @ ( plus_plus @ int @ ( one_one @ int ) @ Z ) ) ) ) ).
% Suc_nat_eq_nat_zadd1
thf(fact_3285_nat__less__iff,axiom,
! [W2: int,M: nat] :
( ( ord_less_eq @ int @ ( zero_zero @ int ) @ W2 )
=> ( ( ord_less @ nat @ ( nat2 @ W2 ) @ M )
= ( ord_less @ int @ W2 @ ( semiring_1_of_nat @ int @ M ) ) ) ) ).
% nat_less_iff
thf(fact_3286_nat__mult__distrib__neg,axiom,
! [Z: int,Z8: int] :
( ( ord_less_eq @ int @ Z @ ( zero_zero @ int ) )
=> ( ( nat2 @ ( times_times @ int @ Z @ Z8 ) )
= ( times_times @ nat @ ( nat2 @ ( uminus_uminus @ int @ Z ) ) @ ( nat2 @ ( uminus_uminus @ int @ Z8 ) ) ) ) ) ).
% nat_mult_distrib_neg
thf(fact_3287_nat__abs__int__diff,axiom,
! [A3: nat,B2: nat] :
( ( ( ord_less_eq @ nat @ A3 @ B2 )
=> ( ( nat2 @ ( abs_abs @ int @ ( minus_minus @ int @ ( semiring_1_of_nat @ int @ A3 ) @ ( semiring_1_of_nat @ int @ B2 ) ) ) )
= ( minus_minus @ nat @ B2 @ A3 ) ) )
& ( ~ ( ord_less_eq @ nat @ A3 @ B2 )
=> ( ( nat2 @ ( abs_abs @ int @ ( minus_minus @ int @ ( semiring_1_of_nat @ int @ A3 ) @ ( semiring_1_of_nat @ int @ B2 ) ) ) )
= ( minus_minus @ nat @ A3 @ B2 ) ) ) ) ).
% nat_abs_int_diff
thf(fact_3288_floor__eq4,axiom,
! [N2: nat,X: real] :
( ( ord_less_eq @ real @ ( semiring_1_of_nat @ real @ N2 ) @ X )
=> ( ( ord_less @ real @ X @ ( semiring_1_of_nat @ real @ ( suc @ N2 ) ) )
=> ( ( nat2 @ ( archim6421214686448440834_floor @ real @ X ) )
= N2 ) ) ) ).
% floor_eq4
thf(fact_3289_diff__nat__eq__if,axiom,
! [Z8: int,Z: int] :
( ( ( ord_less @ int @ Z8 @ ( zero_zero @ int ) )
=> ( ( minus_minus @ nat @ ( nat2 @ Z ) @ ( nat2 @ Z8 ) )
= ( nat2 @ Z ) ) )
& ( ~ ( ord_less @ int @ Z8 @ ( zero_zero @ int ) )
=> ( ( minus_minus @ nat @ ( nat2 @ Z ) @ ( nat2 @ Z8 ) )
= ( if @ nat @ ( ord_less @ int @ ( minus_minus @ int @ Z @ Z8 ) @ ( zero_zero @ int ) ) @ ( zero_zero @ nat ) @ ( nat2 @ ( minus_minus @ int @ Z @ Z8 ) ) ) ) ) ) ).
% diff_nat_eq_if
thf(fact_3290_of__int__of__nat,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( ( ring_1_of_int @ A )
= ( ^ [K2: int] : ( if @ A @ ( ord_less @ int @ K2 @ ( zero_zero @ int ) ) @ ( uminus_uminus @ A @ ( semiring_1_of_nat @ A @ ( nat2 @ ( uminus_uminus @ int @ K2 ) ) ) ) @ ( semiring_1_of_nat @ A @ ( nat2 @ K2 ) ) ) ) ) ) ).
% of_int_of_nat
thf(fact_3291_nat__dvd__iff,axiom,
! [Z: int,M: nat] :
( ( dvd_dvd @ nat @ ( nat2 @ Z ) @ M )
= ( ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( dvd_dvd @ int @ Z @ ( semiring_1_of_nat @ int @ M ) ) )
& ( ~ ( ord_less_eq @ int @ ( zero_zero @ int ) @ Z )
=> ( M
= ( zero_zero @ nat ) ) ) ) ) ).
% nat_dvd_iff
thf(fact_3292_cosh__field__def,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ( ( cosh @ A )
= ( ^ [Z6: A] : ( divide_divide @ A @ ( plus_plus @ A @ ( exp @ A @ Z6 ) @ ( exp @ A @ ( uminus_uminus @ A @ Z6 ) ) ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% cosh_field_def
thf(fact_3293_exp__series__add__commuting,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ! [X: A,Y: A,N2: nat] :
( ( ( times_times @ A @ X @ Y )
= ( times_times @ A @ Y @ X ) )
=> ( ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ A @ ( plus_plus @ A @ X @ Y ) @ N2 ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ ( semiring_char_0_fact @ real @ I5 ) ) @ ( power_power @ A @ X @ I5 ) ) @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ ( semiring_char_0_fact @ real @ ( minus_minus @ nat @ N2 @ I5 ) ) ) @ ( power_power @ A @ Y @ ( minus_minus @ nat @ N2 @ I5 ) ) ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) ) ) ).
% exp_series_add_commuting
thf(fact_3294_exp__first__term,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ( ( exp @ A )
= ( ^ [X2: A] :
( plus_plus @ A @ ( one_one @ A )
@ ( suminf @ A
@ ^ [N: nat] : ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ ( semiring_char_0_fact @ real @ ( suc @ N ) ) ) @ ( power_power @ A @ X2 @ ( suc @ N ) ) ) ) ) ) ) ) ).
% exp_first_term
thf(fact_3295_tan__sec,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ( cos @ A @ X )
!= ( zero_zero @ A ) )
=> ( ( plus_plus @ A @ ( one_one @ A ) @ ( power_power @ A @ ( tan @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
= ( power_power @ A @ ( inverse_inverse @ A @ ( cos @ A @ X ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ).
% tan_sec
thf(fact_3296_sinh__converges,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ! [X: A] :
( sums @ A
@ ^ [N: nat] : ( if @ A @ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) @ ( zero_zero @ A ) @ ( real_V8093663219630862766scaleR @ A @ ( inverse_inverse @ real @ ( semiring_char_0_fact @ real @ N ) ) @ ( power_power @ A @ X @ N ) ) )
@ ( sinh @ A @ X ) ) ) ).
% sinh_converges
thf(fact_3297_cosh__double,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( cosh @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ X ) )
= ( plus_plus @ A @ ( power_power @ A @ ( cosh @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( power_power @ A @ ( sinh @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ).
% cosh_double
thf(fact_3298_tanh__add,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( ( ( cosh @ A @ X )
!= ( zero_zero @ A ) )
=> ( ( ( cosh @ A @ Y )
!= ( zero_zero @ A ) )
=> ( ( tanh @ A @ ( plus_plus @ A @ X @ Y ) )
= ( divide_divide @ A @ ( plus_plus @ A @ ( tanh @ A @ X ) @ ( tanh @ A @ Y ) ) @ ( plus_plus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( tanh @ A @ X ) @ ( tanh @ A @ Y ) ) ) ) ) ) ) ) ).
% tanh_add
thf(fact_3299_sum__diff1_H__aux,axiom,
! [B: $tType,A: $tType] :
( ( ab_group_add @ B )
=> ! [F5: set @ A,I6: set @ A,F2: A > B,I: A] :
( ( finite_finite @ A @ F5 )
=> ( ( ord_less_eq @ ( set @ A )
@ ( collect @ A
@ ^ [I5: A] :
( ( member2 @ A @ I5 @ I6 )
& ( ( F2 @ I5 )
!= ( zero_zero @ B ) ) ) )
@ F5 )
=> ( ( ( member2 @ A @ I @ I6 )
=> ( ( groups1027152243600224163dd_sum @ A @ B @ F2 @ ( minus_minus @ ( set @ A ) @ I6 @ ( insert2 @ A @ I @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( minus_minus @ B @ ( groups1027152243600224163dd_sum @ A @ B @ F2 @ I6 ) @ ( F2 @ I ) ) ) )
& ( ~ ( member2 @ A @ I @ I6 )
=> ( ( groups1027152243600224163dd_sum @ A @ B @ F2 @ ( minus_minus @ ( set @ A ) @ I6 @ ( insert2 @ A @ I @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( groups1027152243600224163dd_sum @ A @ B @ F2 @ I6 ) ) ) ) ) ) ) ).
% sum_diff1'_aux
thf(fact_3300_or__nat__unfold,axiom,
( ( bit_se1065995026697491101ons_or @ nat )
= ( ^ [M2: nat,N: nat] :
( if @ nat
@ ( M2
= ( zero_zero @ nat ) )
@ N
@ ( if @ nat
@ ( N
= ( zero_zero @ nat ) )
@ M2
@ ( plus_plus @ nat @ ( ord_max @ nat @ ( modulo_modulo @ nat @ M2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( modulo_modulo @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( bit_se1065995026697491101ons_or @ nat @ ( divide_divide @ nat @ M2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ).
% or_nat_unfold
thf(fact_3301_or_Oright__neutral,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se1065995026697491101ons_or @ A @ A3 @ ( zero_zero @ A ) )
= A3 ) ) ).
% or.right_neutral
thf(fact_3302_or_Oleft__neutral,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se1065995026697491101ons_or @ A @ ( zero_zero @ A ) @ A3 )
= A3 ) ) ).
% or.left_neutral
thf(fact_3303_sinh__0,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ( ( sinh @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% sinh_0
thf(fact_3304_tanh__0,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ( ( tanh @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% tanh_0
thf(fact_3305_sum_Oempty_H,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ A )
=> ! [P4: B > A] :
( ( groups1027152243600224163dd_sum @ B @ A @ P4 @ ( bot_bot @ ( set @ B ) ) )
= ( zero_zero @ A ) ) ) ).
% sum.empty'
thf(fact_3306_or__nat__numerals_I4_J,axiom,
! [X: num] :
( ( bit_se1065995026697491101ons_or @ nat @ ( numeral_numeral @ nat @ ( bit1 @ X ) ) @ ( suc @ ( zero_zero @ nat ) ) )
= ( numeral_numeral @ nat @ ( bit1 @ X ) ) ) ).
% or_nat_numerals(4)
thf(fact_3307_or__nat__numerals_I2_J,axiom,
! [Y: num] :
( ( bit_se1065995026697491101ons_or @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( numeral_numeral @ nat @ ( bit1 @ Y ) ) )
= ( numeral_numeral @ nat @ ( bit1 @ Y ) ) ) ).
% or_nat_numerals(2)
thf(fact_3308_sum_Oinsert_H,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [I6: set @ B,P4: B > A,I: B] :
( ( finite_finite @ B
@ ( collect @ B
@ ^ [X2: B] :
( ( member2 @ B @ X2 @ I6 )
& ( ( P4 @ X2 )
!= ( zero_zero @ A ) ) ) ) )
=> ( ( ( member2 @ B @ I @ I6 )
=> ( ( groups1027152243600224163dd_sum @ B @ A @ P4 @ ( insert2 @ B @ I @ I6 ) )
= ( groups1027152243600224163dd_sum @ B @ A @ P4 @ I6 ) ) )
& ( ~ ( member2 @ B @ I @ I6 )
=> ( ( groups1027152243600224163dd_sum @ B @ A @ P4 @ ( insert2 @ B @ I @ I6 ) )
= ( plus_plus @ A @ ( P4 @ I ) @ ( groups1027152243600224163dd_sum @ B @ A @ P4 @ I6 ) ) ) ) ) ) ) ).
% sum.insert'
thf(fact_3309_or__nat__numerals_I3_J,axiom,
! [X: num] :
( ( bit_se1065995026697491101ons_or @ nat @ ( numeral_numeral @ nat @ ( bit0 @ X ) ) @ ( suc @ ( zero_zero @ nat ) ) )
= ( numeral_numeral @ nat @ ( bit1 @ X ) ) ) ).
% or_nat_numerals(3)
thf(fact_3310_or__nat__numerals_I1_J,axiom,
! [Y: num] :
( ( bit_se1065995026697491101ons_or @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( numeral_numeral @ nat @ ( bit0 @ Y ) ) )
= ( numeral_numeral @ nat @ ( bit1 @ Y ) ) ) ).
% or_nat_numerals(1)
thf(fact_3311_or__numerals_I4_J,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [X: num,Y: num] :
( ( bit_se1065995026697491101ons_or @ A @ ( numeral_numeral @ A @ ( bit0 @ X ) ) @ ( numeral_numeral @ A @ ( bit1 @ Y ) ) )
= ( plus_plus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se1065995026697491101ons_or @ A @ ( numeral_numeral @ A @ X ) @ ( numeral_numeral @ A @ Y ) ) ) ) ) ) ).
% or_numerals(4)
thf(fact_3312_or__numerals_I6_J,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [X: num,Y: num] :
( ( bit_se1065995026697491101ons_or @ A @ ( numeral_numeral @ A @ ( bit1 @ X ) ) @ ( numeral_numeral @ A @ ( bit0 @ Y ) ) )
= ( plus_plus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se1065995026697491101ons_or @ A @ ( numeral_numeral @ A @ X ) @ ( numeral_numeral @ A @ Y ) ) ) ) ) ) ).
% or_numerals(6)
thf(fact_3313_or__numerals_I7_J,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [X: num,Y: num] :
( ( bit_se1065995026697491101ons_or @ A @ ( numeral_numeral @ A @ ( bit1 @ X ) ) @ ( numeral_numeral @ A @ ( bit1 @ Y ) ) )
= ( plus_plus @ A @ ( one_one @ A ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se1065995026697491101ons_or @ A @ ( numeral_numeral @ A @ X ) @ ( numeral_numeral @ A @ Y ) ) ) ) ) ) ).
% or_numerals(7)
thf(fact_3314_bit_Odisj__zero__right,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [X: A] :
( ( bit_se1065995026697491101ons_or @ A @ X @ ( zero_zero @ A ) )
= X ) ) ).
% bit.disj_zero_right
thf(fact_3315_or__eq__0__iff,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A,B2: A] :
( ( ( bit_se1065995026697491101ons_or @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
= ( ( A3
= ( zero_zero @ A ) )
& ( B2
= ( zero_zero @ A ) ) ) ) ) ).
% or_eq_0_iff
thf(fact_3316_sum_Onon__neutral_H,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: B > A,I6: set @ B] :
( ( groups1027152243600224163dd_sum @ B @ A @ G
@ ( collect @ B
@ ^ [X2: B] :
( ( member2 @ B @ X2 @ I6 )
& ( ( G @ X2 )
!= ( zero_zero @ A ) ) ) ) )
= ( groups1027152243600224163dd_sum @ B @ A @ G @ I6 ) ) ) ).
% sum.non_neutral'
thf(fact_3317_disjunctive__add,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A,B2: A] :
( ! [N3: nat] :
( ~ ( bit_se5641148757651400278ts_bit @ A @ A3 @ N3 )
| ~ ( bit_se5641148757651400278ts_bit @ A @ B2 @ N3 ) )
=> ( ( plus_plus @ A @ A3 @ B2 )
= ( bit_se1065995026697491101ons_or @ A @ A3 @ B2 ) ) ) ) ).
% disjunctive_add
thf(fact_3318_sum_Odistrib__triv_H,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [I6: set @ B,G: B > A,H2: B > A] :
( ( finite_finite @ B @ I6 )
=> ( ( groups1027152243600224163dd_sum @ B @ A
@ ^ [I5: B] : ( plus_plus @ A @ ( G @ I5 ) @ ( H2 @ I5 ) )
@ I6 )
= ( plus_plus @ A @ ( groups1027152243600224163dd_sum @ B @ A @ G @ I6 ) @ ( groups1027152243600224163dd_sum @ B @ A @ H2 @ I6 ) ) ) ) ) ).
% sum.distrib_triv'
thf(fact_3319_sum_Omono__neutral__cong__right_H,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [S3: set @ B,T4: set @ B,G: B > A,H2: B > A] :
( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( G @ X5 )
= ( zero_zero @ A ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ S3 )
=> ( ( G @ X5 )
= ( H2 @ X5 ) ) )
=> ( ( groups1027152243600224163dd_sum @ B @ A @ G @ T4 )
= ( groups1027152243600224163dd_sum @ B @ A @ H2 @ S3 ) ) ) ) ) ) ).
% sum.mono_neutral_cong_right'
thf(fact_3320_sum_Omono__neutral__cong__left_H,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [S3: set @ B,T4: set @ B,H2: B > A,G: B > A] :
( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( H2 @ I3 )
= ( zero_zero @ A ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ S3 )
=> ( ( G @ X5 )
= ( H2 @ X5 ) ) )
=> ( ( groups1027152243600224163dd_sum @ B @ A @ G @ S3 )
= ( groups1027152243600224163dd_sum @ B @ A @ H2 @ T4 ) ) ) ) ) ) ).
% sum.mono_neutral_cong_left'
thf(fact_3321_sum_Omono__neutral__right_H,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [S3: set @ B,T4: set @ B,G: B > A] :
( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( G @ X5 )
= ( zero_zero @ A ) ) )
=> ( ( groups1027152243600224163dd_sum @ B @ A @ G @ T4 )
= ( groups1027152243600224163dd_sum @ B @ A @ G @ S3 ) ) ) ) ) ).
% sum.mono_neutral_right'
thf(fact_3322_sum_Omono__neutral__left_H,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [S3: set @ B,T4: set @ B,G: B > A] :
( ( ord_less_eq @ ( set @ B ) @ S3 @ T4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( G @ X5 )
= ( zero_zero @ A ) ) )
=> ( ( groups1027152243600224163dd_sum @ B @ A @ G @ S3 )
= ( groups1027152243600224163dd_sum @ B @ A @ G @ T4 ) ) ) ) ) ).
% sum.mono_neutral_left'
thf(fact_3323_sinh__add,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( ( sinh @ A @ ( plus_plus @ A @ X @ Y ) )
= ( plus_plus @ A @ ( times_times @ A @ ( sinh @ A @ X ) @ ( cosh @ A @ Y ) ) @ ( times_times @ A @ ( cosh @ A @ X ) @ ( sinh @ A @ Y ) ) ) ) ) ).
% sinh_add
thf(fact_3324_cosh__add,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,Y: A] :
( ( cosh @ A @ ( plus_plus @ A @ X @ Y ) )
= ( plus_plus @ A @ ( times_times @ A @ ( cosh @ A @ X ) @ ( cosh @ A @ Y ) ) @ ( times_times @ A @ ( sinh @ A @ X ) @ ( sinh @ A @ Y ) ) ) ) ) ).
% cosh_add
thf(fact_3325_bit_Ocomplement__unique,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [A3: A,X: A,Y: A] :
( ( ( bit_se5824344872417868541ns_and @ A @ A3 @ X )
= ( zero_zero @ A ) )
=> ( ( ( bit_se1065995026697491101ons_or @ A @ A3 @ X )
= ( uminus_uminus @ A @ ( one_one @ A ) ) )
=> ( ( ( bit_se5824344872417868541ns_and @ A @ A3 @ Y )
= ( zero_zero @ A ) )
=> ( ( ( bit_se1065995026697491101ons_or @ A @ A3 @ Y )
= ( uminus_uminus @ A @ ( one_one @ A ) ) )
=> ( X = Y ) ) ) ) ) ) ).
% bit.complement_unique
thf(fact_3326_sinh__plus__cosh,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ! [X: A] :
( ( plus_plus @ A @ ( sinh @ A @ X ) @ ( cosh @ A @ X ) )
= ( exp @ A @ X ) ) ) ).
% sinh_plus_cosh
thf(fact_3327_cosh__plus__sinh,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V2822296259951069270ebra_1 @ A ) )
=> ! [X: A] :
( ( plus_plus @ A @ ( cosh @ A @ X ) @ ( sinh @ A @ X ) )
= ( exp @ A @ X ) ) ) ).
% cosh_plus_sinh
thf(fact_3328_sum_Odistrib_H,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [I6: set @ B,G: B > A,H2: B > A] :
( ( finite_finite @ B
@ ( collect @ B
@ ^ [X2: B] :
( ( member2 @ B @ X2 @ I6 )
& ( ( G @ X2 )
!= ( zero_zero @ A ) ) ) ) )
=> ( ( finite_finite @ B
@ ( collect @ B
@ ^ [X2: B] :
( ( member2 @ B @ X2 @ I6 )
& ( ( H2 @ X2 )
!= ( zero_zero @ A ) ) ) ) )
=> ( ( groups1027152243600224163dd_sum @ B @ A
@ ^ [I5: B] : ( plus_plus @ A @ ( G @ I5 ) @ ( H2 @ I5 ) )
@ I6 )
= ( plus_plus @ A @ ( groups1027152243600224163dd_sum @ B @ A @ G @ I6 ) @ ( groups1027152243600224163dd_sum @ B @ A @ H2 @ I6 ) ) ) ) ) ) ).
% sum.distrib'
thf(fact_3329_sum_OG__def,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ( ( groups1027152243600224163dd_sum @ B @ A )
= ( ^ [P6: B > A,I8: set @ B] :
( if @ A
@ ( finite_finite @ B
@ ( collect @ B
@ ^ [X2: B] :
( ( member2 @ B @ X2 @ I8 )
& ( ( P6 @ X2 )
!= ( zero_zero @ A ) ) ) ) )
@ ( groups7311177749621191930dd_sum @ B @ A @ P6
@ ( collect @ B
@ ^ [X2: B] :
( ( member2 @ B @ X2 @ I8 )
& ( ( P6 @ X2 )
!= ( zero_zero @ A ) ) ) ) )
@ ( zero_zero @ A ) ) ) ) ) ).
% sum.G_def
thf(fact_3330_mask__Suc__exp,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat] :
( ( bit_se2239418461657761734s_mask @ A @ ( suc @ N2 ) )
= ( bit_se1065995026697491101ons_or @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) @ ( bit_se2239418461657761734s_mask @ A @ N2 ) ) ) ) ).
% mask_Suc_exp
thf(fact_3331_or__one__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se1065995026697491101ons_or @ A @ A3 @ ( one_one @ A ) )
= ( plus_plus @ A @ A3 @ ( zero_neq_one_of_bool @ A @ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) ) ) ) ).
% or_one_eq
thf(fact_3332_one__or__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A] :
( ( bit_se1065995026697491101ons_or @ A @ ( one_one @ A ) @ A3 )
= ( plus_plus @ A @ A3 @ ( zero_neq_one_of_bool @ A @ ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) ) ) ) ).
% one_or_eq
thf(fact_3333_mask__Suc__double,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat] :
( ( bit_se2239418461657761734s_mask @ A @ ( suc @ N2 ) )
= ( bit_se1065995026697491101ons_or @ A @ ( one_one @ A ) @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se2239418461657761734s_mask @ A @ N2 ) ) ) ) ) ).
% mask_Suc_double
thf(fact_3334_sinh__zero__iff,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ( sinh @ A @ X )
= ( zero_zero @ A ) )
= ( member2 @ A @ ( exp @ A @ X ) @ ( insert2 @ A @ ( one_one @ A ) @ ( insert2 @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% sinh_zero_iff
thf(fact_3335_tanh__altdef,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ( ( tanh @ A )
= ( ^ [X2: A] : ( divide_divide @ A @ ( minus_minus @ A @ ( exp @ A @ X2 ) @ ( exp @ A @ ( uminus_uminus @ A @ X2 ) ) ) @ ( plus_plus @ A @ ( exp @ A @ X2 ) @ ( exp @ A @ ( uminus_uminus @ A @ X2 ) ) ) ) ) ) ) ).
% tanh_altdef
thf(fact_3336_sum__diff1_H,axiom,
! [B: $tType,A: $tType] :
( ( ab_group_add @ B )
=> ! [I6: set @ A,F2: A > B,I: A] :
( ( finite_finite @ A
@ ( collect @ A
@ ^ [I5: A] :
( ( member2 @ A @ I5 @ I6 )
& ( ( F2 @ I5 )
!= ( zero_zero @ B ) ) ) ) )
=> ( ( ( member2 @ A @ I @ I6 )
=> ( ( groups1027152243600224163dd_sum @ A @ B @ F2 @ ( minus_minus @ ( set @ A ) @ I6 @ ( insert2 @ A @ I @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( minus_minus @ B @ ( groups1027152243600224163dd_sum @ A @ B @ F2 @ I6 ) @ ( F2 @ I ) ) ) )
& ( ~ ( member2 @ A @ I @ I6 )
=> ( ( groups1027152243600224163dd_sum @ A @ B @ F2 @ ( minus_minus @ ( set @ A ) @ I6 @ ( insert2 @ A @ I @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( groups1027152243600224163dd_sum @ A @ B @ F2 @ I6 ) ) ) ) ) ) ).
% sum_diff1'
thf(fact_3337_or__Suc__0__eq,axiom,
! [N2: nat] :
( ( bit_se1065995026697491101ons_or @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) )
= ( plus_plus @ nat @ N2 @ ( zero_neq_one_of_bool @ nat @ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ).
% or_Suc_0_eq
thf(fact_3338_Suc__0__or__eq,axiom,
! [N2: nat] :
( ( bit_se1065995026697491101ons_or @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
= ( plus_plus @ nat @ N2 @ ( zero_neq_one_of_bool @ nat @ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ) ) ).
% Suc_0_or_eq
thf(fact_3339_or__nat__rec,axiom,
( ( bit_se1065995026697491101ons_or @ nat )
= ( ^ [M2: nat,N: nat] :
( plus_plus @ nat
@ ( zero_neq_one_of_bool @ nat
@ ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ M2 )
| ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) ) )
@ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( bit_se1065995026697491101ons_or @ nat @ ( divide_divide @ nat @ M2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( divide_divide @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% or_nat_rec
thf(fact_3340_cosh__square__eq,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( power_power @ A @ ( cosh @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( plus_plus @ A @ ( power_power @ A @ ( sinh @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ A ) ) ) ) ).
% cosh_square_eq
thf(fact_3341_VEBT_Osize_I3_J,axiom,
! [X11: option @ ( product_prod @ nat @ nat ),X12: nat,X13: list @ vEBT_VEBT,X14: vEBT_VEBT] :
( ( size_size @ vEBT_VEBT @ ( vEBT_Node @ X11 @ X12 @ X13 @ X14 ) )
= ( plus_plus @ nat @ ( plus_plus @ nat @ ( size_list @ vEBT_VEBT @ ( size_size @ vEBT_VEBT ) @ X13 ) @ ( size_size @ vEBT_VEBT @ X14 ) ) @ ( suc @ ( zero_zero @ nat ) ) ) ) ).
% VEBT.size(3)
thf(fact_3342_Cauchy__iff2,axiom,
( ( topolo3814608138187158403Cauchy @ real )
= ( ^ [X8: nat > real] :
! [J3: nat] :
? [M9: nat] :
! [M2: nat] :
( ( ord_less_eq @ nat @ M9 @ M2 )
=> ! [N: nat] :
( ( ord_less_eq @ nat @ M9 @ N )
=> ( ord_less @ real @ ( abs_abs @ real @ ( minus_minus @ real @ ( X8 @ M2 ) @ ( X8 @ N ) ) ) @ ( inverse_inverse @ real @ ( semiring_1_of_nat @ real @ ( suc @ J3 ) ) ) ) ) ) ) ) ).
% Cauchy_iff2
thf(fact_3343_sum__power2,axiom,
! [K: nat] :
( ( groups7311177749621191930dd_sum @ nat @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ K ) )
= ( minus_minus @ nat @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ K ) @ ( one_one @ nat ) ) ) ).
% sum_power2
thf(fact_3344_is__singleton__the__elem,axiom,
! [A: $tType] :
( ( is_singleton @ A )
= ( ^ [A6: set @ A] :
( A6
= ( insert2 @ A @ ( the_elem @ A @ A6 ) @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% is_singleton_the_elem
thf(fact_3345_length__subseqs,axiom,
! [A: $tType,Xs: list @ A] :
( ( size_size @ ( list @ ( list @ A ) ) @ ( subseqs @ A @ Xs ) )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ) ).
% length_subseqs
thf(fact_3346_atLeastLessThan__iff,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [I: A,L: A,U: A] :
( ( member2 @ A @ I @ ( set_or7035219750837199246ssThan @ A @ L @ U ) )
= ( ( ord_less_eq @ A @ L @ I )
& ( ord_less @ A @ I @ U ) ) ) ) ).
% atLeastLessThan_iff
thf(fact_3347_atLeastLessThan__empty,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( set_or7035219750837199246ssThan @ A @ A3 @ B2 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% atLeastLessThan_empty
thf(fact_3348_ivl__subset,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [I: A,J: A,M: A,N2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ I @ J ) @ ( set_or7035219750837199246ssThan @ A @ M @ N2 ) )
= ( ( ord_less_eq @ A @ J @ I )
| ( ( ord_less_eq @ A @ M @ I )
& ( ord_less_eq @ A @ J @ N2 ) ) ) ) ) ).
% ivl_subset
thf(fact_3349_atLeastLessThan__empty__iff,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A] :
( ( ( set_or7035219750837199246ssThan @ A @ A3 @ B2 )
= ( bot_bot @ ( set @ A ) ) )
= ( ~ ( ord_less @ A @ A3 @ B2 ) ) ) ) ).
% atLeastLessThan_empty_iff
thf(fact_3350_atLeastLessThan__empty__iff2,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A] :
( ( ( bot_bot @ ( set @ A ) )
= ( set_or7035219750837199246ssThan @ A @ A3 @ B2 ) )
= ( ~ ( ord_less @ A @ A3 @ B2 ) ) ) ) ).
% atLeastLessThan_empty_iff2
thf(fact_3351_infinite__Ico__iff,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A] :
( ( ~ ( finite_finite @ A @ ( set_or7035219750837199246ssThan @ A @ A3 @ B2 ) ) )
= ( ord_less @ A @ A3 @ B2 ) ) ) ).
% infinite_Ico_iff
thf(fact_3352_ivl__diff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [I: A,N2: A,M: A] :
( ( ord_less_eq @ A @ I @ N2 )
=> ( ( minus_minus @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ I @ M ) @ ( set_or7035219750837199246ssThan @ A @ I @ N2 ) )
= ( set_or7035219750837199246ssThan @ A @ N2 @ M ) ) ) ) ).
% ivl_diff
thf(fact_3353_is__singletonI,axiom,
! [A: $tType,X: A] : ( is_singleton @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ).
% is_singletonI
thf(fact_3354_atLeastLessThan__singleton,axiom,
! [M: nat] :
( ( set_or7035219750837199246ssThan @ nat @ M @ ( suc @ M ) )
= ( insert2 @ nat @ M @ ( bot_bot @ ( set @ nat ) ) ) ) ).
% atLeastLessThan_singleton
thf(fact_3355_sum_Oop__ivl__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [N2: nat,M: nat,G: nat > A] :
( ( ( ord_less @ nat @ N2 @ M )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ ( suc @ N2 ) ) )
= ( zero_zero @ A ) ) )
& ( ~ ( ord_less @ nat @ N2 @ M )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) @ ( G @ N2 ) ) ) ) ) ) ).
% sum.op_ivl_Suc
thf(fact_3356_prod_Oop__ivl__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [N2: nat,M: nat,G: nat > A] :
( ( ( ord_less @ nat @ N2 @ M )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ ( suc @ N2 ) ) )
= ( one_one @ A ) ) )
& ( ~ ( ord_less @ nat @ N2 @ M )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) @ ( G @ N2 ) ) ) ) ) ) ).
% prod.op_ivl_Suc
thf(fact_3357_atLeastLessThan__eq__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ C2 @ D2 )
=> ( ( ( set_or7035219750837199246ssThan @ A @ A3 @ B2 )
= ( set_or7035219750837199246ssThan @ A @ C2 @ D2 ) )
= ( ( A3 = C2 )
& ( B2 = D2 ) ) ) ) ) ) ).
% atLeastLessThan_eq_iff
thf(fact_3358_atLeastLessThan__inj_I1_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ( set_or7035219750837199246ssThan @ A @ A3 @ B2 )
= ( set_or7035219750837199246ssThan @ A @ C2 @ D2 ) )
=> ( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ C2 @ D2 )
=> ( A3 = C2 ) ) ) ) ) ).
% atLeastLessThan_inj(1)
thf(fact_3359_atLeastLessThan__inj_I2_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ( set_or7035219750837199246ssThan @ A @ A3 @ B2 )
= ( set_or7035219750837199246ssThan @ A @ C2 @ D2 ) )
=> ( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ C2 @ D2 )
=> ( B2 = D2 ) ) ) ) ) ).
% atLeastLessThan_inj(2)
thf(fact_3360_subseqs__refl,axiom,
! [A: $tType,Xs: list @ A] : ( member2 @ ( list @ A ) @ Xs @ ( set2 @ ( list @ A ) @ ( subseqs @ A @ Xs ) ) ) ).
% subseqs_refl
thf(fact_3361_atLeastLessThan__subset__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ A3 @ B2 ) @ ( set_or7035219750837199246ssThan @ A @ C2 @ D2 ) )
=> ( ( ord_less_eq @ A @ B2 @ A3 )
| ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less_eq @ A @ B2 @ D2 ) ) ) ) ) ).
% atLeastLessThan_subset_iff
thf(fact_3362_infinite__Ico,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ~ ( finite_finite @ A @ ( set_or7035219750837199246ssThan @ A @ A3 @ B2 ) ) ) ) ).
% infinite_Ico
thf(fact_3363_all__nat__less__eq,axiom,
! [N2: nat,P2: nat > $o] :
( ( ! [M2: nat] :
( ( ord_less @ nat @ M2 @ N2 )
=> ( P2 @ M2 ) ) )
= ( ! [X2: nat] :
( ( member2 @ nat @ X2 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) )
=> ( P2 @ X2 ) ) ) ) ).
% all_nat_less_eq
thf(fact_3364_ex__nat__less__eq,axiom,
! [N2: nat,P2: nat > $o] :
( ( ? [M2: nat] :
( ( ord_less @ nat @ M2 @ N2 )
& ( P2 @ M2 ) ) )
= ( ? [X2: nat] :
( ( member2 @ nat @ X2 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) )
& ( P2 @ X2 ) ) ) ) ).
% ex_nat_less_eq
thf(fact_3365_atLeastLessThanSuc__atLeastAtMost,axiom,
! [L: nat,U: nat] :
( ( set_or7035219750837199246ssThan @ nat @ L @ ( suc @ U ) )
= ( set_or1337092689740270186AtMost @ nat @ L @ U ) ) ).
% atLeastLessThanSuc_atLeastAtMost
thf(fact_3366_lessThan__atLeast0,axiom,
( ( set_ord_lessThan @ nat )
= ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) ) ) ).
% lessThan_atLeast0
thf(fact_3367_atLeastLessThan0,axiom,
! [M: nat] :
( ( set_or7035219750837199246ssThan @ nat @ M @ ( zero_zero @ nat ) )
= ( bot_bot @ ( set @ nat ) ) ) ).
% atLeastLessThan0
thf(fact_3368_sum_Oshift__bounds__Suc__ivl,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ).
% sum.shift_bounds_Suc_ivl
thf(fact_3369_sum_Oshift__bounds__nat__ivl,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,K: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( plus_plus @ nat @ M @ K ) @ ( plus_plus @ nat @ N2 @ K ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( plus_plus @ nat @ I5 @ K ) )
@ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ).
% sum.shift_bounds_nat_ivl
thf(fact_3370_prod_Oshift__bounds__Suc__ivl,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( suc @ I5 ) )
@ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ).
% prod.shift_bounds_Suc_ivl
thf(fact_3371_prod_Oshift__bounds__nat__ivl,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,K: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( plus_plus @ nat @ M @ K ) @ ( plus_plus @ nat @ N2 @ K ) ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( plus_plus @ nat @ I5 @ K ) )
@ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ).
% prod.shift_bounds_nat_ivl
thf(fact_3372_is__singletonI_H,axiom,
! [A: $tType,A4: set @ A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ( member2 @ A @ Y4 @ A4 )
=> ( X5 = Y4 ) ) )
=> ( is_singleton @ A @ A4 ) ) ) ).
% is_singletonI'
thf(fact_3373_sum_Oivl__cong,axiom,
! [A: $tType,B: $tType] :
( ( ( ord @ B )
& ( comm_monoid_add @ A ) )
=> ! [A3: B,C2: B,B2: B,D2: B,G: B > A,H2: B > A] :
( ( A3 = C2 )
=> ( ( B2 = D2 )
=> ( ! [X5: B] :
( ( ord_less_eq @ B @ C2 @ X5 )
=> ( ( ord_less @ B @ X5 @ D2 )
=> ( ( G @ X5 )
= ( H2 @ X5 ) ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( set_or7035219750837199246ssThan @ B @ A3 @ B2 ) )
= ( groups7311177749621191930dd_sum @ B @ A @ H2 @ ( set_or7035219750837199246ssThan @ B @ C2 @ D2 ) ) ) ) ) ) ) ).
% sum.ivl_cong
thf(fact_3374_prod_Oivl__cong,axiom,
! [A: $tType,B: $tType] :
( ( ( ord @ B )
& ( comm_monoid_mult @ A ) )
=> ! [A3: B,C2: B,B2: B,D2: B,G: B > A,H2: B > A] :
( ( A3 = C2 )
=> ( ( B2 = D2 )
=> ( ! [X5: B] :
( ( ord_less_eq @ B @ C2 @ X5 )
=> ( ( ord_less @ B @ X5 @ D2 )
=> ( ( G @ X5 )
= ( H2 @ X5 ) ) ) )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ ( set_or7035219750837199246ssThan @ B @ A3 @ B2 ) )
= ( groups7121269368397514597t_prod @ B @ A @ H2 @ ( set_or7035219750837199246ssThan @ B @ C2 @ D2 ) ) ) ) ) ) ) ).
% prod.ivl_cong
thf(fact_3375_sum_OatLeastLessThan__concat,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [M: nat,N2: nat,P4: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( ord_less_eq @ nat @ N2 @ P4 )
=> ( ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ N2 @ P4 ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ P4 ) ) ) ) ) ) ).
% sum.atLeastLessThan_concat
thf(fact_3376_sum__diff__nat__ivl,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [M: nat,N2: nat,P4: nat,F2: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( ord_less_eq @ nat @ N2 @ P4 )
=> ( ( minus_minus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or7035219750837199246ssThan @ nat @ M @ P4 ) ) @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or7035219750837199246ssThan @ nat @ N2 @ P4 ) ) ) ) ) ) ).
% sum_diff_nat_ivl
thf(fact_3377_size__list__estimation,axiom,
! [A: $tType,X: A,Xs: list @ A,Y: nat,F2: A > nat] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( ord_less @ nat @ Y @ ( F2 @ X ) )
=> ( ord_less @ nat @ Y @ ( size_list @ A @ F2 @ Xs ) ) ) ) ).
% size_list_estimation
thf(fact_3378_size__list__pointwise,axiom,
! [A: $tType,Xs: list @ A,F2: A > nat,G: A > nat] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ord_less_eq @ nat @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ord_less_eq @ nat @ ( size_list @ A @ F2 @ Xs ) @ ( size_list @ A @ G @ Xs ) ) ) ).
% size_list_pointwise
thf(fact_3379_size__list__estimation_H,axiom,
! [A: $tType,X: A,Xs: list @ A,Y: nat,F2: A > nat] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( ord_less_eq @ nat @ Y @ ( F2 @ X ) )
=> ( ord_less_eq @ nat @ Y @ ( size_list @ A @ F2 @ Xs ) ) ) ) ).
% size_list_estimation'
thf(fact_3380_prod_OatLeastLessThan__concat,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [M: nat,N2: nat,P4: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( ord_less_eq @ nat @ N2 @ P4 )
=> ( ( times_times @ A @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ N2 @ P4 ) ) )
= ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ P4 ) ) ) ) ) ) ).
% prod.atLeastLessThan_concat
thf(fact_3381_atLeast0__lessThan__Suc,axiom,
! [N2: nat] :
( ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) )
= ( insert2 @ nat @ N2 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ).
% atLeast0_lessThan_Suc
thf(fact_3382_subset__eq__atLeast0__lessThan__finite,axiom,
! [N7: set @ nat,N2: nat] :
( ( ord_less_eq @ ( set @ nat ) @ N7 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) )
=> ( finite_finite @ nat @ N7 ) ) ).
% subset_eq_atLeast0_lessThan_finite
thf(fact_3383_atLeastAtMost__subseteq__atLeastLessThan__iff,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ ( set_or7035219750837199246ssThan @ A @ C2 @ D2 ) )
= ( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less @ A @ B2 @ D2 ) ) ) ) ) ).
% atLeastAtMost_subseteq_atLeastLessThan_iff
thf(fact_3384_atLeastLessThan__subseteq__atLeastAtMost__iff,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ A3 @ B2 ) @ ( set_or1337092689740270186AtMost @ A @ C2 @ D2 ) )
= ( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less_eq @ A @ B2 @ D2 ) ) ) ) ) ).
% atLeastLessThan_subseteq_atLeastAtMost_iff
thf(fact_3385_sum__shift__lb__Suc0__0__upt,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [F2: nat > A,K: nat] :
( ( ( F2 @ ( zero_zero @ nat ) )
= ( zero_zero @ A ) )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or7035219750837199246ssThan @ nat @ ( suc @ ( zero_zero @ nat ) ) @ K ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ K ) ) ) ) ) ).
% sum_shift_lb_Suc0_0_upt
thf(fact_3386_sum_OatLeast0__lessThan__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) @ ( G @ N2 ) ) ) ) ).
% sum.atLeast0_lessThan_Suc
thf(fact_3387_sum_OatLeast__Suc__lessThan,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less @ nat @ M @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) )
= ( plus_plus @ A @ ( G @ M ) @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( suc @ M ) @ N2 ) ) ) ) ) ) ).
% sum.atLeast_Suc_lessThan
thf(fact_3388_sum_OatLeastLessThan__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [A3: nat,B2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ A3 @ B2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ A3 @ ( suc @ B2 ) ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ A3 @ B2 ) ) @ ( G @ B2 ) ) ) ) ) ).
% sum.atLeastLessThan_Suc
thf(fact_3389_atLeastLessThan__eq__atLeastAtMost__diff,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( set_or7035219750837199246ssThan @ A )
= ( ^ [A5: A,B4: A] : ( minus_minus @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ A5 @ B4 ) @ ( insert2 @ A @ B4 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% atLeastLessThan_eq_atLeastAtMost_diff
thf(fact_3390_prod_OatLeast0__lessThan__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) @ ( G @ N2 ) ) ) ) ).
% prod.atLeast0_lessThan_Suc
thf(fact_3391_prod_OatLeast__Suc__lessThan,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less @ nat @ M @ N2 )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) )
= ( times_times @ A @ ( G @ M ) @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( suc @ M ) @ N2 ) ) ) ) ) ) ).
% prod.atLeast_Suc_lessThan
thf(fact_3392_prod_OatLeastLessThan__Suc,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: nat,B2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ A3 @ B2 )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ A3 @ ( suc @ B2 ) ) )
= ( times_times @ A @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ A3 @ B2 ) ) @ ( G @ B2 ) ) ) ) ) ).
% prod.atLeastLessThan_Suc
thf(fact_3393_sum_Olast__plus,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( plus_plus @ A @ ( G @ N2 ) @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ) ) ).
% sum.last_plus
thf(fact_3394_prod_Olast__plus,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( times_times @ A @ ( G @ N2 ) @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ) ) ).
% prod.last_plus
thf(fact_3395_sum__Suc__diff_H,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [M: nat,N2: nat,F2: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( minus_minus @ A @ ( F2 @ ( suc @ I5 ) ) @ ( F2 @ I5 ) )
@ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) )
= ( minus_minus @ A @ ( F2 @ N2 ) @ ( F2 @ M ) ) ) ) ) ).
% sum_Suc_diff'
thf(fact_3396_sum_OatLeastLessThan__rev,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat,M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ N2 @ M ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( minus_minus @ nat @ ( plus_plus @ nat @ M @ N2 ) @ ( suc @ I5 ) ) )
@ ( set_or7035219750837199246ssThan @ nat @ N2 @ M ) ) ) ) ).
% sum.atLeastLessThan_rev
thf(fact_3397_atLeastLessThanSuc,axiom,
! [M: nat,N2: nat] :
( ( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( set_or7035219750837199246ssThan @ nat @ M @ ( suc @ N2 ) )
= ( insert2 @ nat @ N2 @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) )
& ( ~ ( ord_less_eq @ nat @ M @ N2 )
=> ( ( set_or7035219750837199246ssThan @ nat @ M @ ( suc @ N2 ) )
= ( bot_bot @ ( set @ nat ) ) ) ) ) ).
% atLeastLessThanSuc
thf(fact_3398_sum_Onested__swap,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [A3: nat > nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( groups7311177749621191930dd_sum @ nat @ A @ ( A3 @ I5 ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [J3: nat] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( A3 @ I5 @ J3 )
@ ( set_or1337092689740270186AtMost @ nat @ ( suc @ J3 ) @ N2 ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% sum.nested_swap
thf(fact_3399_prod_OatLeastLessThan__rev,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat,M: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ N2 @ M ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( minus_minus @ nat @ ( plus_plus @ nat @ M @ N2 ) @ ( suc @ I5 ) ) )
@ ( set_or7035219750837199246ssThan @ nat @ N2 @ M ) ) ) ) ).
% prod.atLeastLessThan_rev
thf(fact_3400_prod_Onested__swap,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A3: nat > nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( groups7121269368397514597t_prod @ nat @ A @ ( A3 @ I5 ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [J3: nat] :
( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( A3 @ I5 @ J3 )
@ ( set_or1337092689740270186AtMost @ nat @ ( suc @ J3 ) @ N2 ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% prod.nested_swap
thf(fact_3401_sum_Onat__group,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,K: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [M2: nat] : ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( times_times @ nat @ M2 @ K ) @ ( plus_plus @ nat @ ( times_times @ nat @ M2 @ K ) @ K ) ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_ord_lessThan @ nat @ ( times_times @ nat @ N2 @ K ) ) ) ) ) ).
% sum.nat_group
thf(fact_3402_prod_Onat__group,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,K: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A
@ ^ [M2: nat] : ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( times_times @ nat @ M2 @ K ) @ ( plus_plus @ nat @ ( times_times @ nat @ M2 @ K ) @ K ) ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
= ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_ord_lessThan @ nat @ ( times_times @ nat @ N2 @ K ) ) ) ) ) ).
% prod.nat_group
thf(fact_3403_prod__Suc__Suc__fact,axiom,
! [N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ nat @ suc @ ( set_or7035219750837199246ssThan @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 ) )
= ( semiring_char_0_fact @ nat @ N2 ) ) ).
% prod_Suc_Suc_fact
thf(fact_3404_prod__Suc__fact,axiom,
! [N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ nat @ suc @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) )
= ( semiring_char_0_fact @ nat @ N2 ) ) ).
% prod_Suc_fact
thf(fact_3405_is__singletonE,axiom,
! [A: $tType,A4: set @ A] :
( ( is_singleton @ A @ A4 )
=> ~ ! [X5: A] :
( A4
!= ( insert2 @ A @ X5 @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% is_singletonE
thf(fact_3406_is__singleton__def,axiom,
! [A: $tType] :
( ( is_singleton @ A )
= ( ^ [A6: set @ A] :
? [X2: A] :
( A6
= ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% is_singleton_def
thf(fact_3407_sum_Ohead__if,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [N2: nat,M: nat,G: nat > A] :
( ( ( ord_less @ nat @ N2 @ M )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( zero_zero @ A ) ) )
& ( ~ ( ord_less @ nat @ N2 @ M )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) @ ( G @ N2 ) ) ) ) ) ) ).
% sum.head_if
thf(fact_3408_prod_Ohead__if,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [N2: nat,M: nat,G: nat > A] :
( ( ( ord_less @ nat @ N2 @ M )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( one_one @ A ) ) )
& ( ~ ( ord_less @ nat @ N2 @ M )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( times_times @ A @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) @ ( G @ N2 ) ) ) ) ) ) ).
% prod.head_if
thf(fact_3409_fact__prod__Suc,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ( ( semiring_char_0_fact @ A )
= ( ^ [N: nat] : ( semiring_1_of_nat @ A @ ( groups7121269368397514597t_prod @ nat @ nat @ suc @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N ) ) ) ) ) ) ).
% fact_prod_Suc
thf(fact_3410_sum_OatLeastLessThan__rev__at__least__Suc__atMost,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat,M: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ N2 @ M ) )
= ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( G @ ( minus_minus @ nat @ ( plus_plus @ nat @ M @ N2 ) @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( suc @ N2 ) @ M ) ) ) ) ).
% sum.atLeastLessThan_rev_at_least_Suc_atMost
thf(fact_3411_prod_OatLeastLessThan__rev__at__least__Suc__atMost,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat,M: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ N2 @ M ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( G @ ( minus_minus @ nat @ ( plus_plus @ nat @ M @ N2 ) @ I5 ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( suc @ N2 ) @ M ) ) ) ) ).
% prod.atLeastLessThan_rev_at_least_Suc_atMost
thf(fact_3412_pochhammer__prod,axiom,
! [A: $tType] :
( ( comm_semiring_1 @ A )
=> ( ( comm_s3205402744901411588hammer @ A )
= ( ^ [A5: A,N: nat] :
( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( plus_plus @ A @ A5 @ ( semiring_1_of_nat @ A @ I5 ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N ) ) ) ) ) ).
% pochhammer_prod
thf(fact_3413_atLeastLessThan__nat__numeral,axiom,
! [M: nat,K: num] :
( ( ( ord_less_eq @ nat @ M @ ( pred_numeral @ K ) )
=> ( ( set_or7035219750837199246ssThan @ nat @ M @ ( numeral_numeral @ nat @ K ) )
= ( insert2 @ nat @ ( pred_numeral @ K ) @ ( set_or7035219750837199246ssThan @ nat @ M @ ( pred_numeral @ K ) ) ) ) )
& ( ~ ( ord_less_eq @ nat @ M @ ( pred_numeral @ K ) )
=> ( ( set_or7035219750837199246ssThan @ nat @ M @ ( numeral_numeral @ nat @ K ) )
= ( bot_bot @ ( set @ nat ) ) ) ) ) ).
% atLeastLessThan_nat_numeral
thf(fact_3414_fact__prod__rev,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ( ( semiring_char_0_fact @ A )
= ( ^ [N: nat] : ( semiring_1_of_nat @ A @ ( groups7121269368397514597t_prod @ nat @ nat @ ( minus_minus @ nat @ N ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N ) ) ) ) ) ) ).
% fact_prod_rev
thf(fact_3415_summable__Cauchy,axiom,
! [A: $tType] :
( ( real_Vector_banach @ A )
=> ( ( summable @ A )
= ( ^ [F3: nat > A] :
! [E4: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E4 )
=> ? [N6: nat] :
! [M2: nat] :
( ( ord_less_eq @ nat @ N6 @ M2 )
=> ! [N: nat] : ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F3 @ ( set_or7035219750837199246ssThan @ nat @ M2 @ N ) ) ) @ E4 ) ) ) ) ) ) ).
% summable_Cauchy
thf(fact_3416_CauchyD,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X7: nat > A,E3: real] :
( ( topolo3814608138187158403Cauchy @ A @ X7 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ E3 )
=> ? [M8: nat] :
! [M4: nat] :
( ( ord_less_eq @ nat @ M8 @ M4 )
=> ! [N5: nat] :
( ( ord_less_eq @ nat @ M8 @ N5 )
=> ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ ( X7 @ M4 ) @ ( X7 @ N5 ) ) ) @ E3 ) ) ) ) ) ) ).
% CauchyD
thf(fact_3417_CauchyI,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X7: nat > A] :
( ! [E: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E )
=> ? [M10: nat] :
! [M3: nat] :
( ( ord_less_eq @ nat @ M10 @ M3 )
=> ! [N3: nat] :
( ( ord_less_eq @ nat @ M10 @ N3 )
=> ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ ( X7 @ M3 ) @ ( X7 @ N3 ) ) ) @ E ) ) ) )
=> ( topolo3814608138187158403Cauchy @ A @ X7 ) ) ) ).
% CauchyI
thf(fact_3418_Cauchy__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ( ( topolo3814608138187158403Cauchy @ A )
= ( ^ [X8: nat > A] :
! [E4: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E4 )
=> ? [M9: nat] :
! [M2: nat] :
( ( ord_less_eq @ nat @ M9 @ M2 )
=> ! [N: nat] :
( ( ord_less_eq @ nat @ M9 @ N )
=> ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ ( X8 @ M2 ) @ ( X8 @ N ) ) ) @ E4 ) ) ) ) ) ) ) ).
% Cauchy_iff
thf(fact_3419_sums__group,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [F2: nat > A,S: A,K: nat] :
( ( sums @ A @ F2 @ S )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( sums @ A
@ ^ [N: nat] : ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or7035219750837199246ssThan @ nat @ ( times_times @ nat @ N @ K ) @ ( plus_plus @ nat @ ( times_times @ nat @ N @ K ) @ K ) ) )
@ S ) ) ) ) ).
% sums_group
thf(fact_3420_atLeast1__lessThan__eq__remove0,axiom,
! [N2: nat] :
( ( set_or7035219750837199246ssThan @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 )
= ( minus_minus @ ( set @ nat ) @ ( set_ord_lessThan @ nat @ N2 ) @ ( insert2 @ nat @ ( zero_zero @ nat ) @ ( bot_bot @ ( set @ nat ) ) ) ) ) ).
% atLeast1_lessThan_eq_remove0
thf(fact_3421_fact__split,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( semiring_char_0_fact @ A @ N2 )
= ( times_times @ A @ ( semiring_1_of_nat @ A @ ( groups7121269368397514597t_prod @ nat @ nat @ suc @ ( set_or7035219750837199246ssThan @ nat @ ( minus_minus @ nat @ N2 @ K ) @ N2 ) ) ) @ ( semiring_char_0_fact @ A @ ( minus_minus @ nat @ N2 @ K ) ) ) ) ) ) ).
% fact_split
thf(fact_3422_binomial__altdef__of__nat,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [K: nat,N2: nat] :
( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( semiring_1_of_nat @ A @ ( binomial @ N2 @ K ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( divide_divide @ A @ ( semiring_1_of_nat @ A @ ( minus_minus @ nat @ N2 @ I5 ) ) @ ( semiring_1_of_nat @ A @ ( minus_minus @ nat @ K @ I5 ) ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ K ) ) ) ) ) ).
% binomial_altdef_of_nat
thf(fact_3423_gbinomial__altdef__of__nat,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ( ( gbinomial @ A )
= ( ^ [A5: A,K2: nat] :
( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( divide_divide @ A @ ( minus_minus @ A @ A5 @ ( semiring_1_of_nat @ A @ I5 ) ) @ ( semiring_1_of_nat @ A @ ( minus_minus @ nat @ K2 @ I5 ) ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ K2 ) ) ) ) ) ).
% gbinomial_altdef_of_nat
thf(fact_3424_gbinomial__mult__fact,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [K: nat,A3: A] :
( ( times_times @ A @ ( semiring_char_0_fact @ A @ K ) @ ( gbinomial @ A @ A3 @ K ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( minus_minus @ A @ A3 @ ( semiring_1_of_nat @ A @ I5 ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ K ) ) ) ) ).
% gbinomial_mult_fact
thf(fact_3425_gbinomial__mult__fact_H,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,K: nat] :
( ( times_times @ A @ ( gbinomial @ A @ A3 @ K ) @ ( semiring_char_0_fact @ A @ K ) )
= ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( minus_minus @ A @ A3 @ ( semiring_1_of_nat @ A @ I5 ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ K ) ) ) ) ).
% gbinomial_mult_fact'
thf(fact_3426_gbinomial__prod__rev,axiom,
! [A: $tType] :
( ( ( semiring_char_0 @ A )
& ( semidom_divide @ A ) )
=> ( ( gbinomial @ A )
= ( ^ [A5: A,K2: nat] :
( divide_divide @ A
@ ( groups7121269368397514597t_prod @ nat @ A
@ ^ [I5: nat] : ( minus_minus @ A @ A5 @ ( semiring_1_of_nat @ A @ I5 ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ K2 ) )
@ ( semiring_char_0_fact @ A @ K2 ) ) ) ) ) ).
% gbinomial_prod_rev
thf(fact_3427_horner__sum__eq__sum,axiom,
! [A: $tType,B: $tType] :
( ( comm_semiring_1 @ A )
=> ( ( groups4207007520872428315er_sum @ B @ A )
= ( ^ [F3: B > A,A5: A,Xs2: list @ B] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [N: nat] : ( times_times @ A @ ( F3 @ ( nth @ B @ Xs2 @ N ) ) @ ( power_power @ A @ A5 @ N ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( size_size @ ( list @ B ) @ Xs2 ) ) ) ) ) ) ).
% horner_sum_eq_sum
thf(fact_3428_Chebyshev__sum__upper,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: nat,A3: nat > A,B2: nat > A] :
( ! [I3: nat,J2: nat] :
( ( ord_less_eq @ nat @ I3 @ J2 )
=> ( ( ord_less @ nat @ J2 @ N2 )
=> ( ord_less_eq @ A @ ( A3 @ I3 ) @ ( A3 @ J2 ) ) ) )
=> ( ! [I3: nat,J2: nat] :
( ( ord_less_eq @ nat @ I3 @ J2 )
=> ( ( ord_less @ nat @ J2 @ N2 )
=> ( ord_less_eq @ A @ ( B2 @ J2 ) @ ( B2 @ I3 ) ) ) )
=> ( ord_less_eq @ A
@ ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 )
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( times_times @ A @ ( A3 @ K2 ) @ ( B2 @ K2 ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) )
@ ( times_times @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ A3 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) @ ( groups7311177749621191930dd_sum @ nat @ A @ B2 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ) ) ) ).
% Chebyshev_sum_upper
thf(fact_3429_Chebyshev__sum__upper__nat,axiom,
! [N2: nat,A3: nat > nat,B2: nat > nat] :
( ! [I3: nat,J2: nat] :
( ( ord_less_eq @ nat @ I3 @ J2 )
=> ( ( ord_less @ nat @ J2 @ N2 )
=> ( ord_less_eq @ nat @ ( A3 @ I3 ) @ ( A3 @ J2 ) ) ) )
=> ( ! [I3: nat,J2: nat] :
( ( ord_less_eq @ nat @ I3 @ J2 )
=> ( ( ord_less @ nat @ J2 @ N2 )
=> ( ord_less_eq @ nat @ ( B2 @ J2 ) @ ( B2 @ I3 ) ) ) )
=> ( ord_less_eq @ nat
@ ( times_times @ nat @ N2
@ ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [I5: nat] : ( times_times @ nat @ ( A3 @ I5 ) @ ( B2 @ I5 ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) )
@ ( times_times @ nat @ ( groups7311177749621191930dd_sum @ nat @ nat @ A3 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) @ ( groups7311177749621191930dd_sum @ nat @ nat @ B2 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ) ) ).
% Chebyshev_sum_upper_nat
thf(fact_3430_VEBT_Osize__gen_I1_J,axiom,
! [X11: option @ ( product_prod @ nat @ nat ),X12: nat,X13: list @ vEBT_VEBT,X14: vEBT_VEBT] :
( ( vEBT_size_VEBT @ ( vEBT_Node @ X11 @ X12 @ X13 @ X14 ) )
= ( plus_plus @ nat @ ( plus_plus @ nat @ ( size_list @ vEBT_VEBT @ vEBT_size_VEBT @ X13 ) @ ( vEBT_size_VEBT @ X14 ) ) @ ( suc @ ( zero_zero @ nat ) ) ) ) ).
% VEBT.size_gen(1)
thf(fact_3431_length__mul__elem,axiom,
! [A: $tType,Xs: list @ ( list @ A ),N2: nat] :
( ! [X5: list @ A] :
( ( member2 @ ( list @ A ) @ X5 @ ( set2 @ ( list @ A ) @ Xs ) )
=> ( ( size_size @ ( list @ A ) @ X5 )
= N2 ) )
=> ( ( size_size @ ( list @ A ) @ ( concat @ A @ Xs ) )
= ( times_times @ nat @ ( size_size @ ( list @ ( list @ A ) ) @ Xs ) @ N2 ) ) ) ).
% length_mul_elem
thf(fact_3432_VEBT_Osize__gen_I2_J,axiom,
! [X21: $o,X222: $o] :
( ( vEBT_size_VEBT @ ( vEBT_Leaf @ X21 @ X222 ) )
= ( zero_zero @ nat ) ) ).
% VEBT.size_gen(2)
thf(fact_3433_set__n__lists,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( set2 @ ( list @ A ) @ ( n_lists @ A @ N2 @ Xs ) )
= ( collect @ ( list @ A )
@ ^ [Ys3: list @ A] :
( ( ( size_size @ ( list @ A ) @ Ys3 )
= N2 )
& ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Ys3 ) @ ( set2 @ A @ Xs ) ) ) ) ) ).
% set_n_lists
thf(fact_3434_pair__leqI2,axiom,
! [A3: nat,B2: nat,S: nat,T2: nat] :
( ( ord_less_eq @ nat @ A3 @ B2 )
=> ( ( ord_less_eq @ nat @ S @ T2 )
=> ( member2 @ ( product_prod @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) ) @ ( product_Pair @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ A3 @ S ) @ ( product_Pair @ nat @ nat @ B2 @ T2 ) ) @ fun_pair_leq ) ) ) ).
% pair_leqI2
thf(fact_3435_pair__leqI1,axiom,
! [A3: nat,B2: nat,S: nat,T2: nat] :
( ( ord_less @ nat @ A3 @ B2 )
=> ( member2 @ ( product_prod @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) ) @ ( product_Pair @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ A3 @ S ) @ ( product_Pair @ nat @ nat @ B2 @ T2 ) ) @ fun_pair_leq ) ) ).
% pair_leqI1
thf(fact_3436_case__nat__add__eq__if,axiom,
! [A: $tType,A3: A,F2: nat > A,V2: num,N2: nat] :
( ( case_nat @ A @ A3 @ F2 @ ( plus_plus @ nat @ ( numeral_numeral @ nat @ V2 ) @ N2 ) )
= ( F2 @ ( plus_plus @ nat @ ( pred_numeral @ V2 ) @ N2 ) ) ) ).
% case_nat_add_eq_if
thf(fact_3437_rec__nat__add__eq__if,axiom,
! [A: $tType,A3: A,F2: nat > A > A,V2: num,N2: nat] :
( ( rec_nat @ A @ A3 @ F2 @ ( plus_plus @ nat @ ( numeral_numeral @ nat @ V2 ) @ N2 ) )
= ( F2 @ ( plus_plus @ nat @ ( pred_numeral @ V2 ) @ N2 ) @ ( rec_nat @ A @ A3 @ F2 @ ( plus_plus @ nat @ ( pred_numeral @ V2 ) @ N2 ) ) ) ) ).
% rec_nat_add_eq_if
thf(fact_3438_old_Onat_Osimps_I7_J,axiom,
! [T: $tType,F1: T,F22: nat > T > T,Nat: nat] :
( ( rec_nat @ T @ F1 @ F22 @ ( suc @ Nat ) )
= ( F22 @ Nat @ ( rec_nat @ T @ F1 @ F22 @ Nat ) ) ) ).
% old.nat.simps(7)
thf(fact_3439_old_Onat_Osimps_I6_J,axiom,
! [T: $tType,F1: T,F22: nat > T > T] :
( ( rec_nat @ T @ F1 @ F22 @ ( zero_zero @ nat ) )
= F1 ) ).
% old.nat.simps(6)
thf(fact_3440_nat_Ocase__distrib,axiom,
! [B: $tType,A: $tType,H2: A > B,F1: A,F22: nat > A,Nat: nat] :
( ( H2 @ ( case_nat @ A @ F1 @ F22 @ Nat ) )
= ( case_nat @ B @ ( H2 @ F1 )
@ ^ [X2: nat] : ( H2 @ ( F22 @ X2 ) )
@ Nat ) ) ).
% nat.case_distrib
thf(fact_3441_old_Onat_Osimps_I5_J,axiom,
! [A: $tType,F1: A,F22: nat > A,X22: nat] :
( ( case_nat @ A @ F1 @ F22 @ ( suc @ X22 ) )
= ( F22 @ X22 ) ) ).
% old.nat.simps(5)
thf(fact_3442_old_Onat_Osimps_I4_J,axiom,
! [A: $tType,F1: A,F22: nat > A] :
( ( case_nat @ A @ F1 @ F22 @ ( zero_zero @ nat ) )
= F1 ) ).
% old.nat.simps(4)
thf(fact_3443_nat_Odisc__eq__case_I2_J,axiom,
! [Nat: nat] :
( ( Nat
!= ( zero_zero @ nat ) )
= ( case_nat @ $o @ $false
@ ^ [Uu3: nat] : $true
@ Nat ) ) ).
% nat.disc_eq_case(2)
thf(fact_3444_nat_Odisc__eq__case_I1_J,axiom,
! [Nat: nat] :
( ( Nat
= ( zero_zero @ nat ) )
= ( case_nat @ $o @ $true
@ ^ [Uu3: nat] : $false
@ Nat ) ) ).
% nat.disc_eq_case(1)
thf(fact_3445_less__eq__nat_Osimps_I2_J,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( suc @ M ) @ N2 )
= ( case_nat @ $o @ $false @ ( ord_less_eq @ nat @ M ) @ N2 ) ) ).
% less_eq_nat.simps(2)
thf(fact_3446_max__Suc1,axiom,
! [N2: nat,M: nat] :
( ( ord_max @ nat @ ( suc @ N2 ) @ M )
= ( case_nat @ nat @ ( suc @ N2 )
@ ^ [M5: nat] : ( suc @ ( ord_max @ nat @ N2 @ M5 ) )
@ M ) ) ).
% max_Suc1
thf(fact_3447_max__Suc2,axiom,
! [M: nat,N2: nat] :
( ( ord_max @ nat @ M @ ( suc @ N2 ) )
= ( case_nat @ nat @ ( suc @ N2 )
@ ^ [M5: nat] : ( suc @ ( ord_max @ nat @ M5 @ N2 ) )
@ M ) ) ).
% max_Suc2
thf(fact_3448_length__n__lists__elem,axiom,
! [A: $tType,Ys: list @ A,N2: nat,Xs: list @ A] :
( ( member2 @ ( list @ A ) @ Ys @ ( set2 @ ( list @ A ) @ ( n_lists @ A @ N2 @ Xs ) ) )
=> ( ( size_size @ ( list @ A ) @ Ys )
= N2 ) ) ).
% length_n_lists_elem
thf(fact_3449_diff__Suc,axiom,
! [M: nat,N2: nat] :
( ( minus_minus @ nat @ M @ ( suc @ N2 ) )
= ( case_nat @ nat @ ( zero_zero @ nat )
@ ^ [K2: nat] : K2
@ ( minus_minus @ nat @ M @ N2 ) ) ) ).
% diff_Suc
thf(fact_3450_Nitpick_Ocase__nat__unfold,axiom,
! [A: $tType] :
( ( case_nat @ A )
= ( ^ [X2: A,F3: nat > A,N: nat] :
( if @ A
@ ( N
= ( zero_zero @ nat ) )
@ X2
@ ( F3 @ ( minus_minus @ nat @ N @ ( one_one @ nat ) ) ) ) ) ) ).
% Nitpick.case_nat_unfold
thf(fact_3451_rec__nat__0__imp,axiom,
! [A: $tType,F2: nat > A,F1: A,F22: nat > A > A] :
( ( F2
= ( rec_nat @ A @ F1 @ F22 ) )
=> ( ( F2 @ ( zero_zero @ nat ) )
= F1 ) ) ).
% rec_nat_0_imp
thf(fact_3452_rec__nat__Suc__imp,axiom,
! [A: $tType,F2: nat > A,F1: A,F22: nat > A > A,N2: nat] :
( ( F2
= ( rec_nat @ A @ F1 @ F22 ) )
=> ( ( F2 @ ( suc @ N2 ) )
= ( F22 @ N2 @ ( F2 @ N2 ) ) ) ) ).
% rec_nat_Suc_imp
thf(fact_3453_nat_Osplit__sels_I1_J,axiom,
! [A: $tType,P2: A > $o,F1: A,F22: nat > A,Nat: nat] :
( ( P2 @ ( case_nat @ A @ F1 @ F22 @ Nat ) )
= ( ( ( Nat
= ( zero_zero @ nat ) )
=> ( P2 @ F1 ) )
& ( ( Nat
= ( suc @ ( pred @ Nat ) ) )
=> ( P2 @ ( F22 @ ( pred @ Nat ) ) ) ) ) ) ).
% nat.split_sels(1)
thf(fact_3454_nat_Osplit__sels_I2_J,axiom,
! [A: $tType,P2: A > $o,F1: A,F22: nat > A,Nat: nat] :
( ( P2 @ ( case_nat @ A @ F1 @ F22 @ Nat ) )
= ( ~ ( ( ( Nat
= ( zero_zero @ nat ) )
& ~ ( P2 @ F1 ) )
| ( ( Nat
= ( suc @ ( pred @ Nat ) ) )
& ~ ( P2 @ ( F22 @ ( pred @ Nat ) ) ) ) ) ) ) ).
% nat.split_sels(2)
thf(fact_3455_pred__def,axiom,
( pred
= ( case_nat @ nat @ ( zero_zero @ nat )
@ ^ [X24: nat] : X24 ) ) ).
% pred_def
thf(fact_3456_subset__CollectI,axiom,
! [A: $tType,B3: set @ A,A4: set @ A,Q: A > $o,P2: A > $o] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ B3 )
=> ( ( Q @ X5 )
=> ( P2 @ X5 ) ) )
=> ( ord_less_eq @ ( set @ A )
@ ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ B3 )
& ( Q @ X2 ) ) )
@ ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( P2 @ X2 ) ) ) ) ) ) ).
% subset_CollectI
thf(fact_3457_subset__Collect__iff,axiom,
! [A: $tType,B3: set @ A,A4: set @ A,P2: A > $o] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3
@ ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( P2 @ X2 ) ) ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ B3 )
=> ( P2 @ X2 ) ) ) ) ) ).
% subset_Collect_iff
thf(fact_3458_signed__take__bit__code,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ( ( bit_ri4674362597316999326ke_bit @ A )
= ( ^ [N: nat,A5: A] : ( if @ A @ ( bit_se5641148757651400278ts_bit @ A @ ( bit_se2584673776208193580ke_bit @ A @ ( suc @ N ) @ A5 ) @ N ) @ ( plus_plus @ A @ ( bit_se2584673776208193580ke_bit @ A @ ( suc @ N ) @ A5 ) @ ( bit_se4730199178511100633sh_bit @ A @ ( suc @ N ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) @ ( bit_se2584673776208193580ke_bit @ A @ ( suc @ N ) @ A5 ) ) ) ) ) ).
% signed_take_bit_code
thf(fact_3459_bezw__0,axiom,
! [X: nat] :
( ( bezw @ X @ ( zero_zero @ nat ) )
= ( product_Pair @ int @ int @ ( one_one @ int ) @ ( zero_zero @ int ) ) ) ).
% bezw_0
thf(fact_3460_prod__decode__aux_Osimps,axiom,
( nat_prod_decode_aux
= ( ^ [K2: nat,M2: nat] : ( if @ ( product_prod @ nat @ nat ) @ ( ord_less_eq @ nat @ M2 @ K2 ) @ ( product_Pair @ nat @ nat @ M2 @ ( minus_minus @ nat @ K2 @ M2 ) ) @ ( nat_prod_decode_aux @ ( suc @ K2 ) @ ( minus_minus @ nat @ M2 @ ( suc @ K2 ) ) ) ) ) ) ).
% prod_decode_aux.simps
thf(fact_3461_prod__decode__aux_Oelims,axiom,
! [X: nat,Xa2: nat,Y: product_prod @ nat @ nat] :
( ( ( nat_prod_decode_aux @ X @ Xa2 )
= Y )
=> ( ( ( ord_less_eq @ nat @ Xa2 @ X )
=> ( Y
= ( product_Pair @ nat @ nat @ Xa2 @ ( minus_minus @ nat @ X @ Xa2 ) ) ) )
& ( ~ ( ord_less_eq @ nat @ Xa2 @ X )
=> ( Y
= ( nat_prod_decode_aux @ ( suc @ X ) @ ( minus_minus @ nat @ Xa2 @ ( suc @ X ) ) ) ) ) ) ) ).
% prod_decode_aux.elims
thf(fact_3462_Suc__0__div__numeral,axiom,
! [K: num] :
( ( divide_divide @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( numeral_numeral @ nat @ K ) )
= ( product_fst @ nat @ nat @ ( unique8689654367752047608divmod @ nat @ one2 @ K ) ) ) ).
% Suc_0_div_numeral
thf(fact_3463_push__bit__of__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat] :
( ( bit_se4730199178511100633sh_bit @ A @ N2 @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% push_bit_of_0
thf(fact_3464_push__bit__eq__0__iff,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [N2: nat,A3: A] :
( ( ( bit_se4730199178511100633sh_bit @ A @ N2 @ A3 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ).
% push_bit_eq_0_iff
thf(fact_3465_push__bit__push__bit,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,N2: nat,A3: A] :
( ( bit_se4730199178511100633sh_bit @ A @ M @ ( bit_se4730199178511100633sh_bit @ A @ N2 @ A3 ) )
= ( bit_se4730199178511100633sh_bit @ A @ ( plus_plus @ nat @ M @ N2 ) @ A3 ) ) ) ).
% push_bit_push_bit
thf(fact_3466_push__bit__Suc__numeral,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,K: num] :
( ( bit_se4730199178511100633sh_bit @ A @ ( suc @ N2 ) @ ( numeral_numeral @ A @ K ) )
= ( bit_se4730199178511100633sh_bit @ A @ N2 @ ( numeral_numeral @ A @ ( bit0 @ K ) ) ) ) ) ).
% push_bit_Suc_numeral
thf(fact_3467_push__bit__Suc__minus__numeral,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [N2: nat,K: num] :
( ( bit_se4730199178511100633sh_bit @ A @ ( suc @ N2 ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ K ) ) )
= ( bit_se4730199178511100633sh_bit @ A @ N2 @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ ( bit0 @ K ) ) ) ) ) ) ).
% push_bit_Suc_minus_numeral
thf(fact_3468_push__bit__Suc,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( bit_se4730199178511100633sh_bit @ A @ ( suc @ N2 ) @ A3 )
= ( bit_se4730199178511100633sh_bit @ A @ N2 @ ( times_times @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% push_bit_Suc
thf(fact_3469_push__bit__of__Suc__0,axiom,
! [N2: nat] :
( ( bit_se4730199178511100633sh_bit @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) ).
% push_bit_of_Suc_0
thf(fact_3470_even__push__bit__iff,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( bit_se4730199178511100633sh_bit @ A @ N2 @ A3 ) )
= ( ( N2
!= ( zero_zero @ nat ) )
| ( dvd_dvd @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) ) ) ) ).
% even_push_bit_iff
thf(fact_3471_push__bit__add,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A,B2: A] :
( ( bit_se4730199178511100633sh_bit @ A @ N2 @ ( plus_plus @ A @ A3 @ B2 ) )
= ( plus_plus @ A @ ( bit_se4730199178511100633sh_bit @ A @ N2 @ A3 ) @ ( bit_se4730199178511100633sh_bit @ A @ N2 @ B2 ) ) ) ) ).
% push_bit_add
thf(fact_3472_fst__conv,axiom,
! [B: $tType,A: $tType,X1: A,X22: B] :
( ( product_fst @ A @ B @ ( product_Pair @ A @ B @ X1 @ X22 ) )
= X1 ) ).
% fst_conv
thf(fact_3473_fst__eqD,axiom,
! [B: $tType,A: $tType,X: A,Y: B,A3: A] :
( ( ( product_fst @ A @ B @ ( product_Pair @ A @ B @ X @ Y ) )
= A3 )
=> ( X = A3 ) ) ).
% fst_eqD
thf(fact_3474_push__bit__take__bit,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,N2: nat,A3: A] :
( ( bit_se4730199178511100633sh_bit @ A @ M @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) )
= ( bit_se2584673776208193580ke_bit @ A @ ( plus_plus @ nat @ M @ N2 ) @ ( bit_se4730199178511100633sh_bit @ A @ M @ A3 ) ) ) ) ).
% push_bit_take_bit
thf(fact_3475_bit__push__bit__iff__int,axiom,
! [M: nat,K: int,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ int @ ( bit_se4730199178511100633sh_bit @ int @ M @ K ) @ N2 )
= ( ( ord_less_eq @ nat @ M @ N2 )
& ( bit_se5641148757651400278ts_bit @ int @ K @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ).
% bit_push_bit_iff_int
thf(fact_3476_bit__push__bit__iff__nat,axiom,
! [M: nat,Q2: nat,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ nat @ ( bit_se4730199178511100633sh_bit @ nat @ M @ Q2 ) @ N2 )
= ( ( ord_less_eq @ nat @ M @ N2 )
& ( bit_se5641148757651400278ts_bit @ nat @ Q2 @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ).
% bit_push_bit_iff_nat
thf(fact_3477_bit__iff__and__push__bit__not__eq__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ( ( bit_se5641148757651400278ts_bit @ A )
= ( ^ [A5: A,N: nat] :
( ( bit_se5824344872417868541ns_and @ A @ A5 @ ( bit_se4730199178511100633sh_bit @ A @ N @ ( one_one @ A ) ) )
!= ( zero_zero @ A ) ) ) ) ) ).
% bit_iff_and_push_bit_not_eq_0
thf(fact_3478_take__bit__sum,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ( ( bit_se2584673776208193580ke_bit @ A )
= ( ^ [N: nat,A5: A] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [K2: nat] : ( bit_se4730199178511100633sh_bit @ A @ K2 @ ( zero_neq_one_of_bool @ A @ ( bit_se5641148757651400278ts_bit @ A @ A5 @ K2 ) ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N ) ) ) ) ) ).
% take_bit_sum
thf(fact_3479_in__set__enumerate__eq,axiom,
! [A: $tType,P4: product_prod @ nat @ A,N2: nat,Xs: list @ A] :
( ( member2 @ ( product_prod @ nat @ A ) @ P4 @ ( set2 @ ( product_prod @ nat @ A ) @ ( enumerate @ A @ N2 @ Xs ) ) )
= ( ( ord_less_eq @ nat @ N2 @ ( product_fst @ nat @ A @ P4 ) )
& ( ord_less @ nat @ ( product_fst @ nat @ A @ P4 ) @ ( plus_plus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 ) )
& ( ( nth @ A @ Xs @ ( minus_minus @ nat @ ( product_fst @ nat @ A @ P4 ) @ N2 ) )
= ( product_snd @ nat @ A @ P4 ) ) ) ) ).
% in_set_enumerate_eq
thf(fact_3480_Suc__0__mod__numeral,axiom,
! [K: num] :
( ( modulo_modulo @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( numeral_numeral @ nat @ K ) )
= ( product_snd @ nat @ nat @ ( unique8689654367752047608divmod @ nat @ one2 @ K ) ) ) ).
% Suc_0_mod_numeral
thf(fact_3481_nth__rotate1,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ A @ ( rotate1 @ A @ Xs ) @ N2 )
= ( nth @ A @ Xs @ ( modulo_modulo @ nat @ ( suc @ N2 ) @ ( size_size @ ( list @ A ) @ Xs ) ) ) ) ) ).
% nth_rotate1
thf(fact_3482_set__update__distinct,axiom,
! [A: $tType,Xs: list @ A,N2: nat,X: A] :
( ( distinct @ A @ Xs )
=> ( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( set2 @ A @ ( list_update @ A @ Xs @ N2 @ X ) )
= ( insert2 @ A @ X @ ( minus_minus @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( insert2 @ A @ ( nth @ A @ Xs @ N2 ) @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% set_update_distinct
thf(fact_3483_drop__bit__rec,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ( ( bit_se4197421643247451524op_bit @ A )
= ( ^ [N: nat,A5: A] :
( if @ A
@ ( N
= ( zero_zero @ nat ) )
@ A5
@ ( bit_se4197421643247451524op_bit @ A @ ( minus_minus @ nat @ N @ ( one_one @ nat ) ) @ ( divide_divide @ A @ A5 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ).
% drop_bit_rec
thf(fact_3484_drop__bit__of__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat] :
( ( bit_se4197421643247451524op_bit @ A @ N2 @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% drop_bit_of_0
thf(fact_3485_drop__bit__drop__bit,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,N2: nat,A3: A] :
( ( bit_se4197421643247451524op_bit @ A @ M @ ( bit_se4197421643247451524op_bit @ A @ N2 @ A3 ) )
= ( bit_se4197421643247451524op_bit @ A @ ( plus_plus @ nat @ M @ N2 ) @ A3 ) ) ) ).
% drop_bit_drop_bit
thf(fact_3486_set__rotate1,axiom,
! [A: $tType,Xs: list @ A] :
( ( set2 @ A @ ( rotate1 @ A @ Xs ) )
= ( set2 @ A @ Xs ) ) ).
% set_rotate1
thf(fact_3487_length__rotate1,axiom,
! [A: $tType,Xs: list @ A] :
( ( size_size @ ( list @ A ) @ ( rotate1 @ A @ Xs ) )
= ( size_size @ ( list @ A ) @ Xs ) ) ).
% length_rotate1
thf(fact_3488_distinct1__rotate,axiom,
! [A: $tType,Xs: list @ A] :
( ( distinct @ A @ ( rotate1 @ A @ Xs ) )
= ( distinct @ A @ Xs ) ) ).
% distinct1_rotate
thf(fact_3489_distinct__insert,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( distinct @ A @ ( insert @ A @ X @ Xs ) )
= ( distinct @ A @ Xs ) ) ).
% distinct_insert
thf(fact_3490_prod_Ocollapse,axiom,
! [B: $tType,A: $tType,Prod: product_prod @ A @ B] :
( ( product_Pair @ A @ B @ ( product_fst @ A @ B @ Prod ) @ ( product_snd @ A @ B @ Prod ) )
= Prod ) ).
% prod.collapse
thf(fact_3491_drop__bit__of__bool,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,B2: $o] :
( ( bit_se4197421643247451524op_bit @ A @ N2 @ ( zero_neq_one_of_bool @ A @ B2 ) )
= ( zero_neq_one_of_bool @ A
@ ( ( N2
= ( zero_zero @ nat ) )
& B2 ) ) ) ) ).
% drop_bit_of_bool
thf(fact_3492_drop__bit__of__Suc__0,axiom,
! [N2: nat] :
( ( bit_se4197421643247451524op_bit @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) )
= ( zero_neq_one_of_bool @ nat
@ ( N2
= ( zero_zero @ nat ) ) ) ) ).
% drop_bit_of_Suc_0
thf(fact_3493_drop__bit__Suc__minus__bit0,axiom,
! [N2: nat,K: num] :
( ( bit_se4197421643247451524op_bit @ int @ ( suc @ N2 ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ ( bit0 @ K ) ) ) )
= ( bit_se4197421643247451524op_bit @ int @ N2 @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ K ) ) ) ) ).
% drop_bit_Suc_minus_bit0
thf(fact_3494_drop__bit__Suc__bit0,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [N2: nat,K: num] :
( ( bit_se4197421643247451524op_bit @ A @ ( suc @ N2 ) @ ( numeral_numeral @ A @ ( bit0 @ K ) ) )
= ( bit_se4197421643247451524op_bit @ A @ N2 @ ( numeral_numeral @ A @ K ) ) ) ) ).
% drop_bit_Suc_bit0
thf(fact_3495_drop__bit__Suc__bit1,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [N2: nat,K: num] :
( ( bit_se4197421643247451524op_bit @ A @ ( suc @ N2 ) @ ( numeral_numeral @ A @ ( bit1 @ K ) ) )
= ( bit_se4197421643247451524op_bit @ A @ N2 @ ( numeral_numeral @ A @ K ) ) ) ) ).
% drop_bit_Suc_bit1
thf(fact_3496_drop__bit__of__1,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat] :
( ( bit_se4197421643247451524op_bit @ A @ N2 @ ( one_one @ A ) )
= ( zero_neq_one_of_bool @ A
@ ( N2
= ( zero_zero @ nat ) ) ) ) ) ).
% drop_bit_of_1
thf(fact_3497_rotate1__length01,axiom,
! [A: $tType,Xs: list @ A] :
( ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) )
=> ( ( rotate1 @ A @ Xs )
= Xs ) ) ).
% rotate1_length01
thf(fact_3498_distinct__swap,axiom,
! [A: $tType,I: nat,Xs: list @ A,J: nat] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ord_less @ nat @ J @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( distinct @ A @ ( list_update @ A @ ( list_update @ A @ Xs @ I @ ( nth @ A @ Xs @ J ) ) @ J @ ( nth @ A @ Xs @ I ) ) )
= ( distinct @ A @ Xs ) ) ) ) ).
% distinct_swap
thf(fact_3499_drop__bit__Suc__minus__bit1,axiom,
! [N2: nat,K: num] :
( ( bit_se4197421643247451524op_bit @ int @ ( suc @ N2 ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ ( bit1 @ K ) ) ) )
= ( bit_se4197421643247451524op_bit @ int @ N2 @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ ( inc @ K ) ) ) ) ) ).
% drop_bit_Suc_minus_bit1
thf(fact_3500_finite__lists__distinct__length__eq,axiom,
! [A: $tType,A4: set @ A,N2: nat] :
( ( finite_finite @ A @ A4 )
=> ( finite_finite @ ( list @ A )
@ ( collect @ ( list @ A )
@ ^ [Xs2: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs2 )
= N2 )
& ( distinct @ A @ Xs2 )
& ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs2 ) @ A4 ) ) ) ) ) ).
% finite_lists_distinct_length_eq
thf(fact_3501_sorted__list__of__set_Odistinct__if__distinct__map,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( distinct @ A @ Xs )
=> ( distinct @ A @ Xs ) ) ) ).
% sorted_list_of_set.distinct_if_distinct_map
thf(fact_3502_distinct__zipI2,axiom,
! [B: $tType,A: $tType,Ys: list @ A,Xs: list @ B] :
( ( distinct @ A @ Ys )
=> ( distinct @ ( product_prod @ B @ A ) @ ( zip @ B @ A @ Xs @ Ys ) ) ) ).
% distinct_zipI2
thf(fact_3503_distinct__zipI1,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B] :
( ( distinct @ A @ Xs )
=> ( distinct @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) ) ) ).
% distinct_zipI1
thf(fact_3504_distinct__product,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B] :
( ( distinct @ A @ Xs )
=> ( ( distinct @ B @ Ys )
=> ( distinct @ ( product_prod @ A @ B ) @ ( product @ A @ B @ Xs @ Ys ) ) ) ) ).
% distinct_product
thf(fact_3505_snd__eqD,axiom,
! [B: $tType,A: $tType,X: B,Y: A,A3: A] :
( ( ( product_snd @ B @ A @ ( product_Pair @ B @ A @ X @ Y ) )
= A3 )
=> ( Y = A3 ) ) ).
% snd_eqD
thf(fact_3506_snd__conv,axiom,
! [Aa: $tType,A: $tType,X1: Aa,X22: A] :
( ( product_snd @ Aa @ A @ ( product_Pair @ Aa @ A @ X1 @ X22 ) )
= X22 ) ).
% snd_conv
thf(fact_3507_distinct__enumerate,axiom,
! [A: $tType,N2: nat,Xs: list @ A] : ( distinct @ ( product_prod @ nat @ A ) @ ( enumerate @ A @ N2 @ Xs ) ) ).
% distinct_enumerate
thf(fact_3508_finite__distinct__list,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ? [Xs3: list @ A] :
( ( ( set2 @ A @ Xs3 )
= A4 )
& ( distinct @ A @ Xs3 ) ) ) ).
% finite_distinct_list
thf(fact_3509_prod_Oexhaust__sel,axiom,
! [B: $tType,A: $tType,Prod: product_prod @ A @ B] :
( Prod
= ( product_Pair @ A @ B @ ( product_fst @ A @ B @ Prod ) @ ( product_snd @ A @ B @ Prod ) ) ) ).
% prod.exhaust_sel
thf(fact_3510_surjective__pairing,axiom,
! [B: $tType,A: $tType,T2: product_prod @ A @ B] :
( T2
= ( product_Pair @ A @ B @ ( product_fst @ A @ B @ T2 ) @ ( product_snd @ A @ B @ T2 ) ) ) ).
% surjective_pairing
thf(fact_3511_BNF__Greatest__Fixpoint_Osubst__Pair,axiom,
! [B: $tType,A: $tType,P2: A > B > $o,X: A,Y: B,A3: product_prod @ A @ B] :
( ( P2 @ X @ Y )
=> ( ( A3
= ( product_Pair @ A @ B @ X @ Y ) )
=> ( P2 @ ( product_fst @ A @ B @ A3 ) @ ( product_snd @ A @ B @ A3 ) ) ) ) ).
% BNF_Greatest_Fixpoint.subst_Pair
thf(fact_3512_take__bit__eq__self__iff__drop__bit__eq__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 )
= A3 )
= ( ( bit_se4197421643247451524op_bit @ A @ N2 @ A3 )
= ( zero_zero @ A ) ) ) ) ).
% take_bit_eq_self_iff_drop_bit_eq_0
thf(fact_3513_take__bit__drop__bit,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,N2: nat,A3: A] :
( ( bit_se2584673776208193580ke_bit @ A @ M @ ( bit_se4197421643247451524op_bit @ A @ N2 @ A3 ) )
= ( bit_se4197421643247451524op_bit @ A @ N2 @ ( bit_se2584673776208193580ke_bit @ A @ ( plus_plus @ nat @ M @ N2 ) @ A3 ) ) ) ) ).
% take_bit_drop_bit
thf(fact_3514_subseqs__distinctD,axiom,
! [A: $tType,Ys: list @ A,Xs: list @ A] :
( ( member2 @ ( list @ A ) @ Ys @ ( set2 @ ( list @ A ) @ ( subseqs @ A @ Xs ) ) )
=> ( ( distinct @ A @ Xs )
=> ( distinct @ A @ Ys ) ) ) ).
% subseqs_distinctD
thf(fact_3515_divides__aux__def,axiom,
! [A: $tType] :
( ( unique1627219031080169319umeral @ A )
=> ( ( unique5940410009612947441es_aux @ A )
= ( ^ [Qr: product_prod @ A @ A] :
( ( product_snd @ A @ A @ Qr )
= ( zero_zero @ A ) ) ) ) ) ).
% divides_aux_def
thf(fact_3516_distinct__conv__nth,axiom,
! [A: $tType] :
( ( distinct @ A )
= ( ^ [Xs2: list @ A] :
! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs2 ) )
=> ! [J3: nat] :
( ( ord_less @ nat @ J3 @ ( size_size @ ( list @ A ) @ Xs2 ) )
=> ( ( I5 != J3 )
=> ( ( nth @ A @ Xs2 @ I5 )
!= ( nth @ A @ Xs2 @ J3 ) ) ) ) ) ) ) ).
% distinct_conv_nth
thf(fact_3517_nth__eq__iff__index__eq,axiom,
! [A: $tType,Xs: list @ A,I: nat,J: nat] :
( ( distinct @ A @ Xs )
=> ( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ord_less @ nat @ J @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ( nth @ A @ Xs @ I )
= ( nth @ A @ Xs @ J ) )
= ( I = J ) ) ) ) ) ).
% nth_eq_iff_index_eq
thf(fact_3518_prod_Osplit__sel__asm,axiom,
! [C: $tType,B: $tType,A: $tType,P2: C > $o,F2: A > B > C,Prod: product_prod @ A @ B] :
( ( P2 @ ( product_case_prod @ A @ B @ C @ F2 @ Prod ) )
= ( ~ ( ( Prod
= ( product_Pair @ A @ B @ ( product_fst @ A @ B @ Prod ) @ ( product_snd @ A @ B @ Prod ) ) )
& ~ ( P2 @ ( F2 @ ( product_fst @ A @ B @ Prod ) @ ( product_snd @ A @ B @ Prod ) ) ) ) ) ) ).
% prod.split_sel_asm
thf(fact_3519_prod_Osplit__sel,axiom,
! [C: $tType,B: $tType,A: $tType,P2: C > $o,F2: A > B > C,Prod: product_prod @ A @ B] :
( ( P2 @ ( product_case_prod @ A @ B @ C @ F2 @ Prod ) )
= ( ( Prod
= ( product_Pair @ A @ B @ ( product_fst @ A @ B @ Prod ) @ ( product_snd @ A @ B @ Prod ) ) )
=> ( P2 @ ( F2 @ ( product_fst @ A @ B @ Prod ) @ ( product_snd @ A @ B @ Prod ) ) ) ) ) ).
% prod.split_sel
thf(fact_3520_bits__ident,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( plus_plus @ A @ ( bit_se4730199178511100633sh_bit @ A @ N2 @ ( bit_se4197421643247451524op_bit @ A @ N2 @ A3 ) ) @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) )
= A3 ) ) ).
% bits_ident
thf(fact_3521_distinct__Ex1,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( distinct @ A @ Xs )
=> ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ? [X5: nat] :
( ( ord_less @ nat @ X5 @ ( size_size @ ( list @ A ) @ Xs ) )
& ( ( nth @ A @ Xs @ X5 )
= X )
& ! [Y3: nat] :
( ( ( ord_less @ nat @ Y3 @ ( size_size @ ( list @ A ) @ Xs ) )
& ( ( nth @ A @ Xs @ Y3 )
= X ) )
=> ( Y3 = X5 ) ) ) ) ) ).
% distinct_Ex1
thf(fact_3522_update__zip,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ B,I: nat,Xy: product_prod @ A @ B] :
( ( list_update @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) @ I @ Xy )
= ( zip @ A @ B @ ( list_update @ A @ Xs @ I @ ( product_fst @ A @ B @ Xy ) ) @ ( list_update @ B @ Ys @ I @ ( product_snd @ A @ B @ Xy ) ) ) ) ).
% update_zip
thf(fact_3523_drop__bit__Suc,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( bit_se4197421643247451524op_bit @ A @ ( suc @ N2 ) @ A3 )
= ( bit_se4197421643247451524op_bit @ A @ N2 @ ( divide_divide @ A @ A3 @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) ) ) ) ).
% drop_bit_Suc
thf(fact_3524_distinct__list__update,axiom,
! [A: $tType,Xs: list @ A,A3: A,I: nat] :
( ( distinct @ A @ Xs )
=> ( ~ ( member2 @ A @ A3 @ ( minus_minus @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( insert2 @ A @ ( nth @ A @ Xs @ I ) @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( distinct @ A @ ( list_update @ A @ Xs @ I @ A3 ) ) ) ) ).
% distinct_list_update
thf(fact_3525_in__set__zip,axiom,
! [B: $tType,A: $tType,P4: product_prod @ A @ B,Xs: list @ A,Ys: list @ B] :
( ( member2 @ ( product_prod @ A @ B ) @ P4 @ ( set2 @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) ) )
= ( ? [N: nat] :
( ( ( nth @ A @ Xs @ N )
= ( product_fst @ A @ B @ P4 ) )
& ( ( nth @ B @ Ys @ N )
= ( product_snd @ A @ B @ P4 ) )
& ( ord_less @ nat @ N @ ( size_size @ ( list @ A ) @ Xs ) )
& ( ord_less @ nat @ N @ ( size_size @ ( list @ B ) @ Ys ) ) ) ) ) ).
% in_set_zip
thf(fact_3526_size__prod__simp,axiom,
! [B: $tType,A: $tType] :
( ( basic_BNF_size_prod @ A @ B )
= ( ^ [F3: A > nat,G2: B > nat,P6: product_prod @ A @ B] : ( plus_plus @ nat @ ( plus_plus @ nat @ ( F3 @ ( product_fst @ A @ B @ P6 ) ) @ ( G2 @ ( product_snd @ A @ B @ P6 ) ) ) @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ).
% size_prod_simp
thf(fact_3527_exI__realizer,axiom,
! [B: $tType,A: $tType,P2: A > B > $o,Y: A,X: B] :
( ( P2 @ Y @ X )
=> ( P2 @ ( product_snd @ B @ A @ ( product_Pair @ B @ A @ X @ Y ) ) @ ( product_fst @ B @ A @ ( product_Pair @ B @ A @ X @ Y ) ) ) ) ).
% exI_realizer
thf(fact_3528_conjI__realizer,axiom,
! [A: $tType,B: $tType,P2: A > $o,P4: A,Q: B > $o,Q2: B] :
( ( P2 @ P4 )
=> ( ( Q @ Q2 )
=> ( ( P2 @ ( product_fst @ A @ B @ ( product_Pair @ A @ B @ P4 @ Q2 ) ) )
& ( Q @ ( product_snd @ A @ B @ ( product_Pair @ A @ B @ P4 @ Q2 ) ) ) ) ) ) ).
% conjI_realizer
thf(fact_3529_bezw_Oelims,axiom,
! [X: nat,Xa2: nat,Y: product_prod @ int @ int] :
( ( ( bezw @ X @ Xa2 )
= Y )
=> ( ( ( Xa2
= ( zero_zero @ nat ) )
=> ( Y
= ( product_Pair @ int @ int @ ( one_one @ int ) @ ( zero_zero @ int ) ) ) )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( Y
= ( product_Pair @ int @ int @ ( product_snd @ int @ int @ ( bezw @ Xa2 @ ( modulo_modulo @ nat @ X @ Xa2 ) ) ) @ ( minus_minus @ int @ ( product_fst @ int @ int @ ( bezw @ Xa2 @ ( modulo_modulo @ nat @ X @ Xa2 ) ) ) @ ( times_times @ int @ ( product_snd @ int @ int @ ( bezw @ Xa2 @ ( modulo_modulo @ nat @ X @ Xa2 ) ) ) @ ( semiring_1_of_nat @ int @ ( divide_divide @ nat @ X @ Xa2 ) ) ) ) ) ) ) ) ) ).
% bezw.elims
thf(fact_3530_bezw_Osimps,axiom,
( bezw
= ( ^ [X2: nat,Y2: nat] :
( if @ ( product_prod @ int @ int )
@ ( Y2
= ( zero_zero @ nat ) )
@ ( product_Pair @ int @ int @ ( one_one @ int ) @ ( zero_zero @ int ) )
@ ( product_Pair @ int @ int @ ( product_snd @ int @ int @ ( bezw @ Y2 @ ( modulo_modulo @ nat @ X2 @ Y2 ) ) ) @ ( minus_minus @ int @ ( product_fst @ int @ int @ ( bezw @ Y2 @ ( modulo_modulo @ nat @ X2 @ Y2 ) ) ) @ ( times_times @ int @ ( product_snd @ int @ int @ ( bezw @ Y2 @ ( modulo_modulo @ nat @ X2 @ Y2 ) ) ) @ ( semiring_1_of_nat @ int @ ( divide_divide @ nat @ X2 @ Y2 ) ) ) ) ) ) ) ) ).
% bezw.simps
thf(fact_3531_bezw__non__0,axiom,
! [Y: nat,X: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ Y )
=> ( ( bezw @ X @ Y )
= ( product_Pair @ int @ int @ ( product_snd @ int @ int @ ( bezw @ Y @ ( modulo_modulo @ nat @ X @ Y ) ) ) @ ( minus_minus @ int @ ( product_fst @ int @ int @ ( bezw @ Y @ ( modulo_modulo @ nat @ X @ Y ) ) ) @ ( times_times @ int @ ( product_snd @ int @ int @ ( bezw @ Y @ ( modulo_modulo @ nat @ X @ Y ) ) ) @ ( semiring_1_of_nat @ int @ ( divide_divide @ nat @ X @ Y ) ) ) ) ) ) ) ).
% bezw_non_0
thf(fact_3532_bezw_Opelims,axiom,
! [X: nat,Xa2: nat,Y: product_prod @ int @ int] :
( ( ( bezw @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ nat @ nat ) @ bezw_rel @ ( product_Pair @ nat @ nat @ X @ Xa2 ) )
=> ~ ( ( ( ( Xa2
= ( zero_zero @ nat ) )
=> ( Y
= ( product_Pair @ int @ int @ ( one_one @ int ) @ ( zero_zero @ int ) ) ) )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( Y
= ( product_Pair @ int @ int @ ( product_snd @ int @ int @ ( bezw @ Xa2 @ ( modulo_modulo @ nat @ X @ Xa2 ) ) ) @ ( minus_minus @ int @ ( product_fst @ int @ int @ ( bezw @ Xa2 @ ( modulo_modulo @ nat @ X @ Xa2 ) ) ) @ ( times_times @ int @ ( product_snd @ int @ int @ ( bezw @ Xa2 @ ( modulo_modulo @ nat @ X @ Xa2 ) ) ) @ ( semiring_1_of_nat @ int @ ( divide_divide @ nat @ X @ Xa2 ) ) ) ) ) ) ) )
=> ~ ( accp @ ( product_prod @ nat @ nat ) @ bezw_rel @ ( product_Pair @ nat @ nat @ X @ Xa2 ) ) ) ) ) ).
% bezw.pelims
thf(fact_3533_distinct__union,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( distinct @ A @ ( union @ A @ Xs @ Ys ) )
= ( distinct @ A @ Ys ) ) ).
% distinct_union
thf(fact_3534_set__remove1__eq,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( distinct @ A @ Xs )
=> ( ( set2 @ A @ ( remove1 @ A @ X @ Xs ) )
= ( minus_minus @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% set_remove1_eq
thf(fact_3535_root__powr__inverse,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ X )
=> ( ( root @ N2 @ X )
= ( powr @ real @ X @ ( divide_divide @ real @ ( one_one @ real ) @ ( semiring_1_of_nat @ real @ N2 ) ) ) ) ) ) ).
% root_powr_inverse
thf(fact_3536_horner__sum__eq__sum__funpow,axiom,
! [A: $tType,B: $tType] :
( ( comm_semiring_0 @ A )
=> ( ( groups4207007520872428315er_sum @ B @ A )
= ( ^ [F3: B > A,A5: A,Xs2: list @ B] :
( groups7311177749621191930dd_sum @ nat @ A
@ ^ [N: nat] : ( compow @ ( A > A ) @ N @ ( times_times @ A @ A5 ) @ ( F3 @ ( nth @ B @ Xs2 @ N ) ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( size_size @ ( list @ B ) @ Xs2 ) ) ) ) ) ) ).
% horner_sum_eq_sum_funpow
thf(fact_3537_Suc__funpow,axiom,
! [N2: nat] :
( ( compow @ ( nat > nat ) @ N2 @ suc )
= ( plus_plus @ nat @ N2 ) ) ).
% Suc_funpow
thf(fact_3538_funpow__0,axiom,
! [A: $tType,F2: A > A,X: A] :
( ( compow @ ( A > A ) @ ( zero_zero @ nat ) @ F2 @ X )
= X ) ).
% funpow_0
thf(fact_3539_in__set__remove1,axiom,
! [A: $tType,A3: A,B2: A,Xs: list @ A] :
( ( A3 != B2 )
=> ( ( member2 @ A @ A3 @ ( set2 @ A @ ( remove1 @ A @ B2 @ Xs ) ) )
= ( member2 @ A @ A3 @ ( set2 @ A @ Xs ) ) ) ) ).
% in_set_remove1
thf(fact_3540_real__root__Suc__0,axiom,
! [X: real] :
( ( root @ ( suc @ ( zero_zero @ nat ) ) @ X )
= X ) ).
% real_root_Suc_0
thf(fact_3541_root__0,axiom,
! [X: real] :
( ( root @ ( zero_zero @ nat ) @ X )
= ( zero_zero @ real ) ) ).
% root_0
thf(fact_3542_real__root__eq__iff,axiom,
! [N2: nat,X: real,Y: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ( root @ N2 @ X )
= ( root @ N2 @ Y ) )
= ( X = Y ) ) ) ).
% real_root_eq_iff
thf(fact_3543_real__root__eq__0__iff,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ( root @ N2 @ X )
= ( zero_zero @ real ) )
= ( X
= ( zero_zero @ real ) ) ) ) ).
% real_root_eq_0_iff
thf(fact_3544_real__root__less__iff,axiom,
! [N2: nat,X: real,Y: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( root @ N2 @ X ) @ ( root @ N2 @ Y ) )
= ( ord_less @ real @ X @ Y ) ) ) ).
% real_root_less_iff
thf(fact_3545_real__root__le__iff,axiom,
! [N2: nat,X: real,Y: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ real @ ( root @ N2 @ X ) @ ( root @ N2 @ Y ) )
= ( ord_less_eq @ real @ X @ Y ) ) ) ).
% real_root_le_iff
thf(fact_3546_real__root__eq__1__iff,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ( root @ N2 @ X )
= ( one_one @ real ) )
= ( X
= ( one_one @ real ) ) ) ) ).
% real_root_eq_1_iff
thf(fact_3547_real__root__one,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( root @ N2 @ ( one_one @ real ) )
= ( one_one @ real ) ) ) ).
% real_root_one
thf(fact_3548_real__root__lt__0__iff,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( root @ N2 @ X ) @ ( zero_zero @ real ) )
= ( ord_less @ real @ X @ ( zero_zero @ real ) ) ) ) ).
% real_root_lt_0_iff
thf(fact_3549_real__root__gt__0__iff,axiom,
! [N2: nat,Y: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ ( root @ N2 @ Y ) )
= ( ord_less @ real @ ( zero_zero @ real ) @ Y ) ) ) ).
% real_root_gt_0_iff
thf(fact_3550_real__root__le__0__iff,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ real @ ( root @ N2 @ X ) @ ( zero_zero @ real ) )
= ( ord_less_eq @ real @ X @ ( zero_zero @ real ) ) ) ) ).
% real_root_le_0_iff
thf(fact_3551_real__root__ge__0__iff,axiom,
! [N2: nat,Y: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ real @ ( zero_zero @ real ) @ ( root @ N2 @ Y ) )
= ( ord_less_eq @ real @ ( zero_zero @ real ) @ Y ) ) ) ).
% real_root_ge_0_iff
thf(fact_3552_real__root__lt__1__iff,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( root @ N2 @ X ) @ ( one_one @ real ) )
= ( ord_less @ real @ X @ ( one_one @ real ) ) ) ) ).
% real_root_lt_1_iff
thf(fact_3553_real__root__gt__1__iff,axiom,
! [N2: nat,Y: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( one_one @ real ) @ ( root @ N2 @ Y ) )
= ( ord_less @ real @ ( one_one @ real ) @ Y ) ) ) ).
% real_root_gt_1_iff
thf(fact_3554_real__root__le__1__iff,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ real @ ( root @ N2 @ X ) @ ( one_one @ real ) )
= ( ord_less_eq @ real @ X @ ( one_one @ real ) ) ) ) ).
% real_root_le_1_iff
thf(fact_3555_real__root__ge__1__iff,axiom,
! [N2: nat,Y: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ real @ ( one_one @ real ) @ ( root @ N2 @ Y ) )
= ( ord_less_eq @ real @ ( one_one @ real ) @ Y ) ) ) ).
% real_root_ge_1_iff
thf(fact_3556_real__root__pow__pos2,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ real @ ( zero_zero @ real ) @ X )
=> ( ( power_power @ real @ ( root @ N2 @ X ) @ N2 )
= X ) ) ) ).
% real_root_pow_pos2
thf(fact_3557_funpow__swap1,axiom,
! [A: $tType,F2: A > A,N2: nat,X: A] :
( ( F2 @ ( compow @ ( A > A ) @ N2 @ F2 @ X ) )
= ( compow @ ( A > A ) @ N2 @ F2 @ ( F2 @ X ) ) ) ).
% funpow_swap1
thf(fact_3558_remove1__commute,axiom,
! [A: $tType,X: A,Y: A,Zs: list @ A] :
( ( remove1 @ A @ X @ ( remove1 @ A @ Y @ Zs ) )
= ( remove1 @ A @ Y @ ( remove1 @ A @ X @ Zs ) ) ) ).
% remove1_commute
thf(fact_3559_funpow__mult,axiom,
! [A: $tType,N2: nat,M: nat,F2: A > A] :
( ( compow @ ( A > A ) @ N2 @ ( compow @ ( A > A ) @ M @ F2 ) )
= ( compow @ ( A > A ) @ ( times_times @ nat @ M @ N2 ) @ F2 ) ) ).
% funpow_mult
thf(fact_3560_notin__set__remove1,axiom,
! [A: $tType,X: A,Xs: list @ A,Y: A] :
( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ~ ( member2 @ A @ X @ ( set2 @ A @ ( remove1 @ A @ Y @ Xs ) ) ) ) ).
% notin_set_remove1
thf(fact_3561_remove1__idem,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( remove1 @ A @ X @ Xs )
= Xs ) ) ).
% remove1_idem
thf(fact_3562_distinct__remove1,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( distinct @ A @ Xs )
=> ( distinct @ A @ ( remove1 @ A @ X @ Xs ) ) ) ).
% distinct_remove1
thf(fact_3563_set__remove1__subset,axiom,
! [A: $tType,X: A,Xs: list @ A] : ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ ( remove1 @ A @ X @ Xs ) ) @ ( set2 @ A @ Xs ) ) ).
% set_remove1_subset
thf(fact_3564_real__root__less__mono,axiom,
! [N2: nat,X: real,Y: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ X @ Y )
=> ( ord_less @ real @ ( root @ N2 @ X ) @ ( root @ N2 @ Y ) ) ) ) ).
% real_root_less_mono
thf(fact_3565_real__root__le__mono,axiom,
! [N2: nat,X: real,Y: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ real @ X @ Y )
=> ( ord_less_eq @ real @ ( root @ N2 @ X ) @ ( root @ N2 @ Y ) ) ) ) ).
% real_root_le_mono
thf(fact_3566_real__root__power,axiom,
! [N2: nat,X: real,K: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( root @ N2 @ ( power_power @ real @ X @ K ) )
= ( power_power @ real @ ( root @ N2 @ X ) @ K ) ) ) ).
% real_root_power
thf(fact_3567_real__root__abs,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( root @ N2 @ ( abs_abs @ real @ X ) )
= ( abs_abs @ real @ ( root @ N2 @ X ) ) ) ) ).
% real_root_abs
thf(fact_3568_sgn__root,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( sgn_sgn @ real @ ( root @ N2 @ X ) )
= ( sgn_sgn @ real @ X ) ) ) ).
% sgn_root
thf(fact_3569_of__nat__def,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( semiring_1_of_nat @ A )
= ( ^ [N: nat] : ( compow @ ( A > A ) @ N @ ( plus_plus @ A @ ( one_one @ A ) ) @ ( zero_zero @ A ) ) ) ) ) ).
% of_nat_def
thf(fact_3570_real__root__gt__zero,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ X )
=> ( ord_less @ real @ ( zero_zero @ real ) @ ( root @ N2 @ X ) ) ) ) ).
% real_root_gt_zero
thf(fact_3571_numeral__add__unfold__funpow,axiom,
! [A: $tType] :
( ( semiring_numeral @ A )
=> ! [K: num,A3: A] :
( ( plus_plus @ A @ ( numeral_numeral @ A @ K ) @ A3 )
= ( compow @ ( A > A ) @ ( numeral_numeral @ nat @ K ) @ ( plus_plus @ A @ ( one_one @ A ) ) @ A3 ) ) ) ).
% numeral_add_unfold_funpow
thf(fact_3572_real__root__strict__decreasing,axiom,
! [N2: nat,N7: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ nat @ N2 @ N7 )
=> ( ( ord_less @ real @ ( one_one @ real ) @ X )
=> ( ord_less @ real @ ( root @ N7 @ X ) @ ( root @ N2 @ X ) ) ) ) ) ).
% real_root_strict_decreasing
thf(fact_3573_root__abs__power,axiom,
! [N2: nat,Y: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( abs_abs @ real @ ( root @ N2 @ ( power_power @ real @ Y @ N2 ) ) )
= ( abs_abs @ real @ Y ) ) ) ).
% root_abs_power
thf(fact_3574_numeral__unfold__funpow,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( numeral_numeral @ A )
= ( ^ [K2: num] : ( compow @ ( A > A ) @ ( numeral_numeral @ nat @ K2 ) @ ( plus_plus @ A @ ( one_one @ A ) ) @ ( zero_zero @ A ) ) ) ) ) ).
% numeral_unfold_funpow
thf(fact_3575_real__root__pos__pos,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ X )
=> ( ord_less_eq @ real @ ( zero_zero @ real ) @ ( root @ N2 @ X ) ) ) ) ).
% real_root_pos_pos
thf(fact_3576_real__root__strict__increasing,axiom,
! [N2: nat,N7: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ nat @ N2 @ N7 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ X )
=> ( ( ord_less @ real @ X @ ( one_one @ real ) )
=> ( ord_less @ real @ ( root @ N2 @ X ) @ ( root @ N7 @ X ) ) ) ) ) ) ).
% real_root_strict_increasing
thf(fact_3577_real__root__decreasing,axiom,
! [N2: nat,N7: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ nat @ N2 @ N7 )
=> ( ( ord_less_eq @ real @ ( one_one @ real ) @ X )
=> ( ord_less_eq @ real @ ( root @ N7 @ X ) @ ( root @ N2 @ X ) ) ) ) ) ).
% real_root_decreasing
thf(fact_3578_real__root__pow__pos,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ X )
=> ( ( power_power @ real @ ( root @ N2 @ X ) @ N2 )
= X ) ) ) ).
% real_root_pow_pos
thf(fact_3579_real__root__pos__unique,axiom,
! [N2: nat,Y: real,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ real @ ( zero_zero @ real ) @ Y )
=> ( ( ( power_power @ real @ Y @ N2 )
= X )
=> ( ( root @ N2 @ X )
= Y ) ) ) ) ).
% real_root_pos_unique
thf(fact_3580_real__root__power__cancel,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ real @ ( zero_zero @ real ) @ X )
=> ( ( root @ N2 @ ( power_power @ real @ X @ N2 ) )
= X ) ) ) ).
% real_root_power_cancel
thf(fact_3581_length__remove1,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( size_size @ ( list @ A ) @ ( remove1 @ A @ X @ Xs ) )
= ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) ) ) )
& ( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( size_size @ ( list @ A ) @ ( remove1 @ A @ X @ Xs ) )
= ( size_size @ ( list @ A ) @ Xs ) ) ) ) ).
% length_remove1
thf(fact_3582_real__root__increasing,axiom,
! [N2: nat,N7: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ nat @ N2 @ N7 )
=> ( ( ord_less_eq @ real @ ( zero_zero @ real ) @ X )
=> ( ( ord_less_eq @ real @ X @ ( one_one @ real ) )
=> ( ord_less_eq @ real @ ( root @ N2 @ X ) @ ( root @ N7 @ X ) ) ) ) ) ) ).
% real_root_increasing
thf(fact_3583_sgn__power__root,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( times_times @ real @ ( sgn_sgn @ real @ ( root @ N2 @ X ) ) @ ( power_power @ real @ ( abs_abs @ real @ ( root @ N2 @ X ) ) @ N2 ) )
= X ) ) ).
% sgn_power_root
thf(fact_3584_root__sgn__power,axiom,
! [N2: nat,Y: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( root @ N2 @ ( times_times @ real @ ( sgn_sgn @ real @ Y ) @ ( power_power @ real @ ( abs_abs @ real @ Y ) @ N2 ) ) )
= Y ) ) ).
% root_sgn_power
thf(fact_3585_ln__root,axiom,
! [N2: nat,B2: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ B2 )
=> ( ( ln_ln @ real @ ( root @ N2 @ B2 ) )
= ( divide_divide @ real @ ( ln_ln @ real @ B2 ) @ ( semiring_1_of_nat @ real @ N2 ) ) ) ) ) ).
% ln_root
thf(fact_3586_log__root,axiom,
! [N2: nat,A3: real,B2: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ A3 )
=> ( ( log @ B2 @ ( root @ N2 @ A3 ) )
= ( divide_divide @ real @ ( log @ B2 @ A3 ) @ ( semiring_1_of_nat @ real @ N2 ) ) ) ) ) ).
% log_root
thf(fact_3587_log__base__root,axiom,
! [N2: nat,B2: real,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ B2 )
=> ( ( log @ ( root @ N2 @ B2 ) @ X )
= ( times_times @ real @ ( semiring_1_of_nat @ real @ N2 ) @ ( log @ B2 @ X ) ) ) ) ) ).
% log_base_root
thf(fact_3588_split__root,axiom,
! [P2: real > $o,N2: nat,X: real] :
( ( P2 @ ( root @ N2 @ X ) )
= ( ( ( N2
= ( zero_zero @ nat ) )
=> ( P2 @ ( zero_zero @ real ) ) )
& ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ! [Y2: real] :
( ( ( times_times @ real @ ( sgn_sgn @ real @ Y2 ) @ ( power_power @ real @ ( abs_abs @ real @ Y2 ) @ N2 ) )
= X )
=> ( P2 @ Y2 ) ) ) ) ) ).
% split_root
thf(fact_3589_prod__decode__aux_Opelims,axiom,
! [X: nat,Xa2: nat,Y: product_prod @ nat @ nat] :
( ( ( nat_prod_decode_aux @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ nat @ nat ) @ nat_pr5047031295181774490ux_rel @ ( product_Pair @ nat @ nat @ X @ Xa2 ) )
=> ~ ( ( ( ( ord_less_eq @ nat @ Xa2 @ X )
=> ( Y
= ( product_Pair @ nat @ nat @ Xa2 @ ( minus_minus @ nat @ X @ Xa2 ) ) ) )
& ( ~ ( ord_less_eq @ nat @ Xa2 @ X )
=> ( Y
= ( nat_prod_decode_aux @ ( suc @ X ) @ ( minus_minus @ nat @ Xa2 @ ( suc @ X ) ) ) ) ) )
=> ~ ( accp @ ( product_prod @ nat @ nat ) @ nat_pr5047031295181774490ux_rel @ ( product_Pair @ nat @ nat @ X @ Xa2 ) ) ) ) ) ).
% prod_decode_aux.pelims
thf(fact_3590_relpowp__bot,axiom,
! [A: $tType,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( compow @ ( A > A > $o ) @ N2 @ ( bot_bot @ ( A > A > $o ) ) )
= ( bot_bot @ ( A > A > $o ) ) ) ) ).
% relpowp_bot
thf(fact_3591_relpowp__fun__conv,axiom,
! [A: $tType] :
( ( compow @ ( A > A > $o ) )
= ( ^ [N: nat,P: A > A > $o,X2: A,Y2: A] :
? [F3: nat > A] :
( ( ( F3 @ ( zero_zero @ nat ) )
= X2 )
& ( ( F3 @ N )
= Y2 )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ N )
=> ( P @ ( F3 @ I5 ) @ ( F3 @ ( suc @ I5 ) ) ) ) ) ) ) ).
% relpowp_fun_conv
thf(fact_3592_Nat_Ofunpow__code__def,axiom,
! [A: $tType] :
( ( funpow @ A )
= ( compow @ ( A > A ) ) ) ).
% Nat.funpow_code_def
thf(fact_3593_polyfun__rootbound,axiom,
! [A: $tType] :
( ( ( real_V8999393235501362500lgebra @ A )
& ( idom @ A ) )
=> ! [C2: nat > A,K: nat,N2: nat] :
( ( ( C2 @ K )
!= ( zero_zero @ A ) )
=> ( ( ord_less_eq @ nat @ K @ N2 )
=> ( ( finite_finite @ A
@ ( collect @ A
@ ^ [Z6: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ Z6 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( zero_zero @ A ) ) ) )
& ( ord_less_eq @ nat
@ ( finite_card @ A
@ ( collect @ A
@ ^ [Z6: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ Z6 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( zero_zero @ A ) ) ) )
@ N2 ) ) ) ) ) ).
% polyfun_rootbound
thf(fact_3594_card__Collect__less__nat,axiom,
! [N2: nat] :
( ( finite_card @ nat
@ ( collect @ nat
@ ^ [I5: nat] : ( ord_less @ nat @ I5 @ N2 ) ) )
= N2 ) ).
% card_Collect_less_nat
thf(fact_3595_card__atMost,axiom,
! [U: nat] :
( ( finite_card @ nat @ ( set_ord_atMost @ nat @ U ) )
= ( suc @ U ) ) ).
% card_atMost
thf(fact_3596_card__Collect__le__nat,axiom,
! [N2: nat] :
( ( finite_card @ nat
@ ( collect @ nat
@ ^ [I5: nat] : ( ord_less_eq @ nat @ I5 @ N2 ) ) )
= ( suc @ N2 ) ) ).
% card_Collect_le_nat
thf(fact_3597_card_Oempty,axiom,
! [A: $tType] :
( ( finite_card @ A @ ( bot_bot @ ( set @ A ) ) )
= ( zero_zero @ nat ) ) ).
% card.empty
thf(fact_3598_card_Oinfinite,axiom,
! [A: $tType,A4: set @ A] :
( ~ ( finite_finite @ A @ A4 )
=> ( ( finite_card @ A @ A4 )
= ( zero_zero @ nat ) ) ) ).
% card.infinite
thf(fact_3599_card__atLeastAtMost,axiom,
! [L: nat,U: nat] :
( ( finite_card @ nat @ ( set_or1337092689740270186AtMost @ nat @ L @ U ) )
= ( minus_minus @ nat @ ( suc @ U ) @ L ) ) ).
% card_atLeastAtMost
thf(fact_3600_card__0__eq,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( ( finite_card @ A @ A4 )
= ( zero_zero @ nat ) )
= ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% card_0_eq
thf(fact_3601_card__insert__disjoint,axiom,
! [A: $tType,A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ~ ( member2 @ A @ X @ A4 )
=> ( ( finite_card @ A @ ( insert2 @ A @ X @ A4 ) )
= ( suc @ ( finite_card @ A @ A4 ) ) ) ) ) ).
% card_insert_disjoint
thf(fact_3602_n__subsets,axiom,
! [A: $tType,A4: set @ A,K: nat] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_card @ ( set @ A )
@ ( collect @ ( set @ A )
@ ^ [B6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B6 @ A4 )
& ( ( finite_card @ A @ B6 )
= K ) ) ) )
= ( binomial @ ( finite_card @ A @ A4 ) @ K ) ) ) ).
% n_subsets
thf(fact_3603_infinite__arbitrarily__large,axiom,
! [A: $tType,A4: set @ A,N2: nat] :
( ~ ( finite_finite @ A @ A4 )
=> ? [B8: set @ A] :
( ( finite_finite @ A @ B8 )
& ( ( finite_card @ A @ B8 )
= N2 )
& ( ord_less_eq @ ( set @ A ) @ B8 @ A4 ) ) ) ).
% infinite_arbitrarily_large
thf(fact_3604_card__subset__eq,axiom,
! [A: $tType,B3: set @ A,A4: set @ A] :
( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( ( finite_card @ A @ A4 )
= ( finite_card @ A @ B3 ) )
=> ( A4 = B3 ) ) ) ) ).
% card_subset_eq
thf(fact_3605_card__le__if__inj__on__rel,axiom,
! [B: $tType,A: $tType,B3: set @ A,A4: set @ B,R2: B > A > $o] :
( ( finite_finite @ A @ B3 )
=> ( ! [A7: B] :
( ( member2 @ B @ A7 @ A4 )
=> ? [B9: A] :
( ( member2 @ A @ B9 @ B3 )
& ( R2 @ A7 @ B9 ) ) )
=> ( ! [A13: B,A24: B,B5: A] :
( ( member2 @ B @ A13 @ A4 )
=> ( ( member2 @ B @ A24 @ A4 )
=> ( ( member2 @ A @ B5 @ B3 )
=> ( ( R2 @ A13 @ B5 )
=> ( ( R2 @ A24 @ B5 )
=> ( A13 = A24 ) ) ) ) ) )
=> ( ord_less_eq @ nat @ ( finite_card @ B @ A4 ) @ ( finite_card @ A @ B3 ) ) ) ) ) ).
% card_le_if_inj_on_rel
thf(fact_3606_card__insert__le,axiom,
! [A: $tType,A4: set @ A,X: A] : ( ord_less_eq @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ ( insert2 @ A @ X @ A4 ) ) ) ).
% card_insert_le
thf(fact_3607_card__lists__length__eq,axiom,
! [A: $tType,A4: set @ A,N2: nat] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_card @ ( list @ A )
@ ( collect @ ( list @ A )
@ ^ [Xs2: list @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs2 ) @ A4 )
& ( ( size_size @ ( list @ A ) @ Xs2 )
= N2 ) ) ) )
= ( power_power @ nat @ ( finite_card @ A @ A4 ) @ N2 ) ) ) ).
% card_lists_length_eq
thf(fact_3608_card__eq__0__iff,axiom,
! [A: $tType,A4: set @ A] :
( ( ( finite_card @ A @ A4 )
= ( zero_zero @ nat ) )
= ( ( A4
= ( bot_bot @ ( set @ A ) ) )
| ~ ( finite_finite @ A @ A4 ) ) ) ).
% card_eq_0_iff
thf(fact_3609_card__ge__0__finite,axiom,
! [A: $tType,A4: set @ A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( finite_card @ A @ A4 ) )
=> ( finite_finite @ A @ A4 ) ) ).
% card_ge_0_finite
thf(fact_3610_card__Suc__eq__finite,axiom,
! [A: $tType,A4: set @ A,K: nat] :
( ( ( finite_card @ A @ A4 )
= ( suc @ K ) )
= ( ? [B4: A,B6: set @ A] :
( ( A4
= ( insert2 @ A @ B4 @ B6 ) )
& ~ ( member2 @ A @ B4 @ B6 )
& ( ( finite_card @ A @ B6 )
= K )
& ( finite_finite @ A @ B6 ) ) ) ) ).
% card_Suc_eq_finite
thf(fact_3611_card__insert__if,axiom,
! [A: $tType,A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( ( member2 @ A @ X @ A4 )
=> ( ( finite_card @ A @ ( insert2 @ A @ X @ A4 ) )
= ( finite_card @ A @ A4 ) ) )
& ( ~ ( member2 @ A @ X @ A4 )
=> ( ( finite_card @ A @ ( insert2 @ A @ X @ A4 ) )
= ( suc @ ( finite_card @ A @ A4 ) ) ) ) ) ) ).
% card_insert_if
thf(fact_3612_card__mono,axiom,
! [A: $tType,B3: set @ A,A4: set @ A] :
( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ B3 ) ) ) ) ).
% card_mono
thf(fact_3613_card__seteq,axiom,
! [A: $tType,B3: set @ A,A4: set @ A] :
( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( ord_less_eq @ nat @ ( finite_card @ A @ B3 ) @ ( finite_card @ A @ A4 ) )
=> ( A4 = B3 ) ) ) ) ).
% card_seteq
thf(fact_3614_obtain__subset__with__card__n,axiom,
! [A: $tType,N2: nat,S3: set @ A] :
( ( ord_less_eq @ nat @ N2 @ ( finite_card @ A @ S3 ) )
=> ~ ! [T6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ T6 @ S3 )
=> ( ( ( finite_card @ A @ T6 )
= N2 )
=> ~ ( finite_finite @ A @ T6 ) ) ) ) ).
% obtain_subset_with_card_n
thf(fact_3615_finite__if__finite__subsets__card__bdd,axiom,
! [A: $tType,F5: set @ A,C5: nat] :
( ! [G5: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ G5 @ F5 )
=> ( ( finite_finite @ A @ G5 )
=> ( ord_less_eq @ nat @ ( finite_card @ A @ G5 ) @ C5 ) ) )
=> ( ( finite_finite @ A @ F5 )
& ( ord_less_eq @ nat @ ( finite_card @ A @ F5 ) @ C5 ) ) ) ).
% finite_if_finite_subsets_card_bdd
thf(fact_3616_card__less__sym__Diff,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ A @ B3 )
=> ( ( ord_less @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ B3 ) )
=> ( ord_less @ nat @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) ) @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ B3 @ A4 ) ) ) ) ) ) ).
% card_less_sym_Diff
thf(fact_3617_card__le__sym__Diff,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ B3 ) )
=> ( ord_less_eq @ nat @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) ) @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ B3 @ A4 ) ) ) ) ) ) ).
% card_le_sym_Diff
thf(fact_3618_card__length,axiom,
! [A: $tType,Xs: list @ A] : ( ord_less_eq @ nat @ ( finite_card @ A @ ( set2 @ A @ Xs ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ).
% card_length
thf(fact_3619_card__1__singletonE,axiom,
! [A: $tType,A4: set @ A] :
( ( ( finite_card @ A @ A4 )
= ( one_one @ nat ) )
=> ~ ! [X5: A] :
( A4
!= ( insert2 @ A @ X5 @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% card_1_singletonE
thf(fact_3620_psubset__card__mono,axiom,
! [A: $tType,B3: set @ A,A4: set @ A] :
( ( finite_finite @ A @ B3 )
=> ( ( ord_less @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ B3 ) ) ) ) ).
% psubset_card_mono
thf(fact_3621_card__distinct,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( finite_card @ A @ ( set2 @ A @ Xs ) )
= ( size_size @ ( list @ A ) @ Xs ) )
=> ( distinct @ A @ Xs ) ) ).
% card_distinct
thf(fact_3622_distinct__card,axiom,
! [A: $tType,Xs: list @ A] :
( ( distinct @ A @ Xs )
=> ( ( finite_card @ A @ ( set2 @ A @ Xs ) )
= ( size_size @ ( list @ A ) @ Xs ) ) ) ).
% distinct_card
thf(fact_3623_relpowp__Suc__I2,axiom,
! [A: $tType,P2: A > A > $o,X: A,Y: A,N2: nat,Z: A] :
( ( P2 @ X @ Y )
=> ( ( compow @ ( A > A > $o ) @ N2 @ P2 @ Y @ Z )
=> ( compow @ ( A > A > $o ) @ ( suc @ N2 ) @ P2 @ X @ Z ) ) ) ).
% relpowp_Suc_I2
thf(fact_3624_relpowp__Suc__E2,axiom,
! [A: $tType,N2: nat,P2: A > A > $o,X: A,Z: A] :
( ( compow @ ( A > A > $o ) @ ( suc @ N2 ) @ P2 @ X @ Z )
=> ~ ! [Y4: A] :
( ( P2 @ X @ Y4 )
=> ~ ( compow @ ( A > A > $o ) @ N2 @ P2 @ Y4 @ Z ) ) ) ).
% relpowp_Suc_E2
thf(fact_3625_relpowp__Suc__D2,axiom,
! [A: $tType,N2: nat,P2: A > A > $o,X: A,Z: A] :
( ( compow @ ( A > A > $o ) @ ( suc @ N2 ) @ P2 @ X @ Z )
=> ? [Y4: A] :
( ( P2 @ X @ Y4 )
& ( compow @ ( A > A > $o ) @ N2 @ P2 @ Y4 @ Z ) ) ) ).
% relpowp_Suc_D2
thf(fact_3626_relpowp__Suc__I,axiom,
! [A: $tType,N2: nat,P2: A > A > $o,X: A,Y: A,Z: A] :
( ( compow @ ( A > A > $o ) @ N2 @ P2 @ X @ Y )
=> ( ( P2 @ Y @ Z )
=> ( compow @ ( A > A > $o ) @ ( suc @ N2 ) @ P2 @ X @ Z ) ) ) ).
% relpowp_Suc_I
thf(fact_3627_relpowp__Suc__E,axiom,
! [A: $tType,N2: nat,P2: A > A > $o,X: A,Z: A] :
( ( compow @ ( A > A > $o ) @ ( suc @ N2 ) @ P2 @ X @ Z )
=> ~ ! [Y4: A] :
( ( compow @ ( A > A > $o ) @ N2 @ P2 @ X @ Y4 )
=> ~ ( P2 @ Y4 @ Z ) ) ) ).
% relpowp_Suc_E
thf(fact_3628_relpowp_Osimps_I1_J,axiom,
! [A: $tType,R: A > A > $o] :
( ( compow @ ( A > A > $o ) @ ( zero_zero @ nat ) @ R )
= ( ^ [Y5: A,Z3: A] : ( Y5 = Z3 ) ) ) ).
% relpowp.simps(1)
thf(fact_3629_relpowp__0__E,axiom,
! [A: $tType,P2: A > A > $o,X: A,Y: A] :
( ( compow @ ( A > A > $o ) @ ( zero_zero @ nat ) @ P2 @ X @ Y )
=> ( X = Y ) ) ).
% relpowp_0_E
thf(fact_3630_relpowp__0__I,axiom,
! [A: $tType,P2: A > A > $o,X: A] : ( compow @ ( A > A > $o ) @ ( zero_zero @ nat ) @ P2 @ X @ X ) ).
% relpowp_0_I
thf(fact_3631_card__less__Suc2,axiom,
! [M7: set @ nat,I: nat] :
( ~ ( member2 @ nat @ ( zero_zero @ nat ) @ M7 )
=> ( ( finite_card @ nat
@ ( collect @ nat
@ ^ [K2: nat] :
( ( member2 @ nat @ ( suc @ K2 ) @ M7 )
& ( ord_less @ nat @ K2 @ I ) ) ) )
= ( finite_card @ nat
@ ( collect @ nat
@ ^ [K2: nat] :
( ( member2 @ nat @ K2 @ M7 )
& ( ord_less @ nat @ K2 @ ( suc @ I ) ) ) ) ) ) ) ).
% card_less_Suc2
thf(fact_3632_card__less__Suc,axiom,
! [M7: set @ nat,I: nat] :
( ( member2 @ nat @ ( zero_zero @ nat ) @ M7 )
=> ( ( suc
@ ( finite_card @ nat
@ ( collect @ nat
@ ^ [K2: nat] :
( ( member2 @ nat @ ( suc @ K2 ) @ M7 )
& ( ord_less @ nat @ K2 @ I ) ) ) ) )
= ( finite_card @ nat
@ ( collect @ nat
@ ^ [K2: nat] :
( ( member2 @ nat @ K2 @ M7 )
& ( ord_less @ nat @ K2 @ ( suc @ I ) ) ) ) ) ) ) ).
% card_less_Suc
thf(fact_3633_card__less,axiom,
! [M7: set @ nat,I: nat] :
( ( member2 @ nat @ ( zero_zero @ nat ) @ M7 )
=> ( ( finite_card @ nat
@ ( collect @ nat
@ ^ [K2: nat] :
( ( member2 @ nat @ K2 @ M7 )
& ( ord_less @ nat @ K2 @ ( suc @ I ) ) ) ) )
!= ( zero_zero @ nat ) ) ) ).
% card_less
thf(fact_3634_sum__Suc,axiom,
! [A: $tType,F2: A > nat,A4: set @ A] :
( ( groups7311177749621191930dd_sum @ A @ nat
@ ^ [X2: A] : ( suc @ ( F2 @ X2 ) )
@ A4 )
= ( plus_plus @ nat @ ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ A4 ) @ ( finite_card @ A @ A4 ) ) ) ).
% sum_Suc
thf(fact_3635_subset__card__intvl__is__intvl,axiom,
! [A4: set @ nat,K: nat] :
( ( ord_less_eq @ ( set @ nat ) @ A4 @ ( set_or7035219750837199246ssThan @ nat @ K @ ( plus_plus @ nat @ K @ ( finite_card @ nat @ A4 ) ) ) )
=> ( A4
= ( set_or7035219750837199246ssThan @ nat @ K @ ( plus_plus @ nat @ K @ ( finite_card @ nat @ A4 ) ) ) ) ) ).
% subset_card_intvl_is_intvl
thf(fact_3636_sum__bounded__above,axiom,
! [B: $tType,A: $tType] :
( ( ( ordere6911136660526730532id_add @ A )
& ( semiring_1 @ A ) )
=> ! [A4: set @ B,F2: B > A,K5: A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ I3 ) @ K5 ) )
=> ( ord_less_eq @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) @ ( times_times @ A @ ( semiring_1_of_nat @ A @ ( finite_card @ B @ A4 ) ) @ K5 ) ) ) ) ).
% sum_bounded_above
thf(fact_3637_sum__bounded__below,axiom,
! [A: $tType,B: $tType] :
( ( ( ordere6911136660526730532id_add @ A )
& ( semiring_1 @ A ) )
=> ! [A4: set @ B,K5: A,F2: B > A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ord_less_eq @ A @ K5 @ ( F2 @ I3 ) ) )
=> ( ord_less_eq @ A @ ( times_times @ A @ ( semiring_1_of_nat @ A @ ( finite_card @ B @ A4 ) ) @ K5 ) @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) ) ) ) ).
% sum_bounded_below
thf(fact_3638_card__gt__0__iff,axiom,
! [A: $tType,A4: set @ A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( finite_card @ A @ A4 ) )
= ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
& ( finite_finite @ A @ A4 ) ) ) ).
% card_gt_0_iff
thf(fact_3639_card__Suc__eq,axiom,
! [A: $tType,A4: set @ A,K: nat] :
( ( ( finite_card @ A @ A4 )
= ( suc @ K ) )
= ( ? [B4: A,B6: set @ A] :
( ( A4
= ( insert2 @ A @ B4 @ B6 ) )
& ~ ( member2 @ A @ B4 @ B6 )
& ( ( finite_card @ A @ B6 )
= K )
& ( ( K
= ( zero_zero @ nat ) )
=> ( B6
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% card_Suc_eq
thf(fact_3640_card__eq__SucD,axiom,
! [A: $tType,A4: set @ A,K: nat] :
( ( ( finite_card @ A @ A4 )
= ( suc @ K ) )
=> ? [B5: A,B8: set @ A] :
( ( A4
= ( insert2 @ A @ B5 @ B8 ) )
& ~ ( member2 @ A @ B5 @ B8 )
& ( ( finite_card @ A @ B8 )
= K )
& ( ( K
= ( zero_zero @ nat ) )
=> ( B8
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% card_eq_SucD
thf(fact_3641_card__1__singleton__iff,axiom,
! [A: $tType,A4: set @ A] :
( ( ( finite_card @ A @ A4 )
= ( suc @ ( zero_zero @ nat ) ) )
= ( ? [X2: A] :
( A4
= ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% card_1_singleton_iff
thf(fact_3642_card__le__Suc0__iff__eq,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( ord_less_eq @ nat @ ( finite_card @ A @ A4 ) @ ( suc @ ( zero_zero @ nat ) ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ! [Y2: A] :
( ( member2 @ A @ Y2 @ A4 )
=> ( X2 = Y2 ) ) ) ) ) ) ).
% card_le_Suc0_iff_eq
thf(fact_3643_card__le__Suc__iff,axiom,
! [A: $tType,N2: nat,A4: set @ A] :
( ( ord_less_eq @ nat @ ( suc @ N2 ) @ ( finite_card @ A @ A4 ) )
= ( ? [A5: A,B6: set @ A] :
( ( A4
= ( insert2 @ A @ A5 @ B6 ) )
& ~ ( member2 @ A @ A5 @ B6 )
& ( ord_less_eq @ nat @ N2 @ ( finite_card @ A @ B6 ) )
& ( finite_finite @ A @ B6 ) ) ) ) ).
% card_le_Suc_iff
thf(fact_3644_card__Diff1__le,axiom,
! [A: $tType,A4: set @ A,X: A] : ( ord_less_eq @ nat @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) @ ( finite_card @ A @ A4 ) ) ).
% card_Diff1_le
thf(fact_3645_card__Diff__subset,axiom,
! [A: $tType,B3: set @ A,A4: set @ A] :
( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) )
= ( minus_minus @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ B3 ) ) ) ) ) ).
% card_Diff_subset
thf(fact_3646_card__psubset,axiom,
! [A: $tType,B3: set @ A,A4: set @ A] :
( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( ord_less @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ B3 ) )
=> ( ord_less @ ( set @ A ) @ A4 @ B3 ) ) ) ) ).
% card_psubset
thf(fact_3647_diff__card__le__card__Diff,axiom,
! [A: $tType,B3: set @ A,A4: set @ A] :
( ( finite_finite @ A @ B3 )
=> ( ord_less_eq @ nat @ ( minus_minus @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ B3 ) ) @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) ) ) ) ).
% diff_card_le_card_Diff
thf(fact_3648_card__lists__length__le,axiom,
! [A: $tType,A4: set @ A,N2: nat] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_card @ ( list @ A )
@ ( collect @ ( list @ A )
@ ^ [Xs2: list @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs2 ) @ A4 )
& ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs2 ) @ N2 ) ) ) )
= ( groups7311177749621191930dd_sum @ nat @ nat @ ( power_power @ nat @ ( finite_card @ A @ A4 ) ) @ ( set_ord_atMost @ nat @ N2 ) ) ) ) ).
% card_lists_length_le
thf(fact_3649_card__roots__unity,axiom,
! [A: $tType] :
( ( ( real_V8999393235501362500lgebra @ A )
& ( idom @ A ) )
=> ! [N2: nat] :
( ( ord_less_eq @ nat @ ( one_one @ nat ) @ N2 )
=> ( ord_less_eq @ nat
@ ( finite_card @ A
@ ( collect @ A
@ ^ [Z6: A] :
( ( power_power @ A @ Z6 @ N2 )
= ( one_one @ A ) ) ) )
@ N2 ) ) ) ).
% card_roots_unity
thf(fact_3650_subset__eq__atLeast0__lessThan__card,axiom,
! [N7: set @ nat,N2: nat] :
( ( ord_less_eq @ ( set @ nat ) @ N7 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) )
=> ( ord_less_eq @ nat @ ( finite_card @ nat @ N7 ) @ N2 ) ) ).
% subset_eq_atLeast0_lessThan_card
thf(fact_3651_card__sum__le__nat__sum,axiom,
! [S3: set @ nat] :
( ord_less_eq @ nat
@ ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [X2: nat] : X2
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( finite_card @ nat @ S3 ) ) )
@ ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [X2: nat] : X2
@ S3 ) ) ).
% card_sum_le_nat_sum
thf(fact_3652_card__nth__roots,axiom,
! [C2: complex,N2: nat] :
( ( C2
!= ( zero_zero @ complex ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( finite_card @ complex
@ ( collect @ complex
@ ^ [Z6: complex] :
( ( power_power @ complex @ Z6 @ N2 )
= C2 ) ) )
= N2 ) ) ) ).
% card_nth_roots
thf(fact_3653_card__roots__unity__eq,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( finite_card @ complex
@ ( collect @ complex
@ ^ [Z6: complex] :
( ( power_power @ complex @ Z6 @ N2 )
= ( one_one @ complex ) ) ) )
= N2 ) ) ).
% card_roots_unity_eq
thf(fact_3654_card__2__iff,axiom,
! [A: $tType,S3: set @ A] :
( ( ( finite_card @ A @ S3 )
= ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) )
= ( ? [X2: A,Y2: A] :
( ( S3
= ( insert2 @ A @ X2 @ ( insert2 @ A @ Y2 @ ( bot_bot @ ( set @ A ) ) ) ) )
& ( X2 != Y2 ) ) ) ) ).
% card_2_iff
thf(fact_3655_card__3__iff,axiom,
! [A: $tType,S3: set @ A] :
( ( ( finite_card @ A @ S3 )
= ( numeral_numeral @ nat @ ( bit1 @ one2 ) ) )
= ( ? [X2: A,Y2: A,Z6: A] :
( ( S3
= ( insert2 @ A @ X2 @ ( insert2 @ A @ Y2 @ ( insert2 @ A @ Z6 @ ( bot_bot @ ( set @ A ) ) ) ) ) )
& ( X2 != Y2 )
& ( Y2 != Z6 )
& ( X2 != Z6 ) ) ) ) ).
% card_3_iff
thf(fact_3656_odd__card__imp__not__empty,axiom,
! [A: $tType,A4: set @ A] :
( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( finite_card @ A @ A4 ) )
=> ( A4
!= ( bot_bot @ ( set @ A ) ) ) ) ).
% odd_card_imp_not_empty
thf(fact_3657_card_Oremove,axiom,
! [A: $tType,A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( finite_card @ A @ A4 )
= ( suc @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ).
% card.remove
thf(fact_3658_card_Oinsert__remove,axiom,
! [A: $tType,A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_card @ A @ ( insert2 @ A @ X @ A4 ) )
= ( suc @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% card.insert_remove
thf(fact_3659_card__Suc__Diff1,axiom,
! [A: $tType,A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( suc @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) )
= ( finite_card @ A @ A4 ) ) ) ) ).
% card_Suc_Diff1
thf(fact_3660_card__Diff1__less,axiom,
! [A: $tType,A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ord_less @ nat @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) @ ( finite_card @ A @ A4 ) ) ) ) ).
% card_Diff1_less
thf(fact_3661_card__Diff2__less,axiom,
! [A: $tType,A4: set @ A,X: A,Y: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( member2 @ A @ Y @ A4 )
=> ( ord_less @ nat @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) @ ( insert2 @ A @ Y @ ( bot_bot @ ( set @ A ) ) ) ) ) @ ( finite_card @ A @ A4 ) ) ) ) ) ).
% card_Diff2_less
thf(fact_3662_card__Diff1__less__iff,axiom,
! [A: $tType,A4: set @ A,X: A] :
( ( ord_less @ nat @ ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) @ ( finite_card @ A @ A4 ) )
= ( ( finite_finite @ A @ A4 )
& ( member2 @ A @ X @ A4 ) ) ) ).
% card_Diff1_less_iff
thf(fact_3663_card__Diff__singleton__if,axiom,
! [A: $tType,X: A,A4: set @ A] :
( ( ( member2 @ A @ X @ A4 )
=> ( ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( minus_minus @ nat @ ( finite_card @ A @ A4 ) @ ( one_one @ nat ) ) ) )
& ( ~ ( member2 @ A @ X @ A4 )
=> ( ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( finite_card @ A @ A4 ) ) ) ) ).
% card_Diff_singleton_if
thf(fact_3664_card__Diff__singleton,axiom,
! [A: $tType,X: A,A4: set @ A] :
( ( member2 @ A @ X @ A4 )
=> ( ( finite_card @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( minus_minus @ nat @ ( finite_card @ A @ A4 ) @ ( one_one @ nat ) ) ) ) ).
% card_Diff_singleton
thf(fact_3665_card__lists__distinct__length__eq_H,axiom,
! [A: $tType,K: nat,A4: set @ A] :
( ( ord_less @ nat @ K @ ( finite_card @ A @ A4 ) )
=> ( ( finite_card @ ( list @ A )
@ ( collect @ ( list @ A )
@ ^ [Xs2: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs2 )
= K )
& ( distinct @ A @ Xs2 )
& ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs2 ) @ A4 ) ) ) )
= ( groups7121269368397514597t_prod @ nat @ nat
@ ^ [X2: nat] : X2
@ ( set_or1337092689740270186AtMost @ nat @ ( plus_plus @ nat @ ( minus_minus @ nat @ ( finite_card @ A @ A4 ) @ K ) @ ( one_one @ nat ) ) @ ( finite_card @ A @ A4 ) ) ) ) ) ).
% card_lists_distinct_length_eq'
thf(fact_3666_card__lists__distinct__length__eq,axiom,
! [A: $tType,A4: set @ A,K: nat] :
( ( finite_finite @ A @ A4 )
=> ( ( ord_less_eq @ nat @ K @ ( finite_card @ A @ A4 ) )
=> ( ( finite_card @ ( list @ A )
@ ( collect @ ( list @ A )
@ ^ [Xs2: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs2 )
= K )
& ( distinct @ A @ Xs2 )
& ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs2 ) @ A4 ) ) ) )
= ( groups7121269368397514597t_prod @ nat @ nat
@ ^ [X2: nat] : X2
@ ( set_or1337092689740270186AtMost @ nat @ ( plus_plus @ nat @ ( minus_minus @ nat @ ( finite_card @ A @ A4 ) @ K ) @ ( one_one @ nat ) ) @ ( finite_card @ A @ A4 ) ) ) ) ) ) ).
% card_lists_distinct_length_eq
thf(fact_3667_prod__le__power,axiom,
! [B: $tType,A: $tType] :
( ( linordered_semidom @ A )
=> ! [A4: set @ B,F2: B > A,N2: A,K: nat] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( F2 @ I3 ) )
& ( ord_less_eq @ A @ ( F2 @ I3 ) @ N2 ) ) )
=> ( ( ord_less_eq @ nat @ ( finite_card @ B @ A4 ) @ K )
=> ( ( ord_less_eq @ A @ ( one_one @ A ) @ N2 )
=> ( ord_less_eq @ A @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) @ ( power_power @ A @ N2 @ K ) ) ) ) ) ) ).
% prod_le_power
thf(fact_3668_sum__bounded__above__strict,axiom,
! [B: $tType,A: $tType] :
( ( ( ordere8940638589300402666id_add @ A )
& ( semiring_1 @ A ) )
=> ! [A4: set @ B,F2: B > A,K5: A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ord_less @ A @ ( F2 @ I3 ) @ K5 ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( finite_card @ B @ A4 ) )
=> ( ord_less @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) @ ( times_times @ A @ ( semiring_1_of_nat @ A @ ( finite_card @ B @ A4 ) ) @ K5 ) ) ) ) ) ).
% sum_bounded_above_strict
thf(fact_3669_sum__bounded__above__divide,axiom,
! [B: $tType,A: $tType] :
( ( linordered_field @ A )
=> ! [A4: set @ B,F2: B > A,K5: A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ I3 ) @ ( divide_divide @ A @ K5 @ ( semiring_1_of_nat @ A @ ( finite_card @ B @ A4 ) ) ) ) )
=> ( ( finite_finite @ B @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ord_less_eq @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) @ K5 ) ) ) ) ) ).
% sum_bounded_above_divide
thf(fact_3670_card__insert__le__m1,axiom,
! [A: $tType,N2: nat,Y: set @ A,X: A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less_eq @ nat @ ( finite_card @ A @ Y ) @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) )
=> ( ord_less_eq @ nat @ ( finite_card @ A @ ( insert2 @ A @ X @ Y ) ) @ N2 ) ) ) ).
% card_insert_le_m1
thf(fact_3671_polyfun__roots__card,axiom,
! [A: $tType] :
( ( ( real_V8999393235501362500lgebra @ A )
& ( idom @ A ) )
=> ! [C2: nat > A,K: nat,N2: nat] :
( ( ( C2 @ K )
!= ( zero_zero @ A ) )
=> ( ( ord_less_eq @ nat @ K @ N2 )
=> ( ord_less_eq @ nat
@ ( finite_card @ A
@ ( collect @ A
@ ^ [Z6: A] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ Z6 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) )
= ( zero_zero @ A ) ) ) )
@ N2 ) ) ) ) ).
% polyfun_roots_card
thf(fact_3672_relpowp__E2,axiom,
! [A: $tType,N2: nat,P2: A > A > $o,X: A,Z: A] :
( ( compow @ ( A > A > $o ) @ N2 @ P2 @ X @ Z )
=> ( ( ( N2
= ( zero_zero @ nat ) )
=> ( X != Z ) )
=> ~ ! [Y4: A,M3: nat] :
( ( N2
= ( suc @ M3 ) )
=> ( ( P2 @ X @ Y4 )
=> ~ ( compow @ ( A > A > $o ) @ M3 @ P2 @ Y4 @ Z ) ) ) ) ) ).
% relpowp_E2
thf(fact_3673_relpowp__E,axiom,
! [A: $tType,N2: nat,P2: A > A > $o,X: A,Z: A] :
( ( compow @ ( A > A > $o ) @ N2 @ P2 @ X @ Z )
=> ( ( ( N2
= ( zero_zero @ nat ) )
=> ( X != Z ) )
=> ~ ! [Y4: A,M3: nat] :
( ( N2
= ( suc @ M3 ) )
=> ( ( compow @ ( A > A > $o ) @ M3 @ P2 @ X @ Y4 )
=> ~ ( P2 @ Y4 @ Z ) ) ) ) ) ).
% relpowp_E
thf(fact_3674_max__nat_Osemilattice__neutr__order__axioms,axiom,
( semila1105856199041335345_order @ nat @ ( ord_max @ nat ) @ ( zero_zero @ nat )
@ ^ [X2: nat,Y2: nat] : ( ord_less_eq @ nat @ Y2 @ X2 )
@ ^ [X2: nat,Y2: nat] : ( ord_less @ nat @ Y2 @ X2 ) ) ).
% max_nat.semilattice_neutr_order_axioms
thf(fact_3675_set__removeAll,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( set2 @ A @ ( removeAll @ A @ X @ Xs ) )
= ( minus_minus @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% set_removeAll
thf(fact_3676_times__int_Oabs__eq,axiom,
! [Xa2: product_prod @ nat @ nat,X: product_prod @ nat @ nat] :
( ( times_times @ int @ ( abs_Integ @ Xa2 ) @ ( abs_Integ @ X ) )
= ( abs_Integ
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ X2 @ U2 ) @ ( times_times @ nat @ Y2 @ V5 ) ) @ ( plus_plus @ nat @ ( times_times @ nat @ X2 @ V5 ) @ ( times_times @ nat @ Y2 @ U2 ) ) ) )
@ Xa2
@ X ) ) ) ).
% times_int.abs_eq
thf(fact_3677_Gcd__remove0__nat,axiom,
! [M7: set @ nat] :
( ( finite_finite @ nat @ M7 )
=> ( ( gcd_Gcd @ nat @ M7 )
= ( gcd_Gcd @ nat @ ( minus_minus @ ( set @ nat ) @ M7 @ ( insert2 @ nat @ ( zero_zero @ nat ) @ ( bot_bot @ ( set @ nat ) ) ) ) ) ) ) ).
% Gcd_remove0_nat
thf(fact_3678_removeAll__id,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( removeAll @ A @ X @ Xs )
= Xs ) ) ).
% removeAll_id
thf(fact_3679_Gcd__empty,axiom,
! [A: $tType] :
( ( semiring_Gcd @ A )
=> ( ( gcd_Gcd @ A @ ( bot_bot @ ( set @ A ) ) )
= ( zero_zero @ A ) ) ) ).
% Gcd_empty
thf(fact_3680_Gcd__0__iff,axiom,
! [A: $tType] :
( ( semiring_Gcd @ A )
=> ! [A4: set @ A] :
( ( ( gcd_Gcd @ A @ A4 )
= ( zero_zero @ A ) )
= ( ord_less_eq @ ( set @ A ) @ A4 @ ( insert2 @ A @ ( zero_zero @ A ) @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% Gcd_0_iff
thf(fact_3681_int_Oabs__induct,axiom,
! [P2: int > $o,X: int] :
( ! [Y4: product_prod @ nat @ nat] : ( P2 @ ( abs_Integ @ Y4 ) )
=> ( P2 @ X ) ) ).
% int.abs_induct
thf(fact_3682_semilattice__neutr__order_Oeq__neutr__iff,axiom,
! [A: $tType,F2: A > A > A,Z: A,Less_eq: A > A > $o,Less: A > A > $o,A3: A,B2: A] :
( ( semila1105856199041335345_order @ A @ F2 @ Z @ Less_eq @ Less )
=> ( ( ( F2 @ A3 @ B2 )
= Z )
= ( ( A3 = Z )
& ( B2 = Z ) ) ) ) ).
% semilattice_neutr_order.eq_neutr_iff
thf(fact_3683_semilattice__neutr__order_Oneutr__eq__iff,axiom,
! [A: $tType,F2: A > A > A,Z: A,Less_eq: A > A > $o,Less: A > A > $o,A3: A,B2: A] :
( ( semila1105856199041335345_order @ A @ F2 @ Z @ Less_eq @ Less )
=> ( ( Z
= ( F2 @ A3 @ B2 ) )
= ( ( A3 = Z )
& ( B2 = Z ) ) ) ) ).
% semilattice_neutr_order.neutr_eq_iff
thf(fact_3684_eq__Abs__Integ,axiom,
! [Z: int] :
~ ! [X5: nat,Y4: nat] :
( Z
!= ( abs_Integ @ ( product_Pair @ nat @ nat @ X5 @ Y4 ) ) ) ).
% eq_Abs_Integ
thf(fact_3685_distinct__removeAll,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( distinct @ A @ Xs )
=> ( distinct @ A @ ( removeAll @ A @ X @ Xs ) ) ) ).
% distinct_removeAll
thf(fact_3686_nat_Oabs__eq,axiom,
! [X: product_prod @ nat @ nat] :
( ( nat2 @ ( abs_Integ @ X ) )
= ( product_case_prod @ nat @ nat @ nat @ ( minus_minus @ nat ) @ X ) ) ).
% nat.abs_eq
thf(fact_3687_length__removeAll__less__eq,axiom,
! [A: $tType,X: A,Xs: list @ A] : ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ ( removeAll @ A @ X @ Xs ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ).
% length_removeAll_less_eq
thf(fact_3688_distinct__remove1__removeAll,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( distinct @ A @ Xs )
=> ( ( remove1 @ A @ X @ Xs )
= ( removeAll @ A @ X @ Xs ) ) ) ).
% distinct_remove1_removeAll
thf(fact_3689_zero__int__def,axiom,
( ( zero_zero @ int )
= ( abs_Integ @ ( product_Pair @ nat @ nat @ ( zero_zero @ nat ) @ ( zero_zero @ nat ) ) ) ) ).
% zero_int_def
thf(fact_3690_int__def,axiom,
( ( semiring_1_of_nat @ int )
= ( ^ [N: nat] : ( abs_Integ @ ( product_Pair @ nat @ nat @ N @ ( zero_zero @ nat ) ) ) ) ) ).
% int_def
thf(fact_3691_length__removeAll__less,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ord_less @ nat @ ( size_size @ ( list @ A ) @ ( removeAll @ A @ X @ Xs ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ) ).
% length_removeAll_less
thf(fact_3692_uminus__int_Oabs__eq,axiom,
! [X: product_prod @ nat @ nat] :
( ( uminus_uminus @ int @ ( abs_Integ @ X ) )
= ( abs_Integ
@ ( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [X2: nat,Y2: nat] : ( product_Pair @ nat @ nat @ Y2 @ X2 )
@ X ) ) ) ).
% uminus_int.abs_eq
thf(fact_3693_one__int__def,axiom,
( ( one_one @ int )
= ( abs_Integ @ ( product_Pair @ nat @ nat @ ( one_one @ nat ) @ ( zero_zero @ nat ) ) ) ) ).
% one_int_def
thf(fact_3694_of__int_Oabs__eq,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [X: product_prod @ nat @ nat] :
( ( ring_1_of_int @ A @ ( abs_Integ @ X ) )
= ( product_case_prod @ nat @ nat @ A
@ ^ [I5: nat,J3: nat] : ( minus_minus @ A @ ( semiring_1_of_nat @ A @ I5 ) @ ( semiring_1_of_nat @ A @ J3 ) )
@ X ) ) ) ).
% of_int.abs_eq
thf(fact_3695_less__int_Oabs__eq,axiom,
! [Xa2: product_prod @ nat @ nat,X: product_prod @ nat @ nat] :
( ( ord_less @ int @ ( abs_Integ @ Xa2 ) @ ( abs_Integ @ X ) )
= ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Y2 ) ) )
@ Xa2
@ X ) ) ).
% less_int.abs_eq
thf(fact_3696_less__eq__int_Oabs__eq,axiom,
! [Xa2: product_prod @ nat @ nat,X: product_prod @ nat @ nat] :
( ( ord_less_eq @ int @ ( abs_Integ @ Xa2 ) @ ( abs_Integ @ X ) )
= ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less_eq @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Y2 ) ) )
@ Xa2
@ X ) ) ).
% less_eq_int.abs_eq
thf(fact_3697_plus__int_Oabs__eq,axiom,
! [Xa2: product_prod @ nat @ nat,X: product_prod @ nat @ nat] :
( ( plus_plus @ int @ ( abs_Integ @ Xa2 ) @ ( abs_Integ @ X ) )
= ( abs_Integ
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ X2 @ U2 ) @ ( plus_plus @ nat @ Y2 @ V5 ) ) )
@ Xa2
@ X ) ) ) ).
% plus_int.abs_eq
thf(fact_3698_minus__int_Oabs__eq,axiom,
! [Xa2: product_prod @ nat @ nat,X: product_prod @ nat @ nat] :
( ( minus_minus @ int @ ( abs_Integ @ Xa2 ) @ ( abs_Integ @ X ) )
= ( abs_Integ
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ Y2 @ U2 ) ) )
@ Xa2
@ X ) ) ) ).
% minus_int.abs_eq
thf(fact_3699_finite__enumerate,axiom,
! [S3: set @ nat] :
( ( finite_finite @ nat @ S3 )
=> ? [R3: nat > nat] :
( ( strict_mono_on @ nat @ nat @ R3 @ ( set_ord_lessThan @ nat @ ( finite_card @ nat @ S3 ) ) )
& ! [N5: nat] :
( ( ord_less @ nat @ N5 @ ( finite_card @ nat @ S3 ) )
=> ( member2 @ nat @ ( R3 @ N5 ) @ S3 ) ) ) ) ).
% finite_enumerate
thf(fact_3700_semiring__char__def,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( semiri4206861660011772517g_char @ A )
= ( ^ [Uu4: itself @ A] :
( gcd_Gcd @ nat
@ ( collect @ nat
@ ^ [N: nat] :
( ( semiring_1_of_nat @ A @ N )
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% semiring_char_def
thf(fact_3701_sndI,axiom,
! [A: $tType,B: $tType,X: product_prod @ A @ B,Y: A,Z: B] :
( ( X
= ( product_Pair @ A @ B @ Y @ Z ) )
=> ( ( product_snd @ A @ B @ X )
= Z ) ) ).
% sndI
thf(fact_3702_eq__snd__iff,axiom,
! [A: $tType,B: $tType,B2: A,P4: product_prod @ B @ A] :
( ( B2
= ( product_snd @ B @ A @ P4 ) )
= ( ? [A5: B] :
( P4
= ( product_Pair @ B @ A @ A5 @ B2 ) ) ) ) ).
% eq_snd_iff
thf(fact_3703_prod_Osize__neq,axiom,
! [A: $tType,B: $tType,X: product_prod @ A @ B] :
( ( size_size @ ( product_prod @ A @ B ) @ X )
!= ( zero_zero @ nat ) ) ).
% prod.size_neq
thf(fact_3704_sum_Osize__neq,axiom,
! [A: $tType,B: $tType,X: sum_sum @ A @ B] :
( ( size_size @ ( sum_sum @ A @ B ) @ X )
!= ( zero_zero @ nat ) ) ).
% sum.size_neq
thf(fact_3705_eq__fst__iff,axiom,
! [A: $tType,B: $tType,A3: A,P4: product_prod @ A @ B] :
( ( A3
= ( product_fst @ A @ B @ P4 ) )
= ( ? [B4: B] :
( P4
= ( product_Pair @ A @ B @ A3 @ B4 ) ) ) ) ).
% eq_fst_iff
thf(fact_3706_fstI,axiom,
! [B: $tType,A: $tType,X: product_prod @ A @ B,Y: A,Z: B] :
( ( X
= ( product_Pair @ A @ B @ Y @ Z ) )
=> ( ( product_fst @ A @ B @ X )
= Y ) ) ).
% fstI
thf(fact_3707_strict__mono__on__def,axiom,
! [B: $tType,A: $tType] :
( ( ( ord @ A )
& ( ord @ B ) )
=> ( ( strict_mono_on @ A @ B )
= ( ^ [F3: A > B,A6: set @ A] :
! [R4: A,S7: A] :
( ( ( member2 @ A @ R4 @ A6 )
& ( member2 @ A @ S7 @ A6 )
& ( ord_less @ A @ R4 @ S7 ) )
=> ( ord_less @ B @ ( F3 @ R4 ) @ ( F3 @ S7 ) ) ) ) ) ) ).
% strict_mono_on_def
thf(fact_3708_strict__mono__onI,axiom,
! [B: $tType,A: $tType] :
( ( ( ord @ A )
& ( ord @ B ) )
=> ! [A4: set @ A,F2: A > B] :
( ! [R3: A,S2: A] :
( ( member2 @ A @ R3 @ A4 )
=> ( ( member2 @ A @ S2 @ A4 )
=> ( ( ord_less @ A @ R3 @ S2 )
=> ( ord_less @ B @ ( F2 @ R3 ) @ ( F2 @ S2 ) ) ) ) )
=> ( strict_mono_on @ A @ B @ F2 @ A4 ) ) ) ).
% strict_mono_onI
thf(fact_3709_strict__mono__onD,axiom,
! [B: $tType,A: $tType] :
( ( ( ord @ A )
& ( ord @ B ) )
=> ! [F2: A > B,A4: set @ A,R2: A,S: A] :
( ( strict_mono_on @ A @ B @ F2 @ A4 )
=> ( ( member2 @ A @ R2 @ A4 )
=> ( ( member2 @ A @ S @ A4 )
=> ( ( ord_less @ A @ R2 @ S )
=> ( ord_less @ B @ ( F2 @ R2 ) @ ( F2 @ S ) ) ) ) ) ) ) ).
% strict_mono_onD
thf(fact_3710_strict__mono__on__leD,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( preorder @ B ) )
=> ! [F2: A > B,A4: set @ A,X: A,Y: A] :
( ( strict_mono_on @ A @ B @ F2 @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( member2 @ A @ Y @ A4 )
=> ( ( ord_less_eq @ A @ X @ Y )
=> ( ord_less_eq @ B @ ( F2 @ X ) @ ( F2 @ Y ) ) ) ) ) ) ) ).
% strict_mono_on_leD
thf(fact_3711_less__eq__int_Orep__eq,axiom,
( ( ord_less_eq @ int )
= ( ^ [X2: int,Xa3: int] :
( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [Y2: nat,Z6: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less_eq @ nat @ ( plus_plus @ nat @ Y2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Z6 ) ) )
@ ( rep_Integ @ X2 )
@ ( rep_Integ @ Xa3 ) ) ) ) ).
% less_eq_int.rep_eq
thf(fact_3712_less__int_Orep__eq,axiom,
( ( ord_less @ int )
= ( ^ [X2: int,Xa3: int] :
( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [Y2: nat,Z6: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less @ nat @ ( plus_plus @ nat @ Y2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Z6 ) ) )
@ ( rep_Integ @ X2 )
@ ( rep_Integ @ Xa3 ) ) ) ) ).
% less_int.rep_eq
thf(fact_3713_prod__encode__def,axiom,
( nat_prod_encode
= ( product_case_prod @ nat @ nat @ nat
@ ^ [M2: nat,N: nat] : ( plus_plus @ nat @ ( nat_triangle @ ( plus_plus @ nat @ M2 @ N ) ) @ M2 ) ) ) ).
% prod_encode_def
thf(fact_3714_add__neg__numeral__special_I4_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [N2: num] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( numeral_numeral @ A @ N2 ) )
= ( neg_numeral_sub @ A @ N2 @ one2 ) ) ) ).
% add_neg_numeral_special(4)
thf(fact_3715_sub__num__simps_I1_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ( ( neg_numeral_sub @ A @ one2 @ one2 )
= ( zero_zero @ A ) ) ) ).
% sub_num_simps(1)
thf(fact_3716_add__neg__numeral__simps_I1_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [M: num,N2: num] :
( ( plus_plus @ A @ ( numeral_numeral @ A @ M ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ N2 ) ) )
= ( neg_numeral_sub @ A @ M @ N2 ) ) ) ).
% add_neg_numeral_simps(1)
thf(fact_3717_add__neg__numeral__simps_I2_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [M: num,N2: num] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( numeral_numeral @ A @ N2 ) )
= ( neg_numeral_sub @ A @ N2 @ M ) ) ) ).
% add_neg_numeral_simps(2)
thf(fact_3718_semiring__norm_I167_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [V2: num,W2: num,Y: A] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) @ ( plus_plus @ A @ ( numeral_numeral @ A @ W2 ) @ Y ) )
= ( plus_plus @ A @ ( neg_numeral_sub @ A @ W2 @ V2 ) @ Y ) ) ) ).
% semiring_norm(167)
thf(fact_3719_semiring__norm_I166_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [V2: num,W2: num,Y: A] :
( ( plus_plus @ A @ ( numeral_numeral @ A @ V2 ) @ ( plus_plus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ W2 ) ) @ Y ) )
= ( plus_plus @ A @ ( neg_numeral_sub @ A @ V2 @ W2 ) @ Y ) ) ) ).
% semiring_norm(166)
thf(fact_3720_add__neg__numeral__special_I1_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [M: num] :
( ( plus_plus @ A @ ( one_one @ A ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) )
= ( neg_numeral_sub @ A @ one2 @ M ) ) ) ).
% add_neg_numeral_special(1)
thf(fact_3721_add__neg__numeral__special_I2_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [M: num] :
( ( plus_plus @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ M ) ) @ ( one_one @ A ) )
= ( neg_numeral_sub @ A @ one2 @ M ) ) ) ).
% add_neg_numeral_special(2)
thf(fact_3722_add__neg__numeral__special_I3_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ! [M: num] :
( ( plus_plus @ A @ ( numeral_numeral @ A @ M ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( neg_numeral_sub @ A @ M @ one2 ) ) ) ).
% add_neg_numeral_special(3)
thf(fact_3723_le__prod__encode__1,axiom,
! [A3: nat,B2: nat] : ( ord_less_eq @ nat @ A3 @ ( nat_prod_encode @ ( product_Pair @ nat @ nat @ A3 @ B2 ) ) ) ).
% le_prod_encode_1
thf(fact_3724_le__prod__encode__2,axiom,
! [B2: nat,A3: nat] : ( ord_less_eq @ nat @ B2 @ ( nat_prod_encode @ ( product_Pair @ nat @ nat @ A3 @ B2 ) ) ) ).
% le_prod_encode_2
thf(fact_3725_sub__non__negative,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: num,M: num] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( neg_numeral_sub @ A @ N2 @ M ) )
= ( ord_less_eq @ num @ M @ N2 ) ) ) ).
% sub_non_negative
thf(fact_3726_sub__non__positive,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: num,M: num] :
( ( ord_less_eq @ A @ ( neg_numeral_sub @ A @ N2 @ M ) @ ( zero_zero @ A ) )
= ( ord_less_eq @ num @ N2 @ M ) ) ) ).
% sub_non_positive
thf(fact_3727_sub__negative,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: num,M: num] :
( ( ord_less @ A @ ( neg_numeral_sub @ A @ N2 @ M ) @ ( zero_zero @ A ) )
= ( ord_less @ num @ N2 @ M ) ) ) ).
% sub_negative
thf(fact_3728_sub__positive,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [N2: num,M: num] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( neg_numeral_sub @ A @ N2 @ M ) )
= ( ord_less @ num @ M @ N2 ) ) ) ).
% sub_positive
thf(fact_3729_nat_Orep__eq,axiom,
( nat2
= ( ^ [X2: int] : ( product_case_prod @ nat @ nat @ nat @ ( minus_minus @ nat ) @ ( rep_Integ @ X2 ) ) ) ) ).
% nat.rep_eq
thf(fact_3730_of__int_Orep__eq,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( ( ring_1_of_int @ A )
= ( ^ [X2: int] :
( product_case_prod @ nat @ nat @ A
@ ^ [I5: nat,J3: nat] : ( minus_minus @ A @ ( semiring_1_of_nat @ A @ I5 ) @ ( semiring_1_of_nat @ A @ J3 ) )
@ ( rep_Integ @ X2 ) ) ) ) ) ).
% of_int.rep_eq
thf(fact_3731_prod__encode__prod__decode__aux,axiom,
! [K: nat,M: nat] :
( ( nat_prod_encode @ ( nat_prod_decode_aux @ K @ M ) )
= ( plus_plus @ nat @ ( nat_triangle @ K ) @ M ) ) ).
% prod_encode_prod_decode_aux
thf(fact_3732_uminus__int__def,axiom,
( ( uminus_uminus @ int )
= ( map_fun @ int @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ int @ rep_Integ @ abs_Integ
@ ( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [X2: nat,Y2: nat] : ( product_Pair @ nat @ nat @ Y2 @ X2 ) ) ) ) ).
% uminus_int_def
thf(fact_3733_num__of__nat_Osimps_I2_J,axiom,
! [N2: nat] :
( ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( num_of_nat @ ( suc @ N2 ) )
= ( inc @ ( num_of_nat @ N2 ) ) ) )
& ( ~ ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( num_of_nat @ ( suc @ N2 ) )
= one2 ) ) ) ).
% num_of_nat.simps(2)
thf(fact_3734_sorted__list__of__set_Osorted__key__list__of__set__remove,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( linord4507533701916653071of_set @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( remove1 @ A @ X @ ( linord4507533701916653071of_set @ A @ A4 ) ) ) ) ) ).
% sorted_list_of_set.sorted_key_list_of_set_remove
thf(fact_3735_in__set__product__lists__length,axiom,
! [A: $tType,Xs: list @ A,Xss: list @ ( list @ A )] :
( ( member2 @ ( list @ A ) @ Xs @ ( set2 @ ( list @ A ) @ ( product_lists @ A @ Xss ) ) )
=> ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ ( list @ A ) ) @ Xss ) ) ) ).
% in_set_product_lists_length
thf(fact_3736_sorted__list__of__set_Oset__sorted__key__list__of__set,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( set2 @ A @ ( linord4507533701916653071of_set @ A @ A4 ) )
= A4 ) ) ) ).
% sorted_list_of_set.set_sorted_key_list_of_set
thf(fact_3737_sorted__list__of__set_Olength__sorted__key__list__of__set,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ( size_size @ ( list @ A ) @ ( linord4507533701916653071of_set @ A @ A4 ) )
= ( finite_card @ A @ A4 ) ) ) ).
% sorted_list_of_set.length_sorted_key_list_of_set
thf(fact_3738_sorted__list__of__set_Osorted__key__list__of__set__inject,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( ( linord4507533701916653071of_set @ A @ A4 )
= ( linord4507533701916653071of_set @ A @ B3 ) )
=> ( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ A @ B3 )
=> ( A4 = B3 ) ) ) ) ) ).
% sorted_list_of_set.sorted_key_list_of_set_inject
thf(fact_3739_sorted__list__of__set_Odistinct__sorted__key__list__of__set,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] : ( distinct @ A @ ( linord4507533701916653071of_set @ A @ A4 ) ) ) ).
% sorted_list_of_set.distinct_sorted_key_list_of_set
thf(fact_3740_num__of__nat_Osimps_I1_J,axiom,
( ( num_of_nat @ ( zero_zero @ nat ) )
= one2 ) ).
% num_of_nat.simps(1)
thf(fact_3741_numeral__num__of__nat,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( numeral_numeral @ nat @ ( num_of_nat @ N2 ) )
= N2 ) ) ).
% numeral_num_of_nat
thf(fact_3742_num__of__nat__One,axiom,
! [N2: nat] :
( ( ord_less_eq @ nat @ N2 @ ( one_one @ nat ) )
=> ( ( num_of_nat @ N2 )
= one2 ) ) ).
% num_of_nat_One
thf(fact_3743_distinct__product__lists,axiom,
! [A: $tType,Xss: list @ ( list @ A )] :
( ! [X5: list @ A] :
( ( member2 @ ( list @ A ) @ X5 @ ( set2 @ ( list @ A ) @ Xss ) )
=> ( distinct @ A @ X5 ) )
=> ( distinct @ ( list @ A ) @ ( product_lists @ A @ Xss ) ) ) ).
% distinct_product_lists
thf(fact_3744_numeral__num__of__nat__unfold,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [N2: nat] :
( ( ( N2
= ( zero_zero @ nat ) )
=> ( ( numeral_numeral @ A @ ( num_of_nat @ N2 ) )
= ( one_one @ A ) ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( numeral_numeral @ A @ ( num_of_nat @ N2 ) )
= ( semiring_1_of_nat @ A @ N2 ) ) ) ) ) ).
% numeral_num_of_nat_unfold
thf(fact_3745_num__of__nat__double,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( num_of_nat @ ( plus_plus @ nat @ N2 @ N2 ) )
= ( bit0 @ ( num_of_nat @ N2 ) ) ) ) ).
% num_of_nat_double
thf(fact_3746_num__of__nat__plus__distrib,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( num_of_nat @ ( plus_plus @ nat @ M @ N2 ) )
= ( plus_plus @ num @ ( num_of_nat @ M ) @ ( num_of_nat @ N2 ) ) ) ) ) ).
% num_of_nat_plus_distrib
thf(fact_3747_times__int__def,axiom,
( ( times_times @ int )
= ( map_fun @ int @ ( product_prod @ nat @ nat ) @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ ( int > int ) @ rep_Integ @ ( map_fun @ int @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ int @ rep_Integ @ abs_Integ )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ X2 @ U2 ) @ ( times_times @ nat @ Y2 @ V5 ) ) @ ( plus_plus @ nat @ ( times_times @ nat @ X2 @ V5 ) @ ( times_times @ nat @ Y2 @ U2 ) ) ) ) ) ) ) ).
% times_int_def
thf(fact_3748_minus__int__def,axiom,
( ( minus_minus @ int )
= ( map_fun @ int @ ( product_prod @ nat @ nat ) @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ ( int > int ) @ rep_Integ @ ( map_fun @ int @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ int @ rep_Integ @ abs_Integ )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ Y2 @ U2 ) ) ) ) ) ) ).
% minus_int_def
thf(fact_3749_plus__int__def,axiom,
( ( plus_plus @ int )
= ( map_fun @ int @ ( product_prod @ nat @ nat ) @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ ( int > int ) @ rep_Integ @ ( map_fun @ int @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ int @ rep_Integ @ abs_Integ )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ X2 @ U2 ) @ ( plus_plus @ nat @ Y2 @ V5 ) ) ) ) ) ) ).
% plus_int_def
thf(fact_3750_sorted__list__of__set_Osorted__key__list__of__set__insert__remove,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( linord4507533701916653071of_set @ A @ ( insert2 @ A @ X @ A4 ) )
= ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ X
@ ( linord4507533701916653071of_set @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ).
% sorted_list_of_set.sorted_key_list_of_set_insert_remove
thf(fact_3751_remove1__insort__key,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [X: B,F2: B > A,Xs: list @ B] :
( ( remove1 @ B @ X @ ( linorder_insort_key @ B @ A @ F2 @ X @ Xs ) )
= Xs ) ) ).
% remove1_insort_key
thf(fact_3752_length__insort,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,X: B,Xs: list @ B] :
( ( size_size @ ( list @ B ) @ ( linorder_insort_key @ B @ A @ F2 @ X @ Xs ) )
= ( suc @ ( size_size @ ( list @ B ) @ Xs ) ) ) ) ).
% length_insort
thf(fact_3753_sorted__list__of__set_Osorted__key__list__of__set__insert,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ~ ( member2 @ A @ X @ A4 )
=> ( ( linord4507533701916653071of_set @ A @ ( insert2 @ A @ X @ A4 ) )
= ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ X
@ ( linord4507533701916653071of_set @ A @ A4 ) ) ) ) ) ) ).
% sorted_list_of_set.sorted_key_list_of_set_insert
thf(fact_3754_insort__left__comm,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A,Xs: list @ A] :
( ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ X
@ ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ Y
@ Xs ) )
= ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ Y
@ ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ X
@ Xs ) ) ) ) ).
% insort_left_comm
thf(fact_3755_insort__key__left__comm,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,X: B,Y: B,Xs: list @ B] :
( ( ( F2 @ X )
!= ( F2 @ Y ) )
=> ( ( linorder_insort_key @ B @ A @ F2 @ Y @ ( linorder_insort_key @ B @ A @ F2 @ X @ Xs ) )
= ( linorder_insort_key @ B @ A @ F2 @ X @ ( linorder_insort_key @ B @ A @ F2 @ Y @ Xs ) ) ) ) ) ).
% insort_key_left_comm
thf(fact_3756_set__insort__key,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,X: B,Xs: list @ B] :
( ( set2 @ B @ ( linorder_insort_key @ B @ A @ F2 @ X @ Xs ) )
= ( insert2 @ B @ X @ ( set2 @ B @ Xs ) ) ) ) ).
% set_insort_key
thf(fact_3757_distinct__insort,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,X: B,Xs: list @ B] :
( ( distinct @ B @ ( linorder_insort_key @ B @ A @ F2 @ X @ Xs ) )
= ( ~ ( member2 @ B @ X @ ( set2 @ B @ Xs ) )
& ( distinct @ B @ Xs ) ) ) ) ).
% distinct_insort
thf(fact_3758_sorted__list__of__set_Ofold__insort__key_Oremove,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( linord4507533701916653071of_set @ A @ A4 )
= ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ X
@ ( linord4507533701916653071of_set @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ).
% sorted_list_of_set.fold_insort_key.remove
thf(fact_3759_distinct__concat,axiom,
! [A: $tType,Xs: list @ ( list @ A )] :
( ( distinct @ ( list @ A ) @ Xs )
=> ( ! [Ys4: list @ A] :
( ( member2 @ ( list @ A ) @ Ys4 @ ( set2 @ ( list @ A ) @ Xs ) )
=> ( distinct @ A @ Ys4 ) )
=> ( ! [Ys4: list @ A,Zs2: list @ A] :
( ( member2 @ ( list @ A ) @ Ys4 @ ( set2 @ ( list @ A ) @ Xs ) )
=> ( ( member2 @ ( list @ A ) @ Zs2 @ ( set2 @ ( list @ A ) @ Xs ) )
=> ( ( Ys4 != Zs2 )
=> ( ( inf_inf @ ( set @ A ) @ ( set2 @ A @ Ys4 ) @ ( set2 @ A @ Zs2 ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) )
=> ( distinct @ A @ ( concat @ A @ Xs ) ) ) ) ) ).
% distinct_concat
thf(fact_3760_sorted__list__of__set__def,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( linord4507533701916653071of_set @ A )
= ( linord144544945434240204of_set @ A @ A
@ ^ [X2: A] : X2 ) ) ) ).
% sorted_list_of_set_def
thf(fact_3761_image__minus__const__atLeastLessThan__nat,axiom,
! [C2: nat,Y: nat,X: nat] :
( ( ( ord_less @ nat @ C2 @ Y )
=> ( ( image2 @ nat @ nat
@ ^ [I5: nat] : ( minus_minus @ nat @ I5 @ C2 )
@ ( set_or7035219750837199246ssThan @ nat @ X @ Y ) )
= ( set_or7035219750837199246ssThan @ nat @ ( minus_minus @ nat @ X @ C2 ) @ ( minus_minus @ nat @ Y @ C2 ) ) ) )
& ( ~ ( ord_less @ nat @ C2 @ Y )
=> ( ( ( ord_less @ nat @ X @ Y )
=> ( ( image2 @ nat @ nat
@ ^ [I5: nat] : ( minus_minus @ nat @ I5 @ C2 )
@ ( set_or7035219750837199246ssThan @ nat @ X @ Y ) )
= ( insert2 @ nat @ ( zero_zero @ nat ) @ ( bot_bot @ ( set @ nat ) ) ) ) )
& ( ~ ( ord_less @ nat @ X @ Y )
=> ( ( image2 @ nat @ nat
@ ^ [I5: nat] : ( minus_minus @ nat @ I5 @ C2 )
@ ( set_or7035219750837199246ssThan @ nat @ X @ Y ) )
= ( bot_bot @ ( set @ nat ) ) ) ) ) ) ) ).
% image_minus_const_atLeastLessThan_nat
thf(fact_3762_ring__1__class_Oof__int__def,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( ( ring_1_of_int @ A )
= ( map_fun @ int @ ( product_prod @ nat @ nat ) @ A @ A @ rep_Integ @ ( id @ A )
@ ( product_case_prod @ nat @ nat @ A
@ ^ [I5: nat,J3: nat] : ( minus_minus @ A @ ( semiring_1_of_nat @ A @ I5 ) @ ( semiring_1_of_nat @ A @ J3 ) ) ) ) ) ) ).
% ring_1_class.of_int_def
thf(fact_3763_inf_Oidem,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A] :
( ( inf_inf @ A @ A3 @ A3 )
= A3 ) ) ).
% inf.idem
thf(fact_3764_inf__idem,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A] :
( ( inf_inf @ A @ X @ X )
= X ) ) ).
% inf_idem
thf(fact_3765_inf_Oleft__idem,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A] :
( ( inf_inf @ A @ A3 @ ( inf_inf @ A @ A3 @ B2 ) )
= ( inf_inf @ A @ A3 @ B2 ) ) ) ).
% inf.left_idem
thf(fact_3766_inf__left__idem,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,Y: A] :
( ( inf_inf @ A @ X @ ( inf_inf @ A @ X @ Y ) )
= ( inf_inf @ A @ X @ Y ) ) ) ).
% inf_left_idem
thf(fact_3767_inf_Oright__idem,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A] :
( ( inf_inf @ A @ ( inf_inf @ A @ A3 @ B2 ) @ B2 )
= ( inf_inf @ A @ A3 @ B2 ) ) ) ).
% inf.right_idem
thf(fact_3768_inf__right__idem,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,Y: A] :
( ( inf_inf @ A @ ( inf_inf @ A @ X @ Y ) @ Y )
= ( inf_inf @ A @ X @ Y ) ) ) ).
% inf_right_idem
thf(fact_3769_inf__apply,axiom,
! [B: $tType,A: $tType] :
( ( semilattice_inf @ B )
=> ( ( inf_inf @ ( A > B ) )
= ( ^ [F3: A > B,G2: A > B,X2: A] : ( inf_inf @ B @ ( F3 @ X2 ) @ ( G2 @ X2 ) ) ) ) ) ).
% inf_apply
thf(fact_3770_of__nat__eq__id,axiom,
( ( semiring_1_of_nat @ nat )
= ( id @ nat ) ) ).
% of_nat_eq_id
thf(fact_3771_le__inf__iff,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less_eq @ A @ X @ ( inf_inf @ A @ Y @ Z ) )
= ( ( ord_less_eq @ A @ X @ Y )
& ( ord_less_eq @ A @ X @ Z ) ) ) ) ).
% le_inf_iff
thf(fact_3772_inf_Obounded__iff,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ ( inf_inf @ A @ B2 @ C2 ) )
= ( ( ord_less_eq @ A @ A3 @ B2 )
& ( ord_less_eq @ A @ A3 @ C2 ) ) ) ) ).
% inf.bounded_iff
thf(fact_3773_image__empty,axiom,
! [B: $tType,A: $tType,F2: B > A] :
( ( image2 @ B @ A @ F2 @ ( bot_bot @ ( set @ B ) ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% image_empty
thf(fact_3774_empty__is__image,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B] :
( ( ( bot_bot @ ( set @ A ) )
= ( image2 @ B @ A @ F2 @ A4 ) )
= ( A4
= ( bot_bot @ ( set @ B ) ) ) ) ).
% empty_is_image
thf(fact_3775_image__is__empty,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B] :
( ( ( image2 @ B @ A @ F2 @ A4 )
= ( bot_bot @ ( set @ A ) ) )
= ( A4
= ( bot_bot @ ( set @ B ) ) ) ) ).
% image_is_empty
thf(fact_3776_boolean__algebra_Oconj__zero__left,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A] :
( ( inf_inf @ A @ ( bot_bot @ A ) @ X )
= ( bot_bot @ A ) ) ) ).
% boolean_algebra.conj_zero_left
thf(fact_3777_boolean__algebra_Oconj__zero__right,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A] :
( ( inf_inf @ A @ X @ ( bot_bot @ A ) )
= ( bot_bot @ A ) ) ) ).
% boolean_algebra.conj_zero_right
thf(fact_3778_inf__bot__right,axiom,
! [A: $tType] :
( ( bounded_lattice_bot @ A )
=> ! [X: A] :
( ( inf_inf @ A @ X @ ( bot_bot @ A ) )
= ( bot_bot @ A ) ) ) ).
% inf_bot_right
thf(fact_3779_inf__bot__left,axiom,
! [A: $tType] :
( ( bounded_lattice_bot @ A )
=> ! [X: A] :
( ( inf_inf @ A @ ( bot_bot @ A ) @ X )
= ( bot_bot @ A ) ) ) ).
% inf_bot_left
thf(fact_3780_Int__subset__iff,axiom,
! [A: $tType,C5: set @ A,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ C5 @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) )
= ( ( ord_less_eq @ ( set @ A ) @ C5 @ A4 )
& ( ord_less_eq @ ( set @ A ) @ C5 @ B3 ) ) ) ).
% Int_subset_iff
thf(fact_3781_case__prod__Pair,axiom,
! [B: $tType,A: $tType] :
( ( product_case_prod @ A @ B @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B ) )
= ( id @ ( product_prod @ A @ B ) ) ) ).
% case_prod_Pair
thf(fact_3782_id__funpow,axiom,
! [A: $tType,N2: nat] :
( ( compow @ ( A > A ) @ N2 @ ( id @ A ) )
= ( id @ A ) ) ).
% id_funpow
thf(fact_3783_image__add__0,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [S3: set @ A] :
( ( image2 @ A @ A @ ( plus_plus @ A @ ( zero_zero @ A ) ) @ S3 )
= S3 ) ) ).
% image_add_0
thf(fact_3784_inf__compl__bot__left1,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A] :
( ( inf_inf @ A @ ( uminus_uminus @ A @ X ) @ ( inf_inf @ A @ X @ Y ) )
= ( bot_bot @ A ) ) ) ).
% inf_compl_bot_left1
thf(fact_3785_inf__compl__bot__left2,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A] :
( ( inf_inf @ A @ X @ ( inf_inf @ A @ ( uminus_uminus @ A @ X ) @ Y ) )
= ( bot_bot @ A ) ) ) ).
% inf_compl_bot_left2
thf(fact_3786_inf__compl__bot__right,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A] :
( ( inf_inf @ A @ X @ ( inf_inf @ A @ Y @ ( uminus_uminus @ A @ X ) ) )
= ( bot_bot @ A ) ) ) ).
% inf_compl_bot_right
thf(fact_3787_boolean__algebra_Oconj__cancel__left,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A] :
( ( inf_inf @ A @ ( uminus_uminus @ A @ X ) @ X )
= ( bot_bot @ A ) ) ) ).
% boolean_algebra.conj_cancel_left
thf(fact_3788_boolean__algebra_Oconj__cancel__right,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A] :
( ( inf_inf @ A @ X @ ( uminus_uminus @ A @ X ) )
= ( bot_bot @ A ) ) ) ).
% boolean_algebra.conj_cancel_right
thf(fact_3789_image__add__atLeastAtMost,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [K: A,I: A,J: A] :
( ( image2 @ A @ A @ ( plus_plus @ A @ K ) @ ( set_or1337092689740270186AtMost @ A @ I @ J ) )
= ( set_or1337092689740270186AtMost @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ K ) ) ) ) ).
% image_add_atLeastAtMost
thf(fact_3790_image__add__atLeastLessThan,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [K: A,I: A,J: A] :
( ( image2 @ A @ A @ ( plus_plus @ A @ K ) @ ( set_or7035219750837199246ssThan @ A @ I @ J ) )
= ( set_or7035219750837199246ssThan @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ K ) ) ) ) ).
% image_add_atLeastLessThan
thf(fact_3791_disjoint__insert_I2_J,axiom,
! [A: $tType,A4: set @ A,B2: A,B3: set @ A] :
( ( ( bot_bot @ ( set @ A ) )
= ( inf_inf @ ( set @ A ) @ A4 @ ( insert2 @ A @ B2 @ B3 ) ) )
= ( ~ ( member2 @ A @ B2 @ A4 )
& ( ( bot_bot @ ( set @ A ) )
= ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) ) ) ).
% disjoint_insert(2)
thf(fact_3792_disjoint__insert_I1_J,axiom,
! [A: $tType,B3: set @ A,A3: A,A4: set @ A] :
( ( ( inf_inf @ ( set @ A ) @ B3 @ ( insert2 @ A @ A3 @ A4 ) )
= ( bot_bot @ ( set @ A ) ) )
= ( ~ ( member2 @ A @ A3 @ B3 )
& ( ( inf_inf @ ( set @ A ) @ B3 @ A4 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% disjoint_insert(1)
thf(fact_3793_insert__disjoint_I2_J,axiom,
! [A: $tType,A3: A,A4: set @ A,B3: set @ A] :
( ( ( bot_bot @ ( set @ A ) )
= ( inf_inf @ ( set @ A ) @ ( insert2 @ A @ A3 @ A4 ) @ B3 ) )
= ( ~ ( member2 @ A @ A3 @ B3 )
& ( ( bot_bot @ ( set @ A ) )
= ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) ) ) ).
% insert_disjoint(2)
thf(fact_3794_insert__disjoint_I1_J,axiom,
! [A: $tType,A3: A,A4: set @ A,B3: set @ A] :
( ( ( inf_inf @ ( set @ A ) @ ( insert2 @ A @ A3 @ A4 ) @ B3 )
= ( bot_bot @ ( set @ A ) ) )
= ( ~ ( member2 @ A @ A3 @ B3 )
& ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% insert_disjoint(1)
thf(fact_3795_image__add__atMost,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [C2: A,A3: A] :
( ( image2 @ A @ A @ ( plus_plus @ A @ C2 ) @ ( set_ord_atMost @ A @ A3 ) )
= ( set_ord_atMost @ A @ ( plus_plus @ A @ C2 @ A3 ) ) ) ) ).
% image_add_atMost
thf(fact_3796_Diff__disjoint,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( inf_inf @ ( set @ A ) @ A4 @ ( minus_minus @ ( set @ A ) @ B3 @ A4 ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% Diff_disjoint
thf(fact_3797_Compl__disjoint,axiom,
! [A: $tType,A4: set @ A] :
( ( inf_inf @ ( set @ A ) @ A4 @ ( uminus_uminus @ ( set @ A ) @ A4 ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% Compl_disjoint
thf(fact_3798_Compl__disjoint2,axiom,
! [A: $tType,A4: set @ A] :
( ( inf_inf @ ( set @ A ) @ ( uminus_uminus @ ( set @ A ) @ A4 ) @ A4 )
= ( bot_bot @ ( set @ A ) ) ) ).
% Compl_disjoint2
thf(fact_3799_push__bit__0__id,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ( ( bit_se4730199178511100633sh_bit @ A @ ( zero_zero @ nat ) )
= ( id @ A ) ) ) ).
% push_bit_0_id
thf(fact_3800_drop__bit__0,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ( ( bit_se4197421643247451524op_bit @ A @ ( zero_zero @ nat ) )
= ( id @ A ) ) ) ).
% drop_bit_0
thf(fact_3801_image__Suc__atLeastAtMost,axiom,
! [I: nat,J: nat] :
( ( image2 @ nat @ nat @ suc @ ( set_or1337092689740270186AtMost @ nat @ I @ J ) )
= ( set_or1337092689740270186AtMost @ nat @ ( suc @ I ) @ ( suc @ J ) ) ) ).
% image_Suc_atLeastAtMost
thf(fact_3802_image__Suc__atLeastLessThan,axiom,
! [I: nat,J: nat] :
( ( image2 @ nat @ nat @ suc @ ( set_or7035219750837199246ssThan @ nat @ I @ J ) )
= ( set_or7035219750837199246ssThan @ nat @ ( suc @ I ) @ ( suc @ J ) ) ) ).
% image_Suc_atLeastLessThan
thf(fact_3803_image__add__atLeastAtMost_H,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [K: A,I: A,J: A] :
( ( image2 @ A @ A
@ ^ [N: A] : ( plus_plus @ A @ N @ K )
@ ( set_or1337092689740270186AtMost @ A @ I @ J ) )
= ( set_or1337092689740270186AtMost @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ K ) ) ) ) ).
% image_add_atLeastAtMost'
thf(fact_3804_image__add__atLeastLessThan_H,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [K: A,I: A,J: A] :
( ( image2 @ A @ A
@ ^ [N: A] : ( plus_plus @ A @ N @ K )
@ ( set_or7035219750837199246ssThan @ A @ I @ J ) )
= ( set_or7035219750837199246ssThan @ A @ ( plus_plus @ A @ I @ K ) @ ( plus_plus @ A @ J @ K ) ) ) ) ).
% image_add_atLeastLessThan'
thf(fact_3805_image__mult__atLeastAtMost,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [D2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ D2 )
=> ( ( image2 @ A @ A @ ( times_times @ A @ D2 ) @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( times_times @ A @ D2 @ A3 ) @ ( times_times @ A @ D2 @ B2 ) ) ) ) ) ).
% image_mult_atLeastAtMost
thf(fact_3806_image__divide__atLeastAtMost,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [D2: A,A3: A,B2: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ D2 )
=> ( ( image2 @ A @ A
@ ^ [C3: A] : ( divide_divide @ A @ C3 @ D2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( divide_divide @ A @ A3 @ D2 ) @ ( divide_divide @ A @ B2 @ D2 ) ) ) ) ) ).
% image_divide_atLeastAtMost
thf(fact_3807_Int__emptyI,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ~ ( member2 @ A @ X5 @ B3 ) )
=> ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% Int_emptyI
thf(fact_3808_disjoint__iff,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
= ( bot_bot @ ( set @ A ) ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ~ ( member2 @ A @ X2 @ B3 ) ) ) ) ).
% disjoint_iff
thf(fact_3809_Int__empty__left,axiom,
! [A: $tType,B3: set @ A] :
( ( inf_inf @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) @ B3 )
= ( bot_bot @ ( set @ A ) ) ) ).
% Int_empty_left
thf(fact_3810_Int__empty__right,axiom,
! [A: $tType,A4: set @ A] :
( ( inf_inf @ ( set @ A ) @ A4 @ ( bot_bot @ ( set @ A ) ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% Int_empty_right
thf(fact_3811_disjoint__iff__not__equal,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
= ( bot_bot @ ( set @ A ) ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ! [Y2: A] :
( ( member2 @ A @ Y2 @ B3 )
=> ( X2 != Y2 ) ) ) ) ) ).
% disjoint_iff_not_equal
thf(fact_3812_image__Int__subset,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B,B3: set @ B] : ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ F2 @ ( inf_inf @ ( set @ B ) @ A4 @ B3 ) ) @ ( inf_inf @ ( set @ A ) @ ( image2 @ B @ A @ F2 @ A4 ) @ ( image2 @ B @ A @ F2 @ B3 ) ) ) ).
% image_Int_subset
thf(fact_3813_inf__sup__aci_I4_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A] :
( ( inf_inf @ A @ X @ ( inf_inf @ A @ X @ Y ) )
= ( inf_inf @ A @ X @ Y ) ) ) ).
% inf_sup_aci(4)
thf(fact_3814_inf__sup__aci_I3_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A,Z: A] :
( ( inf_inf @ A @ X @ ( inf_inf @ A @ Y @ Z ) )
= ( inf_inf @ A @ Y @ ( inf_inf @ A @ X @ Z ) ) ) ) ).
% inf_sup_aci(3)
thf(fact_3815_inf__sup__aci_I2_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A,Z: A] :
( ( inf_inf @ A @ ( inf_inf @ A @ X @ Y ) @ Z )
= ( inf_inf @ A @ X @ ( inf_inf @ A @ Y @ Z ) ) ) ) ).
% inf_sup_aci(2)
thf(fact_3816_inf__sup__aci_I1_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ( ( inf_inf @ A )
= ( ^ [X2: A,Y2: A] : ( inf_inf @ A @ Y2 @ X2 ) ) ) ) ).
% inf_sup_aci(1)
thf(fact_3817_inf_Oassoc,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( inf_inf @ A @ ( inf_inf @ A @ A3 @ B2 ) @ C2 )
= ( inf_inf @ A @ A3 @ ( inf_inf @ A @ B2 @ C2 ) ) ) ) ).
% inf.assoc
thf(fact_3818_inf__assoc,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,Y: A,Z: A] :
( ( inf_inf @ A @ ( inf_inf @ A @ X @ Y ) @ Z )
= ( inf_inf @ A @ X @ ( inf_inf @ A @ Y @ Z ) ) ) ) ).
% inf_assoc
thf(fact_3819_inf_Ocommute,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ( ( inf_inf @ A )
= ( ^ [A5: A,B4: A] : ( inf_inf @ A @ B4 @ A5 ) ) ) ) ).
% inf.commute
thf(fact_3820_inf__commute,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ( ( inf_inf @ A )
= ( ^ [X2: A,Y2: A] : ( inf_inf @ A @ Y2 @ X2 ) ) ) ) ).
% inf_commute
thf(fact_3821_inf_Oleft__commute,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( inf_inf @ A @ B2 @ ( inf_inf @ A @ A3 @ C2 ) )
= ( inf_inf @ A @ A3 @ ( inf_inf @ A @ B2 @ C2 ) ) ) ) ).
% inf.left_commute
thf(fact_3822_inf__left__commute,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,Y: A,Z: A] :
( ( inf_inf @ A @ X @ ( inf_inf @ A @ Y @ Z ) )
= ( inf_inf @ A @ Y @ ( inf_inf @ A @ X @ Z ) ) ) ) ).
% inf_left_commute
thf(fact_3823_inf__fun__def,axiom,
! [B: $tType,A: $tType] :
( ( semilattice_inf @ B )
=> ( ( inf_inf @ ( A > B ) )
= ( ^ [F3: A > B,G2: A > B,X2: A] : ( inf_inf @ B @ ( F3 @ X2 ) @ ( G2 @ X2 ) ) ) ) ) ).
% inf_fun_def
thf(fact_3824_less__infI1,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,X: A,B2: A] :
( ( ord_less @ A @ A3 @ X )
=> ( ord_less @ A @ ( inf_inf @ A @ A3 @ B2 ) @ X ) ) ) ).
% less_infI1
thf(fact_3825_less__infI2,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [B2: A,X: A,A3: A] :
( ( ord_less @ A @ B2 @ X )
=> ( ord_less @ A @ ( inf_inf @ A @ A3 @ B2 ) @ X ) ) ) ).
% less_infI2
thf(fact_3826_inf_Oabsorb3,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( inf_inf @ A @ A3 @ B2 )
= A3 ) ) ) ).
% inf.absorb3
thf(fact_3827_inf_Oabsorb4,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ( inf_inf @ A @ A3 @ B2 )
= B2 ) ) ) ).
% inf.absorb4
thf(fact_3828_inf_Ostrict__boundedE,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ ( inf_inf @ A @ B2 @ C2 ) )
=> ~ ( ( ord_less @ A @ A3 @ B2 )
=> ~ ( ord_less @ A @ A3 @ C2 ) ) ) ) ).
% inf.strict_boundedE
thf(fact_3829_inf_Ostrict__order__iff,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ( ( ord_less @ A )
= ( ^ [A5: A,B4: A] :
( ( A5
= ( inf_inf @ A @ A5 @ B4 ) )
& ( A5 != B4 ) ) ) ) ) ).
% inf.strict_order_iff
thf(fact_3830_inf_Ostrict__coboundedI1,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less @ A @ A3 @ C2 )
=> ( ord_less @ A @ ( inf_inf @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% inf.strict_coboundedI1
thf(fact_3831_inf_Ostrict__coboundedI2,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less @ A @ B2 @ C2 )
=> ( ord_less @ A @ ( inf_inf @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% inf.strict_coboundedI2
thf(fact_3832_inf__sup__ord_I2_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ A @ ( inf_inf @ A @ X @ Y ) @ Y ) ) ).
% inf_sup_ord(2)
thf(fact_3833_inf__sup__ord_I1_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ A @ ( inf_inf @ A @ X @ Y ) @ X ) ) ).
% inf_sup_ord(1)
thf(fact_3834_inf__le1,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ A @ ( inf_inf @ A @ X @ Y ) @ X ) ) ).
% inf_le1
thf(fact_3835_inf__le2,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ A @ ( inf_inf @ A @ X @ Y ) @ Y ) ) ).
% inf_le2
thf(fact_3836_le__infE,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ X @ ( inf_inf @ A @ A3 @ B2 ) )
=> ~ ( ( ord_less_eq @ A @ X @ A3 )
=> ~ ( ord_less_eq @ A @ X @ B2 ) ) ) ) ).
% le_infE
thf(fact_3837_le__infI,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ X @ A3 )
=> ( ( ord_less_eq @ A @ X @ B2 )
=> ( ord_less_eq @ A @ X @ ( inf_inf @ A @ A3 @ B2 ) ) ) ) ) ).
% le_infI
thf(fact_3838_inf__mono,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,C2: A,B2: A,D2: A] :
( ( ord_less_eq @ A @ A3 @ C2 )
=> ( ( ord_less_eq @ A @ B2 @ D2 )
=> ( ord_less_eq @ A @ ( inf_inf @ A @ A3 @ B2 ) @ ( inf_inf @ A @ C2 @ D2 ) ) ) ) ) ).
% inf_mono
thf(fact_3839_le__infI1,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,X: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ X )
=> ( ord_less_eq @ A @ ( inf_inf @ A @ A3 @ B2 ) @ X ) ) ) ).
% le_infI1
thf(fact_3840_le__infI2,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [B2: A,X: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ X )
=> ( ord_less_eq @ A @ ( inf_inf @ A @ A3 @ B2 ) @ X ) ) ) ).
% le_infI2
thf(fact_3841_inf_OorderE,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( A3
= ( inf_inf @ A @ A3 @ B2 ) ) ) ) ).
% inf.orderE
thf(fact_3842_inf_OorderI,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A] :
( ( A3
= ( inf_inf @ A @ A3 @ B2 ) )
=> ( ord_less_eq @ A @ A3 @ B2 ) ) ) ).
% inf.orderI
thf(fact_3843_inf__unique,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [F2: A > A > A,X: A,Y: A] :
( ! [X5: A,Y4: A] : ( ord_less_eq @ A @ ( F2 @ X5 @ Y4 ) @ X5 )
=> ( ! [X5: A,Y4: A] : ( ord_less_eq @ A @ ( F2 @ X5 @ Y4 ) @ Y4 )
=> ( ! [X5: A,Y4: A,Z2: A] :
( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ( ord_less_eq @ A @ X5 @ Z2 )
=> ( ord_less_eq @ A @ X5 @ ( F2 @ Y4 @ Z2 ) ) ) )
=> ( ( inf_inf @ A @ X @ Y )
= ( F2 @ X @ Y ) ) ) ) ) ) ).
% inf_unique
thf(fact_3844_le__iff__inf,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [X2: A,Y2: A] :
( ( inf_inf @ A @ X2 @ Y2 )
= X2 ) ) ) ) ).
% le_iff_inf
thf(fact_3845_inf_Oabsorb1,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( inf_inf @ A @ A3 @ B2 )
= A3 ) ) ) ).
% inf.absorb1
thf(fact_3846_inf_Oabsorb2,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( inf_inf @ A @ A3 @ B2 )
= B2 ) ) ) ).
% inf.absorb2
thf(fact_3847_inf__absorb1,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( inf_inf @ A @ X @ Y )
= X ) ) ) ).
% inf_absorb1
thf(fact_3848_inf__absorb2,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ Y @ X )
=> ( ( inf_inf @ A @ X @ Y )
= Y ) ) ) ).
% inf_absorb2
thf(fact_3849_inf_OboundedE,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ ( inf_inf @ A @ B2 @ C2 ) )
=> ~ ( ( ord_less_eq @ A @ A3 @ B2 )
=> ~ ( ord_less_eq @ A @ A3 @ C2 ) ) ) ) ).
% inf.boundedE
thf(fact_3850_inf_OboundedI,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ A3 @ C2 )
=> ( ord_less_eq @ A @ A3 @ ( inf_inf @ A @ B2 @ C2 ) ) ) ) ) ).
% inf.boundedI
thf(fact_3851_inf__greatest,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_less_eq @ A @ X @ Z )
=> ( ord_less_eq @ A @ X @ ( inf_inf @ A @ Y @ Z ) ) ) ) ) ).
% inf_greatest
thf(fact_3852_inf_Oorder__iff,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [A5: A,B4: A] :
( A5
= ( inf_inf @ A @ A5 @ B4 ) ) ) ) ) ).
% inf.order_iff
thf(fact_3853_inf_Ocobounded1,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ A @ ( inf_inf @ A @ A3 @ B2 ) @ A3 ) ) ).
% inf.cobounded1
thf(fact_3854_inf_Ocobounded2,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ A @ ( inf_inf @ A @ A3 @ B2 ) @ B2 ) ) ).
% inf.cobounded2
thf(fact_3855_inf_Oabsorb__iff1,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [A5: A,B4: A] :
( ( inf_inf @ A @ A5 @ B4 )
= A5 ) ) ) ) ).
% inf.absorb_iff1
thf(fact_3856_inf_Oabsorb__iff2,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [B4: A,A5: A] :
( ( inf_inf @ A @ A5 @ B4 )
= B4 ) ) ) ) ).
% inf.absorb_iff2
thf(fact_3857_inf_OcoboundedI1,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ C2 )
=> ( ord_less_eq @ A @ ( inf_inf @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% inf.coboundedI1
thf(fact_3858_inf_OcoboundedI2,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ C2 )
=> ( ord_less_eq @ A @ ( inf_inf @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% inf.coboundedI2
thf(fact_3859_image__mono,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ A,F2: A > B] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ ( image2 @ A @ B @ F2 @ B3 ) ) ) ).
% image_mono
thf(fact_3860_image__subsetI,axiom,
! [A: $tType,B: $tType,A4: set @ A,F2: A > B,B3: set @ B] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( member2 @ B @ ( F2 @ X5 ) @ B3 ) )
=> ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ B3 ) ) ).
% image_subsetI
thf(fact_3861_subset__imageE,axiom,
! [A: $tType,B: $tType,B3: set @ A,F2: B > A,A4: set @ B] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ~ ! [C6: set @ B] :
( ( ord_less_eq @ ( set @ B ) @ C6 @ A4 )
=> ( B3
!= ( image2 @ B @ A @ F2 @ C6 ) ) ) ) ).
% subset_imageE
thf(fact_3862_image__subset__iff,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ F2 @ A4 ) @ B3 )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( member2 @ A @ ( F2 @ X2 ) @ B3 ) ) ) ) ).
% image_subset_iff
thf(fact_3863_subset__image__iff,axiom,
! [A: $tType,B: $tType,B3: set @ A,F2: B > A,A4: set @ B] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ ( image2 @ B @ A @ F2 @ A4 ) )
= ( ? [AA: set @ B] :
( ( ord_less_eq @ ( set @ B ) @ AA @ A4 )
& ( B3
= ( image2 @ B @ A @ F2 @ AA ) ) ) ) ) ).
% subset_image_iff
thf(fact_3864_all__subset__image,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B,P2: ( set @ A ) > $o] :
( ( ! [B6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B6 @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( P2 @ B6 ) ) )
= ( ! [B6: set @ B] :
( ( ord_less_eq @ ( set @ B ) @ B6 @ A4 )
=> ( P2 @ ( image2 @ B @ A @ F2 @ B6 ) ) ) ) ) ).
% all_subset_image
thf(fact_3865_Int__mono,axiom,
! [A: $tType,A4: set @ A,C5: set @ A,B3: set @ A,D6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ D6 )
=> ( ord_less_eq @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) @ ( inf_inf @ ( set @ A ) @ C5 @ D6 ) ) ) ) ).
% Int_mono
thf(fact_3866_Int__lower1,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] : ( ord_less_eq @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) @ A4 ) ).
% Int_lower1
thf(fact_3867_Int__lower2,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] : ( ord_less_eq @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) @ B3 ) ).
% Int_lower2
thf(fact_3868_Int__absorb1,axiom,
! [A: $tType,B3: set @ A,A4: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
= B3 ) ) ).
% Int_absorb1
thf(fact_3869_Int__absorb2,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
= A4 ) ) ).
% Int_absorb2
thf(fact_3870_Int__greatest,axiom,
! [A: $tType,C5: set @ A,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ C5 @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ C5 @ B3 )
=> ( ord_less_eq @ ( set @ A ) @ C5 @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) ) ) ).
% Int_greatest
thf(fact_3871_Int__Collect__mono,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,P2: A > $o,Q: A > $o] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ( P2 @ X5 )
=> ( Q @ X5 ) ) )
=> ( ord_less_eq @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ A4 @ ( collect @ A @ P2 ) ) @ ( inf_inf @ ( set @ A ) @ B3 @ ( collect @ A @ Q ) ) ) ) ) ).
% Int_Collect_mono
thf(fact_3872_translation__Int,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [A3: A,S: set @ A,T2: set @ A] :
( ( image2 @ A @ A @ ( plus_plus @ A @ A3 ) @ ( inf_inf @ ( set @ A ) @ S @ T2 ) )
= ( inf_inf @ ( set @ A ) @ ( image2 @ A @ A @ ( plus_plus @ A @ A3 ) @ S ) @ ( image2 @ A @ A @ ( plus_plus @ A @ A3 ) @ T2 ) ) ) ) ).
% translation_Int
thf(fact_3873_image__Collect__subsetI,axiom,
! [A: $tType,B: $tType,P2: A > $o,F2: A > B,B3: set @ B] :
( ! [X5: A] :
( ( P2 @ X5 )
=> ( member2 @ B @ ( F2 @ X5 ) @ B3 ) )
=> ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ ( collect @ A @ P2 ) ) @ B3 ) ) ).
% image_Collect_subsetI
thf(fact_3874_inf__cancel__left1,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,A3: A,B2: A] :
( ( inf_inf @ A @ ( inf_inf @ A @ X @ A3 ) @ ( inf_inf @ A @ ( uminus_uminus @ A @ X ) @ B2 ) )
= ( bot_bot @ A ) ) ) ).
% inf_cancel_left1
thf(fact_3875_inf__cancel__left2,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,A3: A,B2: A] :
( ( inf_inf @ A @ ( inf_inf @ A @ ( uminus_uminus @ A @ X ) @ A3 ) @ ( inf_inf @ A @ X @ B2 ) )
= ( bot_bot @ A ) ) ) ).
% inf_cancel_left2
thf(fact_3876_zero__notin__Suc__image,axiom,
! [A4: set @ nat] :
~ ( member2 @ nat @ ( zero_zero @ nat ) @ ( image2 @ nat @ nat @ suc @ A4 ) ) ).
% zero_notin_Suc_image
thf(fact_3877_finite__surj,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B,F2: A > B] :
( ( finite_finite @ A @ A4 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ ( image2 @ A @ B @ F2 @ A4 ) )
=> ( finite_finite @ B @ B3 ) ) ) ).
% finite_surj
thf(fact_3878_finite__subset__image,axiom,
! [A: $tType,B: $tType,B3: set @ A,F2: B > A,A4: set @ B] :
( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ? [C6: set @ B] :
( ( ord_less_eq @ ( set @ B ) @ C6 @ A4 )
& ( finite_finite @ B @ C6 )
& ( B3
= ( image2 @ B @ A @ F2 @ C6 ) ) ) ) ) ).
% finite_subset_image
thf(fact_3879_ex__finite__subset__image,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B,P2: ( set @ A ) > $o] :
( ( ? [B6: set @ A] :
( ( finite_finite @ A @ B6 )
& ( ord_less_eq @ ( set @ A ) @ B6 @ ( image2 @ B @ A @ F2 @ A4 ) )
& ( P2 @ B6 ) ) )
= ( ? [B6: set @ B] :
( ( finite_finite @ B @ B6 )
& ( ord_less_eq @ ( set @ B ) @ B6 @ A4 )
& ( P2 @ ( image2 @ B @ A @ F2 @ B6 ) ) ) ) ) ).
% ex_finite_subset_image
thf(fact_3880_all__finite__subset__image,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B,P2: ( set @ A ) > $o] :
( ( ! [B6: set @ A] :
( ( ( finite_finite @ A @ B6 )
& ( ord_less_eq @ ( set @ A ) @ B6 @ ( image2 @ B @ A @ F2 @ A4 ) ) )
=> ( P2 @ B6 ) ) )
= ( ! [B6: set @ B] :
( ( ( finite_finite @ B @ B6 )
& ( ord_less_eq @ ( set @ B ) @ B6 @ A4 ) )
=> ( P2 @ ( image2 @ B @ A @ F2 @ B6 ) ) ) ) ) ).
% all_finite_subset_image
thf(fact_3881_translation__diff,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [A3: A,S: set @ A,T2: set @ A] :
( ( image2 @ A @ A @ ( plus_plus @ A @ A3 ) @ ( minus_minus @ ( set @ A ) @ S @ T2 ) )
= ( minus_minus @ ( set @ A ) @ ( image2 @ A @ A @ ( plus_plus @ A @ A3 ) @ S ) @ ( image2 @ A @ A @ ( plus_plus @ A @ A3 ) @ T2 ) ) ) ) ).
% translation_diff
thf(fact_3882_funpow__simps__right_I1_J,axiom,
! [A: $tType,F2: A > A] :
( ( compow @ ( A > A ) @ ( zero_zero @ nat ) @ F2 )
= ( id @ A ) ) ).
% funpow_simps_right(1)
thf(fact_3883_image__diff__subset,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B,B3: set @ B] : ( ord_less_eq @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ ( image2 @ B @ A @ F2 @ A4 ) @ ( image2 @ B @ A @ F2 @ B3 ) ) @ ( image2 @ B @ A @ F2 @ ( minus_minus @ ( set @ B ) @ A4 @ B3 ) ) ) ).
% image_diff_subset
thf(fact_3884_translation__Compl,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [A3: A,T2: set @ A] :
( ( image2 @ A @ A @ ( plus_plus @ A @ A3 ) @ ( uminus_uminus @ ( set @ A ) @ T2 ) )
= ( uminus_uminus @ ( set @ A ) @ ( image2 @ A @ A @ ( plus_plus @ A @ A3 ) @ T2 ) ) ) ) ).
% translation_Compl
thf(fact_3885_Diff__triv,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( minus_minus @ ( set @ A ) @ A4 @ B3 )
= A4 ) ) ).
% Diff_triv
thf(fact_3886_Int__Diff__disjoint,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( inf_inf @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% Int_Diff_disjoint
thf(fact_3887_ivl__disj__int__two_I3_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,M: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ L @ M ) @ ( set_or7035219750837199246ssThan @ A @ M @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_two(3)
thf(fact_3888_less__int__def,axiom,
( ( ord_less @ int )
= ( map_fun @ int @ ( product_prod @ nat @ nat ) @ ( ( product_prod @ nat @ nat ) > $o ) @ ( int > $o ) @ rep_Integ @ ( map_fun @ int @ ( product_prod @ nat @ nat ) @ $o @ $o @ rep_Integ @ ( id @ $o ) )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Y2 ) ) ) ) ) ) ).
% less_int_def
thf(fact_3889_less__eq__int__def,axiom,
( ( ord_less_eq @ int )
= ( map_fun @ int @ ( product_prod @ nat @ nat ) @ ( ( product_prod @ nat @ nat ) > $o ) @ ( int > $o ) @ rep_Integ @ ( map_fun @ int @ ( product_prod @ nat @ nat ) @ $o @ $o @ rep_Integ @ ( id @ $o ) )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less_eq @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Y2 ) ) ) ) ) ) ).
% less_eq_int_def
thf(fact_3890_nat__seg__image__imp__finite,axiom,
! [A: $tType,A4: set @ A,F2: nat > A,N2: nat] :
( ( A4
= ( image2 @ nat @ A @ F2
@ ( collect @ nat
@ ^ [I5: nat] : ( ord_less @ nat @ I5 @ N2 ) ) ) )
=> ( finite_finite @ A @ A4 ) ) ).
% nat_seg_image_imp_finite
thf(fact_3891_finite__conv__nat__seg__image,axiom,
! [A: $tType] :
( ( finite_finite @ A )
= ( ^ [A6: set @ A] :
? [N: nat,F3: nat > A] :
( A6
= ( image2 @ nat @ A @ F3
@ ( collect @ nat
@ ^ [I5: nat] : ( ord_less @ nat @ I5 @ N ) ) ) ) ) ) ).
% finite_conv_nat_seg_image
thf(fact_3892_image__constant__conv,axiom,
! [B: $tType,A: $tType,A4: set @ B,C2: A] :
( ( ( A4
= ( bot_bot @ ( set @ B ) ) )
=> ( ( image2 @ B @ A
@ ^ [X2: B] : C2
@ A4 )
= ( bot_bot @ ( set @ A ) ) ) )
& ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( image2 @ B @ A
@ ^ [X2: B] : C2
@ A4 )
= ( insert2 @ A @ C2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% image_constant_conv
thf(fact_3893_image__constant,axiom,
! [A: $tType,B: $tType,X: A,A4: set @ A,C2: B] :
( ( member2 @ A @ X @ A4 )
=> ( ( image2 @ A @ B
@ ^ [X2: A] : C2
@ A4 )
= ( insert2 @ B @ C2 @ ( bot_bot @ ( set @ B ) ) ) ) ) ).
% image_constant
thf(fact_3894_the__elem__image__unique,axiom,
! [B: $tType,A: $tType,A4: set @ A,F2: A > B,X: A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [Y4: A] :
( ( member2 @ A @ Y4 @ A4 )
=> ( ( F2 @ Y4 )
= ( F2 @ X ) ) )
=> ( ( the_elem @ B @ ( image2 @ A @ B @ F2 @ A4 ) )
= ( F2 @ X ) ) ) ) ).
% the_elem_image_unique
thf(fact_3895_nat__def,axiom,
( nat2
= ( map_fun @ int @ ( product_prod @ nat @ nat ) @ nat @ nat @ rep_Integ @ ( id @ nat ) @ ( product_case_prod @ nat @ nat @ nat @ ( minus_minus @ nat ) ) ) ) ).
% nat_def
thf(fact_3896_inf__shunt,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A] :
( ( ( inf_inf @ A @ X @ Y )
= ( bot_bot @ A ) )
= ( ord_less_eq @ A @ X @ ( uminus_uminus @ A @ Y ) ) ) ) ).
% inf_shunt
thf(fact_3897_card__image__le,axiom,
! [B: $tType,A: $tType,A4: set @ A,F2: A > B] :
( ( finite_finite @ A @ A4 )
=> ( ord_less_eq @ nat @ ( finite_card @ B @ ( image2 @ A @ B @ F2 @ A4 ) ) @ ( finite_card @ A @ A4 ) ) ) ).
% card_image_le
thf(fact_3898_ivl__disj__int__two_I7_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,M: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ L @ M ) @ ( set_or1337092689740270186AtMost @ A @ M @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_two(7)
thf(fact_3899_ivl__disj__int__one_I4_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_ord_lessThan @ A @ L ) @ ( set_or1337092689740270186AtMost @ A @ L @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_one(4)
thf(fact_3900_ivl__disj__int__one_I2_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_ord_lessThan @ A @ L ) @ ( set_or7035219750837199246ssThan @ A @ L @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_one(2)
thf(fact_3901_disjoint__eq__subset__Compl,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
= ( bot_bot @ ( set @ A ) ) )
= ( ord_less_eq @ ( set @ A ) @ A4 @ ( uminus_uminus @ ( set @ A ) @ B3 ) ) ) ).
% disjoint_eq_subset_Compl
thf(fact_3902_sum_Ogroup,axiom,
! [C: $tType,A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [S3: set @ B,T4: set @ C,G: B > C,H2: B > A] :
( ( finite_finite @ B @ S3 )
=> ( ( finite_finite @ C @ T4 )
=> ( ( ord_less_eq @ ( set @ C ) @ ( image2 @ B @ C @ G @ S3 ) @ T4 )
=> ( ( groups7311177749621191930dd_sum @ C @ A
@ ^ [Y2: C] :
( groups7311177749621191930dd_sum @ B @ A @ H2
@ ( collect @ B
@ ^ [X2: B] :
( ( member2 @ B @ X2 @ S3 )
& ( ( G @ X2 )
= Y2 ) ) ) )
@ T4 )
= ( groups7311177749621191930dd_sum @ B @ A @ H2 @ S3 ) ) ) ) ) ) ).
% sum.group
thf(fact_3903_prod_Ogroup,axiom,
! [C: $tType,A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [S3: set @ B,T4: set @ C,G: B > C,H2: B > A] :
( ( finite_finite @ B @ S3 )
=> ( ( finite_finite @ C @ T4 )
=> ( ( ord_less_eq @ ( set @ C ) @ ( image2 @ B @ C @ G @ S3 ) @ T4 )
=> ( ( groups7121269368397514597t_prod @ C @ A
@ ^ [Y2: C] :
( groups7121269368397514597t_prod @ B @ A @ H2
@ ( collect @ B
@ ^ [X2: B] :
( ( member2 @ B @ X2 @ S3 )
& ( ( G @ X2 )
= Y2 ) ) ) )
@ T4 )
= ( groups7121269368397514597t_prod @ B @ A @ H2 @ S3 ) ) ) ) ) ) ).
% prod.group
thf(fact_3904_sum_Ointer__restrict,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,G: B > A,B3: set @ B] :
( ( finite_finite @ B @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( inf_inf @ ( set @ B ) @ A4 @ B3 ) )
= ( groups7311177749621191930dd_sum @ B @ A
@ ^ [X2: B] : ( if @ A @ ( member2 @ B @ X2 @ B3 ) @ ( G @ X2 ) @ ( zero_zero @ A ) )
@ A4 ) ) ) ) ).
% sum.inter_restrict
thf(fact_3905_surj__card__le,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B,F2: A > B] :
( ( finite_finite @ A @ A4 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ ( image2 @ A @ B @ F2 @ A4 ) )
=> ( ord_less_eq @ nat @ ( finite_card @ B @ B3 ) @ ( finite_card @ A @ A4 ) ) ) ) ).
% surj_card_le
thf(fact_3906_sum_Omono__neutral__cong,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [T4: set @ B,S3: set @ B,H2: B > A,G: B > A] :
( ( finite_finite @ B @ T4 )
=> ( ( finite_finite @ B @ S3 )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ ( minus_minus @ ( set @ B ) @ T4 @ S3 ) )
=> ( ( H2 @ I3 )
= ( zero_zero @ A ) ) )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ ( minus_minus @ ( set @ B ) @ S3 @ T4 ) )
=> ( ( G @ I3 )
= ( zero_zero @ A ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( inf_inf @ ( set @ B ) @ S3 @ T4 ) )
=> ( ( G @ X5 )
= ( H2 @ X5 ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ S3 )
= ( groups7311177749621191930dd_sum @ B @ A @ H2 @ T4 ) ) ) ) ) ) ) ) ).
% sum.mono_neutral_cong
thf(fact_3907_Iio__Int__singleton,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X: A,K: A] :
( ( ( ord_less @ A @ X @ K )
=> ( ( inf_inf @ ( set @ A ) @ ( set_ord_lessThan @ A @ K ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
& ( ~ ( ord_less @ A @ X @ K )
=> ( ( inf_inf @ ( set @ A ) @ ( set_ord_lessThan @ A @ K ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% Iio_Int_singleton
thf(fact_3908_sum_OInt__Diff,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,G: B > A,B3: set @ B] :
( ( finite_finite @ B @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ G @ ( inf_inf @ ( set @ B ) @ A4 @ B3 ) ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ ( minus_minus @ ( set @ B ) @ A4 @ B3 ) ) ) ) ) ) ).
% sum.Int_Diff
thf(fact_3909_image__Suc__lessThan,axiom,
! [N2: nat] :
( ( image2 @ nat @ nat @ suc @ ( set_ord_lessThan @ nat @ N2 ) )
= ( set_or1337092689740270186AtMost @ nat @ ( one_one @ nat ) @ N2 ) ) ).
% image_Suc_lessThan
thf(fact_3910_image__Suc__atMost,axiom,
! [N2: nat] :
( ( image2 @ nat @ nat @ suc @ ( set_ord_atMost @ nat @ N2 ) )
= ( set_or1337092689740270186AtMost @ nat @ ( one_one @ nat ) @ ( suc @ N2 ) ) ) ).
% image_Suc_atMost
thf(fact_3911_atLeast0__atMost__Suc__eq__insert__0,axiom,
! [N2: nat] :
( ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) )
= ( insert2 @ nat @ ( zero_zero @ nat ) @ ( image2 @ nat @ nat @ suc @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% atLeast0_atMost_Suc_eq_insert_0
thf(fact_3912_atLeast0__lessThan__Suc__eq__insert__0,axiom,
! [N2: nat] :
( ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) )
= ( insert2 @ nat @ ( zero_zero @ nat ) @ ( image2 @ nat @ nat @ suc @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% atLeast0_lessThan_Suc_eq_insert_0
thf(fact_3913_lessThan__Suc__eq__insert__0,axiom,
! [N2: nat] :
( ( set_ord_lessThan @ nat @ ( suc @ N2 ) )
= ( insert2 @ nat @ ( zero_zero @ nat ) @ ( image2 @ nat @ nat @ suc @ ( set_ord_lessThan @ nat @ N2 ) ) ) ) ).
% lessThan_Suc_eq_insert_0
thf(fact_3914_atMost__Suc__eq__insert__0,axiom,
! [N2: nat] :
( ( set_ord_atMost @ nat @ ( suc @ N2 ) )
= ( insert2 @ nat @ ( zero_zero @ nat ) @ ( image2 @ nat @ nat @ suc @ ( set_ord_atMost @ nat @ N2 ) ) ) ) ).
% atMost_Suc_eq_insert_0
thf(fact_3915_sum_OIf__cases,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,P2: B > $o,H2: B > A,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( groups7311177749621191930dd_sum @ B @ A
@ ^ [X2: B] : ( if @ A @ ( P2 @ X2 ) @ ( H2 @ X2 ) @ ( G @ X2 ) )
@ A4 )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ H2 @ ( inf_inf @ ( set @ B ) @ A4 @ ( collect @ B @ P2 ) ) ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ ( inf_inf @ ( set @ B ) @ A4 @ ( uminus_uminus @ ( set @ B ) @ ( collect @ B @ P2 ) ) ) ) ) ) ) ) ).
% sum.If_cases
thf(fact_3916_sum__div__partition,axiom,
! [B: $tType,A: $tType] :
( ( euclid4440199948858584721cancel @ A )
=> ! [A4: set @ B,F2: B > A,B2: A] :
( ( finite_finite @ B @ A4 )
=> ( ( divide_divide @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) @ B2 )
= ( plus_plus @ A
@ ( groups7311177749621191930dd_sum @ B @ A
@ ^ [A5: B] : ( divide_divide @ A @ ( F2 @ A5 ) @ B2 )
@ ( inf_inf @ ( set @ B ) @ A4
@ ( collect @ B
@ ^ [A5: B] : ( dvd_dvd @ A @ B2 @ ( F2 @ A5 ) ) ) ) )
@ ( divide_divide @ A
@ ( groups7311177749621191930dd_sum @ B @ A @ F2
@ ( inf_inf @ ( set @ B ) @ A4
@ ( collect @ B
@ ^ [A5: B] :
~ ( dvd_dvd @ A @ B2 @ ( F2 @ A5 ) ) ) ) )
@ B2 ) ) ) ) ) ).
% sum_div_partition
thf(fact_3917_image__mult__atLeastAtMost__if,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [C2: A,X: A,Y: A] :
( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( image2 @ A @ A @ ( times_times @ A @ C2 ) @ ( set_or1337092689740270186AtMost @ A @ X @ Y ) )
= ( set_or1337092689740270186AtMost @ A @ ( times_times @ A @ C2 @ X ) @ ( times_times @ A @ C2 @ Y ) ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( ( ord_less_eq @ A @ X @ Y )
=> ( ( image2 @ A @ A @ ( times_times @ A @ C2 ) @ ( set_or1337092689740270186AtMost @ A @ X @ Y ) )
= ( set_or1337092689740270186AtMost @ A @ ( times_times @ A @ C2 @ Y ) @ ( times_times @ A @ C2 @ X ) ) ) )
& ( ~ ( ord_less_eq @ A @ X @ Y )
=> ( ( image2 @ A @ A @ ( times_times @ A @ C2 ) @ ( set_or1337092689740270186AtMost @ A @ X @ Y ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% image_mult_atLeastAtMost_if
thf(fact_3918_image__mult__atLeastAtMost__if_H,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A,C2: A] :
( ( ( ord_less_eq @ A @ X @ Y )
=> ( ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( times_times @ A @ X2 @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ X @ Y ) )
= ( set_or1337092689740270186AtMost @ A @ ( times_times @ A @ X @ C2 ) @ ( times_times @ A @ Y @ C2 ) ) ) )
& ( ~ ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( times_times @ A @ X2 @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ X @ Y ) )
= ( set_or1337092689740270186AtMost @ A @ ( times_times @ A @ Y @ C2 ) @ ( times_times @ A @ X @ C2 ) ) ) ) ) )
& ( ~ ( ord_less_eq @ A @ X @ Y )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( times_times @ A @ X2 @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ X @ Y ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% image_mult_atLeastAtMost_if'
thf(fact_3919_image__affinity__atLeastAtMost,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,M: A,C2: A] :
( ( ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( plus_plus @ A @ ( times_times @ A @ M @ X2 ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( bot_bot @ ( set @ A ) ) ) )
& ( ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ M )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( plus_plus @ A @ ( times_times @ A @ M @ X2 ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( plus_plus @ A @ ( times_times @ A @ M @ A3 ) @ C2 ) @ ( plus_plus @ A @ ( times_times @ A @ M @ B2 ) @ C2 ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ M )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( plus_plus @ A @ ( times_times @ A @ M @ X2 ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( plus_plus @ A @ ( times_times @ A @ M @ B2 ) @ C2 ) @ ( plus_plus @ A @ ( times_times @ A @ M @ A3 ) @ C2 ) ) ) ) ) ) ) ) ).
% image_affinity_atLeastAtMost
thf(fact_3920_image__affinity__atLeastAtMost__diff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,M: A,C2: A] :
( ( ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( minus_minus @ A @ ( times_times @ A @ M @ X2 ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( bot_bot @ ( set @ A ) ) ) )
& ( ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ M )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( minus_minus @ A @ ( times_times @ A @ M @ X2 ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( minus_minus @ A @ ( times_times @ A @ M @ A3 ) @ C2 ) @ ( minus_minus @ A @ ( times_times @ A @ M @ B2 ) @ C2 ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ M )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( minus_minus @ A @ ( times_times @ A @ M @ X2 ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( minus_minus @ A @ ( times_times @ A @ M @ B2 ) @ C2 ) @ ( minus_minus @ A @ ( times_times @ A @ M @ A3 ) @ C2 ) ) ) ) ) ) ) ) ).
% image_affinity_atLeastAtMost_diff
thf(fact_3921_image__affinity__atLeastAtMost__div,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,M: A,C2: A] :
( ( ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( plus_plus @ A @ ( divide_divide @ A @ X2 @ M ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( bot_bot @ ( set @ A ) ) ) )
& ( ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ M )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( plus_plus @ A @ ( divide_divide @ A @ X2 @ M ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( plus_plus @ A @ ( divide_divide @ A @ A3 @ M ) @ C2 ) @ ( plus_plus @ A @ ( divide_divide @ A @ B2 @ M ) @ C2 ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ M )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( plus_plus @ A @ ( divide_divide @ A @ X2 @ M ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( plus_plus @ A @ ( divide_divide @ A @ B2 @ M ) @ C2 ) @ ( plus_plus @ A @ ( divide_divide @ A @ A3 @ M ) @ C2 ) ) ) ) ) ) ) ) ).
% image_affinity_atLeastAtMost_div
thf(fact_3922_image__affinity__atLeastAtMost__div__diff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,M: A,C2: A] :
( ( ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( minus_minus @ A @ ( divide_divide @ A @ X2 @ M ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( bot_bot @ ( set @ A ) ) ) )
& ( ( ( set_or1337092689740270186AtMost @ A @ A3 @ B2 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ M )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( minus_minus @ A @ ( divide_divide @ A @ X2 @ M ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( minus_minus @ A @ ( divide_divide @ A @ A3 @ M ) @ C2 ) @ ( minus_minus @ A @ ( divide_divide @ A @ B2 @ M ) @ C2 ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ M )
=> ( ( image2 @ A @ A
@ ^ [X2: A] : ( minus_minus @ A @ ( divide_divide @ A @ X2 @ M ) @ C2 )
@ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( minus_minus @ A @ ( divide_divide @ A @ B2 @ M ) @ C2 ) @ ( minus_minus @ A @ ( divide_divide @ A @ A3 @ M ) @ C2 ) ) ) ) ) ) ) ) ).
% image_affinity_atLeastAtMost_div_diff
thf(fact_3923_sum__fun__comp,axiom,
! [A: $tType,C: $tType,B: $tType] :
( ( semiring_1 @ C )
=> ! [S3: set @ A,R: set @ B,G: A > B,F2: B > C] :
( ( finite_finite @ A @ S3 )
=> ( ( finite_finite @ B @ R )
=> ( ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ G @ S3 ) @ R )
=> ( ( groups7311177749621191930dd_sum @ A @ C
@ ^ [X2: A] : ( F2 @ ( G @ X2 ) )
@ S3 )
= ( groups7311177749621191930dd_sum @ B @ C
@ ^ [Y2: B] :
( times_times @ C
@ ( semiring_1_of_nat @ C
@ ( finite_card @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ S3 )
& ( ( G @ X2 )
= Y2 ) ) ) ) )
@ ( F2 @ Y2 ) )
@ R ) ) ) ) ) ) ).
% sum_fun_comp
thf(fact_3924_distinct__concat__iff,axiom,
! [A: $tType,Xs: list @ ( list @ A )] :
( ( distinct @ A @ ( concat @ A @ Xs ) )
= ( ( distinct @ ( list @ A ) @ ( removeAll @ ( list @ A ) @ ( nil @ A ) @ Xs ) )
& ! [Ys3: list @ A] :
( ( member2 @ ( list @ A ) @ Ys3 @ ( set2 @ ( list @ A ) @ Xs ) )
=> ( distinct @ A @ Ys3 ) )
& ! [Ys3: list @ A,Zs3: list @ A] :
( ( ( member2 @ ( list @ A ) @ Ys3 @ ( set2 @ ( list @ A ) @ Xs ) )
& ( member2 @ ( list @ A ) @ Zs3 @ ( set2 @ ( list @ A ) @ Xs ) )
& ( Ys3 != Zs3 ) )
=> ( ( inf_inf @ ( set @ A ) @ ( set2 @ A @ Ys3 ) @ ( set2 @ A @ Zs3 ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% distinct_concat_iff
thf(fact_3925_card__disjoint__shuffles,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( inf_inf @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ Ys ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_card @ ( list @ A ) @ ( shuffles @ A @ Xs @ Ys ) )
= ( binomial @ ( plus_plus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ A ) @ Ys ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ) ) ).
% card_disjoint_shuffles
thf(fact_3926_card__partition,axiom,
! [A: $tType,C5: set @ ( set @ A ),K: nat] :
( ( finite_finite @ ( set @ A ) @ C5 )
=> ( ( finite_finite @ A @ ( complete_Sup_Sup @ ( set @ A ) @ C5 ) )
=> ( ! [C4: set @ A] :
( ( member2 @ ( set @ A ) @ C4 @ C5 )
=> ( ( finite_card @ A @ C4 )
= K ) )
=> ( ! [C1: set @ A,C22: set @ A] :
( ( member2 @ ( set @ A ) @ C1 @ C5 )
=> ( ( member2 @ ( set @ A ) @ C22 @ C5 )
=> ( ( C1 != C22 )
=> ( ( inf_inf @ ( set @ A ) @ C1 @ C22 )
= ( bot_bot @ ( set @ A ) ) ) ) ) )
=> ( ( times_times @ nat @ K @ ( finite_card @ ( set @ A ) @ C5 ) )
= ( finite_card @ A @ ( complete_Sup_Sup @ ( set @ A ) @ C5 ) ) ) ) ) ) ) ).
% card_partition
thf(fact_3927_nth__image,axiom,
! [A: $tType,L: nat,Xs: list @ A] :
( ( ord_less_eq @ nat @ L @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( image2 @ nat @ A @ ( nth @ A @ Xs ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ L ) )
= ( set2 @ A @ ( take @ A @ L @ Xs ) ) ) ) ).
% nth_image
thf(fact_3928_zip__Nil,axiom,
! [B: $tType,A: $tType,Ys: list @ B] :
( ( zip @ A @ B @ ( nil @ A ) @ Ys )
= ( nil @ ( product_prod @ A @ B ) ) ) ).
% zip_Nil
thf(fact_3929_Nil__eq__zip__iff,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B] :
( ( ( nil @ ( product_prod @ A @ B ) )
= ( zip @ A @ B @ Xs @ Ys ) )
= ( ( Xs
= ( nil @ A ) )
| ( Ys
= ( nil @ B ) ) ) ) ).
% Nil_eq_zip_iff
thf(fact_3930_zip__eq__Nil__iff,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B] :
( ( ( zip @ A @ B @ Xs @ Ys )
= ( nil @ ( product_prod @ A @ B ) ) )
= ( ( Xs
= ( nil @ A ) )
| ( Ys
= ( nil @ B ) ) ) ) ).
% zip_eq_Nil_iff
thf(fact_3931_list__update__nonempty,axiom,
! [A: $tType,Xs: list @ A,K: nat,X: A] :
( ( ( list_update @ A @ Xs @ K @ X )
= ( nil @ A ) )
= ( Xs
= ( nil @ A ) ) ) ).
% list_update_nonempty
thf(fact_3932_concat__replicate__trivial,axiom,
! [A: $tType,I: nat] :
( ( concat @ A @ ( replicate @ ( list @ A ) @ I @ ( nil @ A ) ) )
= ( nil @ A ) ) ).
% concat_replicate_trivial
thf(fact_3933_Nil__in__shuffles,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( member2 @ ( list @ A ) @ ( nil @ A ) @ ( shuffles @ A @ Xs @ Ys ) )
= ( ( Xs
= ( nil @ A ) )
& ( Ys
= ( nil @ A ) ) ) ) ).
% Nil_in_shuffles
thf(fact_3934_enumerate__simps_I1_J,axiom,
! [A: $tType,N2: nat] :
( ( enumerate @ A @ N2 @ ( nil @ A ) )
= ( nil @ ( product_prod @ nat @ A ) ) ) ).
% enumerate_simps(1)
thf(fact_3935_rotate1__is__Nil__conv,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( rotate1 @ A @ Xs )
= ( nil @ A ) )
= ( Xs
= ( nil @ A ) ) ) ).
% rotate1_is_Nil_conv
thf(fact_3936_pair__imageI,axiom,
! [C: $tType,B: $tType,A: $tType,A3: A,B2: B,A4: set @ ( product_prod @ A @ B ),F2: A > B > C] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ A4 )
=> ( member2 @ C @ ( F2 @ A3 @ B2 ) @ ( image2 @ ( product_prod @ A @ B ) @ C @ ( product_case_prod @ A @ B @ C @ F2 ) @ A4 ) ) ) ).
% pair_imageI
thf(fact_3937_list__ex1__simps_I1_J,axiom,
! [A: $tType,P2: A > $o] :
~ ( list_ex1 @ A @ P2 @ ( nil @ A ) ) ).
% list_ex1_simps(1)
thf(fact_3938_finite__shuffles,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] : ( finite_finite @ ( list @ A ) @ ( shuffles @ A @ Xs @ Ys ) ) ).
% finite_shuffles
thf(fact_3939_Sup__atLeastAtMost,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( complete_Sup_Sup @ A @ ( set_or1337092689740270186AtMost @ A @ X @ Y ) )
= Y ) ) ) ).
% Sup_atLeastAtMost
thf(fact_3940_cSup__atLeastAtMost,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ Y @ X )
=> ( ( complete_Sup_Sup @ A @ ( set_or1337092689740270186AtMost @ A @ Y @ X ) )
= X ) ) ) ).
% cSup_atLeastAtMost
thf(fact_3941_cSup__singleton,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X: A] :
( ( complete_Sup_Sup @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= X ) ) ).
% cSup_singleton
thf(fact_3942_set__empty,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( set2 @ A @ Xs )
= ( bot_bot @ ( set @ A ) ) )
= ( Xs
= ( nil @ A ) ) ) ).
% set_empty
thf(fact_3943_set__empty2,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( bot_bot @ ( set @ A ) )
= ( set2 @ A @ Xs ) )
= ( Xs
= ( nil @ A ) ) ) ).
% set_empty2
thf(fact_3944_length__0__conv,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( zero_zero @ nat ) )
= ( Xs
= ( nil @ A ) ) ) ).
% length_0_conv
thf(fact_3945_Sup__atLeastLessThan,axiom,
! [A: $tType] :
( ( ( comple6319245703460814977attice @ A )
& ( dense_linorder @ A ) )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( ( complete_Sup_Sup @ A @ ( set_or7035219750837199246ssThan @ A @ X @ Y ) )
= Y ) ) ) ).
% Sup_atLeastLessThan
thf(fact_3946_cSup__atLeastLessThan,axiom,
! [A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( dense_linorder @ A ) )
=> ! [Y: A,X: A] :
( ( ord_less @ A @ Y @ X )
=> ( ( complete_Sup_Sup @ A @ ( set_or7035219750837199246ssThan @ A @ Y @ X ) )
= X ) ) ) ).
% cSup_atLeastLessThan
thf(fact_3947_take__eq__Nil2,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ( nil @ A )
= ( take @ A @ N2 @ Xs ) )
= ( ( N2
= ( zero_zero @ nat ) )
| ( Xs
= ( nil @ A ) ) ) ) ).
% take_eq_Nil2
thf(fact_3948_take__eq__Nil,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ( take @ A @ N2 @ Xs )
= ( nil @ A ) )
= ( ( N2
= ( zero_zero @ nat ) )
| ( Xs
= ( nil @ A ) ) ) ) ).
% take_eq_Nil
thf(fact_3949_take0,axiom,
! [A: $tType] :
( ( take @ A @ ( zero_zero @ nat ) )
= ( ^ [Xs2: list @ A] : ( nil @ A ) ) ) ).
% take0
thf(fact_3950_replicate__empty,axiom,
! [A: $tType,N2: nat,X: A] :
( ( ( replicate @ A @ N2 @ X )
= ( nil @ A ) )
= ( N2
= ( zero_zero @ nat ) ) ) ).
% replicate_empty
thf(fact_3951_empty__replicate,axiom,
! [A: $tType,N2: nat,X: A] :
( ( ( nil @ A )
= ( replicate @ A @ N2 @ X ) )
= ( N2
= ( zero_zero @ nat ) ) ) ).
% empty_replicate
thf(fact_3952_take__all__iff,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ( take @ A @ N2 @ Xs )
= Xs )
= ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 ) ) ).
% take_all_iff
thf(fact_3953_take__all,axiom,
! [A: $tType,Xs: list @ A,N2: nat] :
( ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 )
=> ( ( take @ A @ N2 @ Xs )
= Xs ) ) ).
% take_all
thf(fact_3954_nth__take,axiom,
! [A: $tType,I: nat,N2: nat,Xs: list @ A] :
( ( ord_less @ nat @ I @ N2 )
=> ( ( nth @ A @ ( take @ A @ N2 @ Xs ) @ I )
= ( nth @ A @ Xs @ I ) ) ) ).
% nth_take
thf(fact_3955_sorted__list__of__set_Osorted__key__list__of__set__empty,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( linord4507533701916653071of_set @ A @ ( bot_bot @ ( set @ A ) ) )
= ( nil @ A ) ) ) ).
% sorted_list_of_set.sorted_key_list_of_set_empty
thf(fact_3956_sorted__list__of__set_Ofold__insort__key_Oinfinite,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ~ ( finite_finite @ A @ A4 )
=> ( ( linord4507533701916653071of_set @ A @ A4 )
= ( nil @ A ) ) ) ) ).
% sorted_list_of_set.fold_insort_key.infinite
thf(fact_3957_take__update__cancel,axiom,
! [A: $tType,N2: nat,M: nat,Xs: list @ A,Y: A] :
( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( take @ A @ N2 @ ( list_update @ A @ Xs @ M @ Y ) )
= ( take @ A @ N2 @ Xs ) ) ) ).
% take_update_cancel
thf(fact_3958_horner__sum__simps_I1_J,axiom,
! [B: $tType,A: $tType] :
( ( comm_semiring_0 @ A )
=> ! [F2: B > A,A3: A] :
( ( groups4207007520872428315er_sum @ B @ A @ F2 @ A3 @ ( nil @ B ) )
= ( zero_zero @ A ) ) ) ).
% horner_sum_simps(1)
thf(fact_3959_cSUP__const,axiom,
! [B: $tType,A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,C2: A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Sup_Sup @ A
@ ( image2 @ B @ A
@ ^ [X2: B] : C2
@ A4 ) )
= C2 ) ) ) ).
% cSUP_const
thf(fact_3960_concat__eq__Nil__conv,axiom,
! [A: $tType,Xss: list @ ( list @ A )] :
( ( ( concat @ A @ Xss )
= ( nil @ A ) )
= ( ! [X2: list @ A] :
( ( member2 @ ( list @ A ) @ X2 @ ( set2 @ ( list @ A ) @ Xss ) )
=> ( X2
= ( nil @ A ) ) ) ) ) ).
% concat_eq_Nil_conv
thf(fact_3961_Nil__eq__concat__conv,axiom,
! [A: $tType,Xss: list @ ( list @ A )] :
( ( ( nil @ A )
= ( concat @ A @ Xss ) )
= ( ! [X2: list @ A] :
( ( member2 @ ( list @ A ) @ X2 @ ( set2 @ ( list @ A ) @ Xss ) )
=> ( X2
= ( nil @ A ) ) ) ) ) ).
% Nil_eq_concat_conv
thf(fact_3962_length__greater__0__conv,axiom,
! [A: $tType,Xs: list @ A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( size_size @ ( list @ A ) @ Xs ) )
= ( Xs
!= ( nil @ A ) ) ) ).
% length_greater_0_conv
thf(fact_3963_sorted__list__of__set_Osorted__key__list__of__set__eq__Nil__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( ( linord4507533701916653071of_set @ A @ A4 )
= ( nil @ A ) )
= ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% sorted_list_of_set.sorted_key_list_of_set_eq_Nil_iff
thf(fact_3964_set__concat,axiom,
! [A: $tType,Xs: list @ ( list @ A )] :
( ( set2 @ A @ ( concat @ A @ Xs ) )
= ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ ( list @ A ) @ ( set @ A ) @ ( set2 @ A ) @ ( set2 @ ( list @ A ) @ Xs ) ) ) ) ).
% set_concat
thf(fact_3965_list__update__code_I1_J,axiom,
! [A: $tType,I: nat,Y: A] :
( ( list_update @ A @ ( nil @ A ) @ I @ Y )
= ( nil @ A ) ) ).
% list_update_code(1)
thf(fact_3966_list__update_Osimps_I1_J,axiom,
! [A: $tType,I: nat,V2: A] :
( ( list_update @ A @ ( nil @ A ) @ I @ V2 )
= ( nil @ A ) ) ).
% list_update.simps(1)
thf(fact_3967_in__set__takeD,axiom,
! [A: $tType,X: A,N2: nat,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ ( take @ A @ N2 @ Xs ) ) )
=> ( member2 @ A @ X @ ( set2 @ A @ Xs ) ) ) ).
% in_set_takeD
thf(fact_3968_concat_Osimps_I1_J,axiom,
! [A: $tType] :
( ( concat @ A @ ( nil @ ( list @ A ) ) )
= ( nil @ A ) ) ).
% concat.simps(1)
thf(fact_3969_take__update__swap,axiom,
! [A: $tType,M: nat,Xs: list @ A,N2: nat,X: A] :
( ( take @ A @ M @ ( list_update @ A @ Xs @ N2 @ X ) )
= ( list_update @ A @ ( take @ A @ M @ Xs ) @ N2 @ X ) ) ).
% take_update_swap
thf(fact_3970_cSup__eq,axiom,
! [A: $tType] :
( ( ( condit1219197933456340205attice @ A )
& ( no_bot @ A ) )
=> ! [X7: set @ A,A3: A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ( ord_less_eq @ A @ X5 @ A3 ) )
=> ( ! [Y4: A] :
( ! [X3: A] :
( ( member2 @ A @ X3 @ X7 )
=> ( ord_less_eq @ A @ X3 @ Y4 ) )
=> ( ord_less_eq @ A @ A3 @ Y4 ) )
=> ( ( complete_Sup_Sup @ A @ X7 )
= A3 ) ) ) ) ).
% cSup_eq
thf(fact_3971_cSup__eq__maximum,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [Z: A,X7: set @ A] :
( ( member2 @ A @ Z @ X7 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ( ord_less_eq @ A @ X5 @ Z ) )
=> ( ( complete_Sup_Sup @ A @ X7 )
= Z ) ) ) ) ).
% cSup_eq_maximum
thf(fact_3972_zip_Osimps_I1_J,axiom,
! [B: $tType,A: $tType,Xs: list @ A] :
( ( zip @ A @ B @ Xs @ ( nil @ B ) )
= ( nil @ ( product_prod @ A @ B ) ) ) ).
% zip.simps(1)
thf(fact_3973_take__zip,axiom,
! [A: $tType,B: $tType,N2: nat,Xs: list @ A,Ys: list @ B] :
( ( take @ ( product_prod @ A @ B ) @ N2 @ ( zip @ A @ B @ Xs @ Ys ) )
= ( zip @ A @ B @ ( take @ A @ N2 @ Xs ) @ ( take @ B @ N2 @ Ys ) ) ) ).
% take_zip
thf(fact_3974_shuffles__commutes,axiom,
! [A: $tType] :
( ( shuffles @ A )
= ( ^ [Xs2: list @ A,Ys3: list @ A] : ( shuffles @ A @ Ys3 @ Xs2 ) ) ) ).
% shuffles_commutes
thf(fact_3975_Nil__in__shufflesI,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( Xs
= ( nil @ A ) )
=> ( ( Ys
= ( nil @ A ) )
=> ( member2 @ ( list @ A ) @ ( nil @ A ) @ ( shuffles @ A @ Xs @ Ys ) ) ) ) ).
% Nil_in_shufflesI
thf(fact_3976_take__equalityI,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ! [I3: nat] :
( ( take @ A @ I3 @ Xs )
= ( take @ A @ I3 @ Ys ) )
=> ( Xs = Ys ) ) ).
% take_equalityI
thf(fact_3977_take__Nil,axiom,
! [A: $tType,N2: nat] :
( ( take @ A @ N2 @ ( nil @ A ) )
= ( nil @ A ) ) ).
% take_Nil
thf(fact_3978_product_Osimps_I1_J,axiom,
! [B: $tType,A: $tType,Uu: list @ B] :
( ( product @ A @ B @ ( nil @ A ) @ Uu )
= ( nil @ ( product_prod @ A @ B ) ) ) ).
% product.simps(1)
thf(fact_3979_take__0,axiom,
! [A: $tType,Xs: list @ A] :
( ( take @ A @ ( zero_zero @ nat ) @ Xs )
= ( nil @ A ) ) ).
% take_0
thf(fact_3980_shuffles_Osimps_I1_J,axiom,
! [A: $tType,Ys: list @ A] :
( ( shuffles @ A @ ( nil @ A ) @ Ys )
= ( insert2 @ ( list @ A ) @ Ys @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) ) ).
% shuffles.simps(1)
thf(fact_3981_shuffles_Osimps_I2_J,axiom,
! [A: $tType,Xs: list @ A] :
( ( shuffles @ A @ Xs @ ( nil @ A ) )
= ( insert2 @ ( list @ A ) @ Xs @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) ) ).
% shuffles.simps(2)
thf(fact_3982_distinct_Osimps_I1_J,axiom,
! [A: $tType] : ( distinct @ A @ ( nil @ A ) ) ).
% distinct.simps(1)
thf(fact_3983_distinct__take,axiom,
! [A: $tType,Xs: list @ A,I: nat] :
( ( distinct @ A @ Xs )
=> ( distinct @ A @ ( take @ A @ I @ Xs ) ) ) ).
% distinct_take
thf(fact_3984_inf__Int__eq2,axiom,
! [B: $tType,A: $tType,R: set @ ( product_prod @ A @ B ),S3: set @ ( product_prod @ A @ B )] :
( ( inf_inf @ ( A > B > $o )
@ ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R )
@ ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ S3 ) )
= ( ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( inf_inf @ ( set @ ( product_prod @ A @ B ) ) @ R @ S3 ) ) ) ) ).
% inf_Int_eq2
thf(fact_3985_insort__not__Nil,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,A3: B,Xs: list @ B] :
( ( linorder_insort_key @ B @ A @ F2 @ A3 @ Xs )
!= ( nil @ B ) ) ) ).
% insort_not_Nil
thf(fact_3986_remove1_Osimps_I1_J,axiom,
! [A: $tType,X: A] :
( ( remove1 @ A @ X @ ( nil @ A ) )
= ( nil @ A ) ) ).
% remove1.simps(1)
thf(fact_3987_removeAll_Osimps_I1_J,axiom,
! [A: $tType,X: A] :
( ( removeAll @ A @ X @ ( nil @ A ) )
= ( nil @ A ) ) ).
% removeAll.simps(1)
thf(fact_3988_rotate1_Osimps_I1_J,axiom,
! [A: $tType] :
( ( rotate1 @ A @ ( nil @ A ) )
= ( nil @ A ) ) ).
% rotate1.simps(1)
thf(fact_3989_UN__le__add__shift__strict,axiom,
! [A: $tType,M7: nat > ( set @ A ),K: nat,N2: nat] :
( ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ nat @ ( set @ A )
@ ^ [I5: nat] : ( M7 @ ( plus_plus @ nat @ I5 @ K ) )
@ ( set_ord_lessThan @ nat @ N2 ) ) )
= ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ M7 @ ( set_or7035219750837199246ssThan @ nat @ K @ ( plus_plus @ nat @ N2 @ K ) ) ) ) ) ).
% UN_le_add_shift_strict
thf(fact_3990_UN__le__add__shift,axiom,
! [A: $tType,M7: nat > ( set @ A ),K: nat,N2: nat] :
( ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ nat @ ( set @ A )
@ ^ [I5: nat] : ( M7 @ ( plus_plus @ nat @ I5 @ K ) )
@ ( set_ord_atMost @ nat @ N2 ) ) )
= ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ M7 @ ( set_or1337092689740270186AtMost @ nat @ K @ ( plus_plus @ nat @ N2 @ K ) ) ) ) ) ).
% UN_le_add_shift
thf(fact_3991_set__take__subset,axiom,
! [A: $tType,N2: nat,Xs: list @ A] : ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ ( take @ A @ N2 @ Xs ) ) @ ( set2 @ A @ Xs ) ) ).
% set_take_subset
thf(fact_3992_member__rec_I2_J,axiom,
! [A: $tType,Y: A] :
~ ( member @ A @ ( nil @ A ) @ Y ) ).
% member_rec(2)
thf(fact_3993_cSup__eq__non__empty,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A,A3: A] :
( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ( ord_less_eq @ A @ X5 @ A3 ) )
=> ( ! [Y4: A] :
( ! [X3: A] :
( ( member2 @ A @ X3 @ X7 )
=> ( ord_less_eq @ A @ X3 @ Y4 ) )
=> ( ord_less_eq @ A @ A3 @ Y4 ) )
=> ( ( complete_Sup_Sup @ A @ X7 )
= A3 ) ) ) ) ) ).
% cSup_eq_non_empty
thf(fact_3994_cSup__least,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A,Z: A] :
( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ( ord_less_eq @ A @ X5 @ Z ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ X7 ) @ Z ) ) ) ) ).
% cSup_least
thf(fact_3995_le__cSup__finite,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A,X: A] :
( ( finite_finite @ A @ X7 )
=> ( ( member2 @ A @ X @ X7 )
=> ( ord_less_eq @ A @ X @ ( complete_Sup_Sup @ A @ X7 ) ) ) ) ) ).
% le_cSup_finite
thf(fact_3996_less__cSupD,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [X7: set @ A,Z: A] :
( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less @ A @ Z @ ( complete_Sup_Sup @ A @ X7 ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ X7 )
& ( ord_less @ A @ Z @ X5 ) ) ) ) ) ).
% less_cSupD
thf(fact_3997_less__cSupE,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [Y: A,X7: set @ A] :
( ( ord_less @ A @ Y @ ( complete_Sup_Sup @ A @ X7 ) )
=> ( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ~ ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ~ ( ord_less @ A @ Y @ X5 ) ) ) ) ) ).
% less_cSupE
thf(fact_3998_finite__imp__Sup__less,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [X7: set @ A,X: A,A3: A] :
( ( finite_finite @ A @ X7 )
=> ( ( member2 @ A @ X @ X7 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ( ord_less @ A @ X5 @ A3 ) )
=> ( ord_less @ A @ ( complete_Sup_Sup @ A @ X7 ) @ A3 ) ) ) ) ) ).
% finite_imp_Sup_less
thf(fact_3999_Sup__inf__eq__bot__iff,axiom,
! [A: $tType] :
( ( comple592849572758109894attice @ A )
=> ! [B3: set @ A,A3: A] :
( ( ( inf_inf @ A @ ( complete_Sup_Sup @ A @ B3 ) @ A3 )
= ( bot_bot @ A ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ B3 )
=> ( ( inf_inf @ A @ X2 @ A3 )
= ( bot_bot @ A ) ) ) ) ) ) ).
% Sup_inf_eq_bot_iff
thf(fact_4000_sum_OUNION__disjoint,axiom,
! [A: $tType,C: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [I6: set @ B,A4: B > ( set @ C ),G: C > A] :
( ( finite_finite @ B @ I6 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ I6 )
=> ( finite_finite @ C @ ( A4 @ X5 ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ I6 )
=> ! [Xa4: B] :
( ( member2 @ B @ Xa4 @ I6 )
=> ( ( X5 != Xa4 )
=> ( ( inf_inf @ ( set @ C ) @ ( A4 @ X5 ) @ ( A4 @ Xa4 ) )
= ( bot_bot @ ( set @ C ) ) ) ) ) )
=> ( ( groups7311177749621191930dd_sum @ C @ A @ G @ ( complete_Sup_Sup @ ( set @ C ) @ ( image2 @ B @ ( set @ C ) @ A4 @ I6 ) ) )
= ( groups7311177749621191930dd_sum @ B @ A
@ ^ [X2: B] : ( groups7311177749621191930dd_sum @ C @ A @ G @ ( A4 @ X2 ) )
@ I6 ) ) ) ) ) ) ).
% sum.UNION_disjoint
thf(fact_4001_prod_OUNION__disjoint,axiom,
! [A: $tType,C: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [I6: set @ B,A4: B > ( set @ C ),G: C > A] :
( ( finite_finite @ B @ I6 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ I6 )
=> ( finite_finite @ C @ ( A4 @ X5 ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ I6 )
=> ! [Xa4: B] :
( ( member2 @ B @ Xa4 @ I6 )
=> ( ( X5 != Xa4 )
=> ( ( inf_inf @ ( set @ C ) @ ( A4 @ X5 ) @ ( A4 @ Xa4 ) )
= ( bot_bot @ ( set @ C ) ) ) ) ) )
=> ( ( groups7121269368397514597t_prod @ C @ A @ G @ ( complete_Sup_Sup @ ( set @ C ) @ ( image2 @ B @ ( set @ C ) @ A4 @ I6 ) ) )
= ( groups7121269368397514597t_prod @ B @ A
@ ^ [X2: B] : ( groups7121269368397514597t_prod @ C @ A @ G @ ( A4 @ X2 ) )
@ I6 ) ) ) ) ) ) ).
% prod.UNION_disjoint
thf(fact_4002_None__notin__image__Some,axiom,
! [A: $tType,A4: set @ A] :
~ ( member2 @ ( option @ A ) @ ( none @ A ) @ ( image2 @ A @ ( option @ A ) @ ( some @ A ) @ A4 ) ) ).
% None_notin_image_Some
thf(fact_4003_insert__partition,axiom,
! [A: $tType,X: set @ A,F5: set @ ( set @ A )] :
( ~ ( member2 @ ( set @ A ) @ X @ F5 )
=> ( ! [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ ( insert2 @ ( set @ A ) @ X @ F5 ) )
=> ! [Xa4: set @ A] :
( ( member2 @ ( set @ A ) @ Xa4 @ ( insert2 @ ( set @ A ) @ X @ F5 ) )
=> ( ( X5 != Xa4 )
=> ( ( inf_inf @ ( set @ A ) @ X5 @ Xa4 )
= ( bot_bot @ ( set @ A ) ) ) ) ) )
=> ( ( inf_inf @ ( set @ A ) @ X @ ( complete_Sup_Sup @ ( set @ A ) @ F5 ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% insert_partition
thf(fact_4004_card__Union__le__sum__card,axiom,
! [A: $tType,U3: set @ ( set @ A )] : ( ord_less_eq @ nat @ ( finite_card @ A @ ( complete_Sup_Sup @ ( set @ A ) @ U3 ) ) @ ( groups7311177749621191930dd_sum @ ( set @ A ) @ nat @ ( finite_card @ A ) @ U3 ) ) ).
% card_Union_le_sum_card
thf(fact_4005_card__UN__le,axiom,
! [B: $tType,A: $tType,I6: set @ A,A4: A > ( set @ B )] :
( ( finite_finite @ A @ I6 )
=> ( ord_less_eq @ nat @ ( finite_card @ B @ ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ A4 @ I6 ) ) )
@ ( groups7311177749621191930dd_sum @ A @ nat
@ ^ [I5: A] : ( finite_card @ B @ ( A4 @ I5 ) )
@ I6 ) ) ) ).
% card_UN_le
thf(fact_4006_empty__set,axiom,
! [A: $tType] :
( ( bot_bot @ ( set @ A ) )
= ( set2 @ A @ ( nil @ A ) ) ) ).
% empty_set
thf(fact_4007_list_Osize_I3_J,axiom,
! [A: $tType] :
( ( size_size @ ( list @ A ) @ ( nil @ A ) )
= ( zero_zero @ nat ) ) ).
% list.size(3)
thf(fact_4008_length__shuffles,axiom,
! [A: $tType,Zs: list @ A,Xs: list @ A,Ys: list @ A] :
( ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ Xs @ Ys ) )
=> ( ( size_size @ ( list @ A ) @ Zs )
= ( plus_plus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ A ) @ Ys ) ) ) ) ).
% length_shuffles
thf(fact_4009_replicate__0,axiom,
! [A: $tType,X: A] :
( ( replicate @ A @ ( zero_zero @ nat ) @ X )
= ( nil @ A ) ) ).
% replicate_0
thf(fact_4010_not__listrel1__Nil,axiom,
! [A: $tType,Xs: list @ A,R2: set @ ( product_prod @ A @ A )] :
~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ ( nil @ A ) ) @ ( listrel1 @ A @ R2 ) ) ).
% not_listrel1_Nil
thf(fact_4011_not__Nil__listrel1,axiom,
! [A: $tType,Xs: list @ A,R2: set @ ( product_prod @ A @ A )] :
~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Xs ) @ ( listrel1 @ A @ R2 ) ) ).
% not_Nil_listrel1
thf(fact_4012_list_Osize__gen_I1_J,axiom,
! [A: $tType,X: A > nat] :
( ( size_list @ A @ X @ ( nil @ A ) )
= ( zero_zero @ nat ) ) ).
% list.size_gen(1)
thf(fact_4013_find_Osimps_I1_J,axiom,
! [A: $tType,Uu: A > $o] :
( ( find @ A @ Uu @ ( nil @ A ) )
= ( none @ A ) ) ).
% find.simps(1)
thf(fact_4014_card__UN__disjoint,axiom,
! [B: $tType,A: $tType,I6: set @ A,A4: A > ( set @ B )] :
( ( finite_finite @ A @ I6 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ I6 )
=> ( finite_finite @ B @ ( A4 @ X5 ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ I6 )
=> ! [Xa4: A] :
( ( member2 @ A @ Xa4 @ I6 )
=> ( ( X5 != Xa4 )
=> ( ( inf_inf @ ( set @ B ) @ ( A4 @ X5 ) @ ( A4 @ Xa4 ) )
= ( bot_bot @ ( set @ B ) ) ) ) ) )
=> ( ( finite_card @ B @ ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ A4 @ I6 ) ) )
= ( groups7311177749621191930dd_sum @ A @ nat
@ ^ [I5: A] : ( finite_card @ B @ ( A4 @ I5 ) )
@ I6 ) ) ) ) ) ).
% card_UN_disjoint
thf(fact_4015_count__list_Osimps_I1_J,axiom,
! [A: $tType,Y: A] :
( ( count_list @ A @ ( nil @ A ) @ Y )
= ( zero_zero @ nat ) ) ).
% count_list.simps(1)
thf(fact_4016_set__take__subset__set__take,axiom,
! [A: $tType,M: nat,N2: nat,Xs: list @ A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ ( take @ A @ M @ Xs ) ) @ ( set2 @ A @ ( take @ A @ N2 @ Xs ) ) ) ) ).
% set_take_subset_set_take
thf(fact_4017_cSUP__least,axiom,
! [B: $tType,A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,F2: B > A,M7: A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ M7 ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ M7 ) ) ) ) ).
% cSUP_least
thf(fact_4018_finite__Sup__less__iff,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [X7: set @ A,A3: A] :
( ( finite_finite @ A @ X7 )
=> ( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less @ A @ ( complete_Sup_Sup @ A @ X7 ) @ A3 )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ X7 )
=> ( ord_less @ A @ X2 @ A3 ) ) ) ) ) ) ) ).
% finite_Sup_less_iff
thf(fact_4019_cSup__abs__le,axiom,
! [A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( linordered_idom @ A ) )
=> ! [S3: set @ A,A3: A] :
( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ S3 )
=> ( ord_less_eq @ A @ ( abs_abs @ A @ X5 ) @ A3 ) )
=> ( ord_less_eq @ A @ ( abs_abs @ A @ ( complete_Sup_Sup @ A @ S3 ) ) @ A3 ) ) ) ) ).
% cSup_abs_le
thf(fact_4020_in__image__insert__iff,axiom,
! [A: $tType,B3: set @ ( set @ A ),X: A,A4: set @ A] :
( ! [C6: set @ A] :
( ( member2 @ ( set @ A ) @ C6 @ B3 )
=> ~ ( member2 @ A @ X @ C6 ) )
=> ( ( member2 @ ( set @ A ) @ A4 @ ( image2 @ ( set @ A ) @ ( set @ A ) @ ( insert2 @ A @ X ) @ B3 ) )
= ( ( member2 @ A @ X @ A4 )
& ( member2 @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) @ B3 ) ) ) ) ).
% in_image_insert_iff
thf(fact_4021_card__Union__le__sum__card__weak,axiom,
! [A: $tType,U3: set @ ( set @ A )] :
( ! [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ U3 )
=> ( finite_finite @ A @ X5 ) )
=> ( ord_less_eq @ nat @ ( finite_card @ A @ ( complete_Sup_Sup @ ( set @ A ) @ U3 ) ) @ ( groups7311177749621191930dd_sum @ ( set @ A ) @ nat @ ( finite_card @ A ) @ U3 ) ) ) ).
% card_Union_le_sum_card_weak
thf(fact_4022_finite__subset__Union,axiom,
! [A: $tType,A4: set @ A,B10: set @ ( set @ A )] :
( ( finite_finite @ A @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( complete_Sup_Sup @ ( set @ A ) @ B10 ) )
=> ~ ! [F7: set @ ( set @ A )] :
( ( finite_finite @ ( set @ A ) @ F7 )
=> ( ( ord_less_eq @ ( set @ ( set @ A ) ) @ F7 @ B10 )
=> ~ ( ord_less_eq @ ( set @ A ) @ A4 @ ( complete_Sup_Sup @ ( set @ A ) @ F7 ) ) ) ) ) ) ).
% finite_subset_Union
thf(fact_4023_nth__take__lemma,axiom,
! [A: $tType,K: nat,Xs: list @ A,Ys: list @ A] :
( ( ord_less_eq @ nat @ K @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ord_less_eq @ nat @ K @ ( size_size @ ( list @ A ) @ Ys ) )
=> ( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ K )
=> ( ( nth @ A @ Xs @ I3 )
= ( nth @ A @ Ys @ I3 ) ) )
=> ( ( take @ A @ K @ Xs )
= ( take @ A @ K @ Ys ) ) ) ) ) ).
% nth_take_lemma
thf(fact_4024_cSup__asclose,axiom,
! [A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( linordered_idom @ A ) )
=> ! [S3: set @ A,L: A,E3: A] :
( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ S3 )
=> ( ord_less_eq @ A @ ( abs_abs @ A @ ( minus_minus @ A @ X5 @ L ) ) @ E3 ) )
=> ( ord_less_eq @ A @ ( abs_abs @ A @ ( minus_minus @ A @ ( complete_Sup_Sup @ A @ S3 ) @ L ) ) @ E3 ) ) ) ) ).
% cSup_asclose
thf(fact_4025_Sup__insert__finite,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [S3: set @ A,X: A] :
( ( finite_finite @ A @ S3 )
=> ( ( ( S3
= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Sup_Sup @ A @ ( insert2 @ A @ X @ S3 ) )
= X ) )
& ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Sup_Sup @ A @ ( insert2 @ A @ X @ S3 ) )
= ( ord_max @ A @ X @ ( complete_Sup_Sup @ A @ S3 ) ) ) ) ) ) ) ).
% Sup_insert_finite
thf(fact_4026_distinct__disjoint__shuffles,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ( distinct @ A @ Xs )
=> ( ( distinct @ A @ Ys )
=> ( ( ( inf_inf @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ Ys ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ Xs @ Ys ) )
=> ( distinct @ A @ Zs ) ) ) ) ) ).
% distinct_disjoint_shuffles
thf(fact_4027_subset__subseqs,axiom,
! [A: $tType,X7: set @ A,Xs: list @ A] :
( ( ord_less_eq @ ( set @ A ) @ X7 @ ( set2 @ A @ Xs ) )
=> ( member2 @ ( set @ A ) @ X7 @ ( image2 @ ( list @ A ) @ ( set @ A ) @ ( set2 @ A ) @ ( set2 @ ( list @ A ) @ ( subseqs @ A @ Xs ) ) ) ) ) ).
% subset_subseqs
thf(fact_4028_dvd__partition,axiom,
! [A: $tType,C5: set @ ( set @ A ),K: nat] :
( ( finite_finite @ A @ ( complete_Sup_Sup @ ( set @ A ) @ C5 ) )
=> ( ! [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ C5 )
=> ( dvd_dvd @ nat @ K @ ( finite_card @ A @ X5 ) ) )
=> ( ! [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ C5 )
=> ! [Xa4: set @ A] :
( ( member2 @ ( set @ A ) @ Xa4 @ C5 )
=> ( ( X5 != Xa4 )
=> ( ( inf_inf @ ( set @ A ) @ X5 @ Xa4 )
= ( bot_bot @ ( set @ A ) ) ) ) ) )
=> ( dvd_dvd @ nat @ K @ ( finite_card @ A @ ( complete_Sup_Sup @ ( set @ A ) @ C5 ) ) ) ) ) ) ).
% dvd_partition
thf(fact_4029_ccSUP__empty,axiom,
! [B: $tType,A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [F2: B > A] :
( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ ( bot_bot @ ( set @ B ) ) ) )
= ( bot_bot @ A ) ) ) ).
% ccSUP_empty
thf(fact_4030_UN__singleton,axiom,
! [A: $tType,A4: set @ A] :
( ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ A @ ( set @ A )
@ ^ [X2: A] : ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) )
@ A4 ) )
= A4 ) ).
% UN_singleton
thf(fact_4031_UN__simps_I1_J,axiom,
! [A: $tType,B: $tType,C5: set @ B,A3: A,B3: B > ( set @ A )] :
( ( ( C5
= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [X2: B] : ( insert2 @ A @ A3 @ ( B3 @ X2 ) )
@ C5 ) )
= ( bot_bot @ ( set @ A ) ) ) )
& ( ( C5
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [X2: B] : ( insert2 @ A @ A3 @ ( B3 @ X2 ) )
@ C5 ) )
= ( insert2 @ A @ A3 @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ B3 @ C5 ) ) ) ) ) ) ).
% UN_simps(1)
thf(fact_4032_SUP__const,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,F2: A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Sup_Sup @ A
@ ( image2 @ B @ A
@ ^ [I5: B] : F2
@ A4 ) )
= F2 ) ) ) ).
% SUP_const
thf(fact_4033_Sup__bot__conv_I1_J,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A] :
( ( ( complete_Sup_Sup @ A @ A4 )
= ( bot_bot @ A ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( X2
= ( bot_bot @ A ) ) ) ) ) ) ).
% Sup_bot_conv(1)
thf(fact_4034_Sup__bot__conv_I2_J,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A] :
( ( ( bot_bot @ A )
= ( complete_Sup_Sup @ A @ A4 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( X2
= ( bot_bot @ A ) ) ) ) ) ) ).
% Sup_bot_conv(2)
thf(fact_4035_Sup__nat__empty,axiom,
( ( complete_Sup_Sup @ nat @ ( bot_bot @ ( set @ nat ) ) )
= ( zero_zero @ nat ) ) ).
% Sup_nat_empty
thf(fact_4036_ccSup__empty,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ( ( complete_Sup_Sup @ A @ ( bot_bot @ ( set @ A ) ) )
= ( bot_bot @ A ) ) ) ).
% ccSup_empty
thf(fact_4037_Sup__empty,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ( ( complete_Sup_Sup @ A @ ( bot_bot @ ( set @ A ) ) )
= ( bot_bot @ A ) ) ) ).
% Sup_empty
thf(fact_4038_ccSUP__bot,axiom,
! [B: $tType,A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B] :
( ( complete_Sup_Sup @ A
@ ( image2 @ B @ A
@ ^ [X2: B] : ( bot_bot @ A )
@ A4 ) )
= ( bot_bot @ A ) ) ) ).
% ccSUP_bot
thf(fact_4039_SUP__bot,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B] :
( ( complete_Sup_Sup @ A
@ ( image2 @ B @ A
@ ^ [X2: B] : ( bot_bot @ A )
@ A4 ) )
= ( bot_bot @ A ) ) ) ).
% SUP_bot
thf(fact_4040_SUP__bot__conv_I1_J,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [B3: B > A,A4: set @ B] :
( ( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ B3 @ A4 ) )
= ( bot_bot @ A ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( ( B3 @ X2 )
= ( bot_bot @ A ) ) ) ) ) ) ).
% SUP_bot_conv(1)
thf(fact_4041_SUP__bot__conv_I2_J,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [B3: B > A,A4: set @ B] :
( ( ( bot_bot @ A )
= ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ B3 @ A4 ) ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( ( B3 @ X2 )
= ( bot_bot @ A ) ) ) ) ) ) ).
% SUP_bot_conv(2)
thf(fact_4042_ccSUP__const,axiom,
! [B: $tType,A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,F2: A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Sup_Sup @ A
@ ( image2 @ B @ A
@ ^ [I5: B] : F2
@ A4 ) )
= F2 ) ) ) ).
% ccSUP_const
thf(fact_4043_UN__constant,axiom,
! [B: $tType,A: $tType,A4: set @ B,C2: set @ A] :
( ( ( A4
= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [Y2: B] : C2
@ A4 ) )
= ( bot_bot @ ( set @ A ) ) ) )
& ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [Y2: B] : C2
@ A4 ) )
= C2 ) ) ) ).
% UN_constant
thf(fact_4044_SUP__UN__eq2,axiom,
! [B: $tType,C: $tType,A: $tType,R2: C > ( set @ ( product_prod @ A @ B ) ),S3: set @ C] :
( ( complete_Sup_Sup @ ( A > B > $o )
@ ( image2 @ C @ ( A > B > $o )
@ ^ [I5: C,X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( R2 @ I5 ) )
@ S3 ) )
= ( ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( complete_Sup_Sup @ ( set @ ( product_prod @ A @ B ) ) @ ( image2 @ C @ ( set @ ( product_prod @ A @ B ) ) @ R2 @ S3 ) ) ) ) ) ).
% SUP_UN_eq2
thf(fact_4045_SUP__Sup__eq2,axiom,
! [B: $tType,A: $tType,S3: set @ ( set @ ( product_prod @ A @ B ) )] :
( ( complete_Sup_Sup @ ( A > B > $o )
@ ( image2 @ ( set @ ( product_prod @ A @ B ) ) @ ( A > B > $o )
@ ^ [I5: set @ ( product_prod @ A @ B ),X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ I5 )
@ S3 ) )
= ( ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( complete_Sup_Sup @ ( set @ ( product_prod @ A @ B ) ) @ S3 ) ) ) ) ).
% SUP_Sup_eq2
thf(fact_4046_Sup__SUP__eq2,axiom,
! [B: $tType,A: $tType] :
( ( complete_Sup_Sup @ ( A > B > $o ) )
= ( ^ [S8: set @ ( A > B > $o ),X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( complete_Sup_Sup @ ( set @ ( product_prod @ A @ B ) ) @ ( image2 @ ( ( product_prod @ A @ B ) > $o ) @ ( set @ ( product_prod @ A @ B ) ) @ ( collect @ ( product_prod @ A @ B ) ) @ ( image2 @ ( A > B > $o ) @ ( ( product_prod @ A @ B ) > $o ) @ ( product_case_prod @ A @ B @ $o ) @ S8 ) ) ) ) ) ) ).
% Sup_SUP_eq2
thf(fact_4047_Sup__eqI,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A,X: A] :
( ! [Y4: A] :
( ( member2 @ A @ Y4 @ A4 )
=> ( ord_less_eq @ A @ Y4 @ X ) )
=> ( ! [Y4: A] :
( ! [Z4: A] :
( ( member2 @ A @ Z4 @ A4 )
=> ( ord_less_eq @ A @ Z4 @ Y4 ) )
=> ( ord_less_eq @ A @ X @ Y4 ) )
=> ( ( complete_Sup_Sup @ A @ A4 )
= X ) ) ) ) ).
% Sup_eqI
thf(fact_4048_Sup__mono,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ! [A7: A] :
( ( member2 @ A @ A7 @ A4 )
=> ? [X3: A] :
( ( member2 @ A @ X3 @ B3 )
& ( ord_less_eq @ A @ A7 @ X3 ) ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ A4 ) @ ( complete_Sup_Sup @ A @ B3 ) ) ) ) ).
% Sup_mono
thf(fact_4049_Sup__least,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A,Z: A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ A @ X5 @ Z ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ A4 ) @ Z ) ) ) ).
% Sup_least
thf(fact_4050_Sup__upper,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [X: A,A4: set @ A] :
( ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ A @ X @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ).
% Sup_upper
thf(fact_4051_Sup__le__iff,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A,B2: A] :
( ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ A4 ) @ B2 )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ X2 @ B2 ) ) ) ) ) ).
% Sup_le_iff
thf(fact_4052_Sup__upper2,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [U: A,A4: set @ A,V2: A] :
( ( member2 @ A @ U @ A4 )
=> ( ( ord_less_eq @ A @ V2 @ U )
=> ( ord_less_eq @ A @ V2 @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ).
% Sup_upper2
thf(fact_4053_less__Sup__iff,axiom,
! [A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [A3: A,S3: set @ A] :
( ( ord_less @ A @ A3 @ ( complete_Sup_Sup @ A @ S3 ) )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ S3 )
& ( ord_less @ A @ A3 @ X2 ) ) ) ) ) ).
% less_Sup_iff
thf(fact_4054_empty__Union__conv,axiom,
! [A: $tType,A4: set @ ( set @ A )] :
( ( ( bot_bot @ ( set @ A ) )
= ( complete_Sup_Sup @ ( set @ A ) @ A4 ) )
= ( ! [X2: set @ A] :
( ( member2 @ ( set @ A ) @ X2 @ A4 )
=> ( X2
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% empty_Union_conv
thf(fact_4055_Union__empty__conv,axiom,
! [A: $tType,A4: set @ ( set @ A )] :
( ( ( complete_Sup_Sup @ ( set @ A ) @ A4 )
= ( bot_bot @ ( set @ A ) ) )
= ( ! [X2: set @ A] :
( ( member2 @ ( set @ A ) @ X2 @ A4 )
=> ( X2
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% Union_empty_conv
thf(fact_4056_Union__empty,axiom,
! [A: $tType] :
( ( complete_Sup_Sup @ ( set @ A ) @ ( bot_bot @ ( set @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% Union_empty
thf(fact_4057_Union__subsetI,axiom,
! [A: $tType,A4: set @ ( set @ A ),B3: set @ ( set @ A )] :
( ! [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ A4 )
=> ? [Y3: set @ A] :
( ( member2 @ ( set @ A ) @ Y3 @ B3 )
& ( ord_less_eq @ ( set @ A ) @ X5 @ Y3 ) ) )
=> ( ord_less_eq @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ A4 ) @ ( complete_Sup_Sup @ ( set @ A ) @ B3 ) ) ) ).
% Union_subsetI
thf(fact_4058_Union__upper,axiom,
! [A: $tType,B3: set @ A,A4: set @ ( set @ A )] :
( ( member2 @ ( set @ A ) @ B3 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ B3 @ ( complete_Sup_Sup @ ( set @ A ) @ A4 ) ) ) ).
% Union_upper
thf(fact_4059_Union__least,axiom,
! [A: $tType,A4: set @ ( set @ A ),C5: set @ A] :
( ! [X9: set @ A] :
( ( member2 @ ( set @ A ) @ X9 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ X9 @ C5 ) )
=> ( ord_less_eq @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ A4 ) @ C5 ) ) ).
% Union_least
thf(fact_4060_Union__mono,axiom,
! [A: $tType,A4: set @ ( set @ A ),B3: set @ ( set @ A )] :
( ( ord_less_eq @ ( set @ ( set @ A ) ) @ A4 @ B3 )
=> ( ord_less_eq @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ A4 ) @ ( complete_Sup_Sup @ ( set @ A ) @ B3 ) ) ) ).
% Union_mono
thf(fact_4061_UNION__empty__conv_I2_J,axiom,
! [A: $tType,B: $tType,B3: B > ( set @ A ),A4: set @ B] :
( ( ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ B3 @ A4 ) )
= ( bot_bot @ ( set @ A ) ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( ( B3 @ X2 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% UNION_empty_conv(2)
thf(fact_4062_UNION__empty__conv_I1_J,axiom,
! [A: $tType,B: $tType,B3: B > ( set @ A ),A4: set @ B] :
( ( ( bot_bot @ ( set @ A ) )
= ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ B3 @ A4 ) ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( ( B3 @ X2 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% UNION_empty_conv(1)
thf(fact_4063_UN__empty,axiom,
! [B: $tType,A: $tType,B3: B > ( set @ A )] :
( ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ B3 @ ( bot_bot @ ( set @ B ) ) ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% UN_empty
thf(fact_4064_UN__empty2,axiom,
! [B: $tType,A: $tType,A4: set @ B] :
( ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [X2: B] : ( bot_bot @ ( set @ A ) )
@ A4 ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% UN_empty2
thf(fact_4065_UN__mono,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ A,F2: A > ( set @ B ),G: A > ( set @ B )] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ ( set @ B ) @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ord_less_eq @ ( set @ B ) @ ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ F2 @ A4 ) ) @ ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ G @ B3 ) ) ) ) ) ).
% UN_mono
thf(fact_4066_UN__least,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: A > ( set @ B ),C5: set @ B] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ ( set @ B ) @ ( B3 @ X5 ) @ C5 ) )
=> ( ord_less_eq @ ( set @ B ) @ ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ B3 @ A4 ) ) @ C5 ) ) ).
% UN_least
thf(fact_4067_UN__upper,axiom,
! [B: $tType,A: $tType,A3: A,A4: set @ A,B3: A > ( set @ B )] :
( ( member2 @ A @ A3 @ A4 )
=> ( ord_less_eq @ ( set @ B ) @ ( B3 @ A3 ) @ ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ B3 @ A4 ) ) ) ) ).
% UN_upper
thf(fact_4068_UN__subset__iff,axiom,
! [A: $tType,B: $tType,A4: B > ( set @ A ),I6: set @ B,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ A4 @ I6 ) ) @ B3 )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ I6 )
=> ( ord_less_eq @ ( set @ A ) @ ( A4 @ X2 ) @ B3 ) ) ) ) ).
% UN_subset_iff
thf(fact_4069_le__Sup__iff,axiom,
! [A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [X: A,A4: set @ A] :
( ( ord_less_eq @ A @ X @ ( complete_Sup_Sup @ A @ A4 ) )
= ( ! [Y2: A] :
( ( ord_less @ A @ Y2 @ X )
=> ? [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( ord_less @ A @ Y2 @ X2 ) ) ) ) ) ) ).
% le_Sup_iff
thf(fact_4070_SUP__eq,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,B3: set @ C,F2: B > A,G: C > A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ? [X3: C] :
( ( member2 @ C @ X3 @ B3 )
& ( ord_less_eq @ A @ ( F2 @ I3 ) @ ( G @ X3 ) ) ) )
=> ( ! [J2: C] :
( ( member2 @ C @ J2 @ B3 )
=> ? [X3: B] :
( ( member2 @ B @ X3 @ A4 )
& ( ord_less_eq @ A @ ( G @ J2 ) @ ( F2 @ X3 ) ) ) )
=> ( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
= ( complete_Sup_Sup @ A @ ( image2 @ C @ A @ G @ B3 ) ) ) ) ) ) ).
% SUP_eq
thf(fact_4071_less__eq__Sup,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A,U: A] :
( ! [V3: A] :
( ( member2 @ A @ V3 @ A4 )
=> ( ord_less_eq @ A @ U @ V3 ) )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ord_less_eq @ A @ U @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ).
% less_eq_Sup
thf(fact_4072_Sup__subset__mono,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ A4 ) @ ( complete_Sup_Sup @ A @ B3 ) ) ) ) ).
% Sup_subset_mono
thf(fact_4073_SUP__eq__const,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [I6: set @ B,F2: B > A,X: A] :
( ( I6
!= ( bot_bot @ ( set @ B ) ) )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ I6 )
=> ( ( F2 @ I3 )
= X ) )
=> ( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ I6 ) )
= X ) ) ) ) ).
% SUP_eq_const
thf(fact_4074_Union__disjoint,axiom,
! [A: $tType,C5: set @ ( set @ A ),A4: set @ A] :
( ( ( inf_inf @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ C5 ) @ A4 )
= ( bot_bot @ ( set @ A ) ) )
= ( ! [X2: set @ A] :
( ( member2 @ ( set @ A ) @ X2 @ C5 )
=> ( ( inf_inf @ ( set @ A ) @ X2 @ A4 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% Union_disjoint
thf(fact_4075_Union__Int__subset,axiom,
! [A: $tType,A4: set @ ( set @ A ),B3: set @ ( set @ A )] : ( ord_less_eq @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( inf_inf @ ( set @ ( set @ A ) ) @ A4 @ B3 ) ) @ ( inf_inf @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ A4 ) @ ( complete_Sup_Sup @ ( set @ A ) @ B3 ) ) ) ).
% Union_Int_subset
thf(fact_4076_SUP__upper2,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [I: B,A4: set @ B,U: A,F2: B > A] :
( ( member2 @ B @ I @ A4 )
=> ( ( ord_less_eq @ A @ U @ ( F2 @ I ) )
=> ( ord_less_eq @ A @ U @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ) ).
% SUP_upper2
thf(fact_4077_SUP__le__iff,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: B > A,A4: set @ B,U: A] :
( ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ U )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ X2 ) @ U ) ) ) ) ) ).
% SUP_le_iff
thf(fact_4078_SUP__upper,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [I: B,A4: set @ B,F2: B > A] :
( ( member2 @ B @ I @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ I ) @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ).
% SUP_upper
thf(fact_4079_SUP__mono_H,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: B > A,G: B > A,A4: set @ B] :
( ! [X5: B] : ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( G @ X5 ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ G @ A4 ) ) ) ) ) ).
% SUP_mono'
thf(fact_4080_SUP__least,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,F2: B > A,U: A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ I3 ) @ U ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ U ) ) ) ).
% SUP_least
thf(fact_4081_SUP__mono,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,B3: set @ C,F2: B > A,G: C > A] :
( ! [N3: B] :
( ( member2 @ B @ N3 @ A4 )
=> ? [X3: C] :
( ( member2 @ C @ X3 @ B3 )
& ( ord_less_eq @ A @ ( F2 @ N3 ) @ ( G @ X3 ) ) ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Sup_Sup @ A @ ( image2 @ C @ A @ G @ B3 ) ) ) ) ) ).
% SUP_mono
thf(fact_4082_SUP__eqI,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,F2: B > A,X: A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ I3 ) @ X ) )
=> ( ! [Y4: A] :
( ! [I4: B] :
( ( member2 @ B @ I4 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ I4 ) @ Y4 ) )
=> ( ord_less_eq @ A @ X @ Y4 ) )
=> ( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
= X ) ) ) ) ).
% SUP_eqI
thf(fact_4083_less__SUP__iff,axiom,
! [A: $tType,B: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [A3: A,F2: B > A,A4: set @ B] :
( ( ord_less @ A @ A3 @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) )
= ( ? [X2: B] :
( ( member2 @ B @ X2 @ A4 )
& ( ord_less @ A @ A3 @ ( F2 @ X2 ) ) ) ) ) ) ).
% less_SUP_iff
thf(fact_4084_SUP__lessD,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: B > A,A4: set @ B,Y: A,I: B] :
( ( ord_less @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ Y )
=> ( ( member2 @ B @ I @ A4 )
=> ( ord_less @ A @ ( F2 @ I ) @ Y ) ) ) ) ).
% SUP_lessD
thf(fact_4085_UN__extend__simps_I1_J,axiom,
! [A: $tType,B: $tType,C5: set @ B,A3: A,B3: B > ( set @ A )] :
( ( ( C5
= ( bot_bot @ ( set @ B ) ) )
=> ( ( insert2 @ A @ A3 @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ B3 @ C5 ) ) )
= ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) )
& ( ( C5
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( insert2 @ A @ A3 @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ B3 @ C5 ) ) )
= ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [X2: B] : ( insert2 @ A @ A3 @ ( B3 @ X2 ) )
@ C5 ) ) ) ) ) ).
% UN_extend_simps(1)
thf(fact_4086_le__SUP__iff,axiom,
! [B: $tType,A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [X: A,F2: B > A,A4: set @ B] :
( ( ord_less_eq @ A @ X @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) )
= ( ! [Y2: A] :
( ( ord_less @ A @ Y2 @ X )
=> ? [X2: B] :
( ( member2 @ B @ X2 @ A4 )
& ( ord_less @ A @ Y2 @ ( F2 @ X2 ) ) ) ) ) ) ) ).
% le_SUP_iff
thf(fact_4087_SUP__eq__iff,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [I6: set @ B,C2: A,F2: B > A] :
( ( I6
!= ( bot_bot @ ( set @ B ) ) )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ I6 )
=> ( ord_less_eq @ A @ C2 @ ( F2 @ I3 ) ) )
=> ( ( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ I6 ) )
= C2 )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ I6 )
=> ( ( F2 @ X2 )
= C2 ) ) ) ) ) ) ) ).
% SUP_eq_iff
thf(fact_4088_Sup__inter__less__eq,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A,B3: set @ A] : ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) @ ( inf_inf @ A @ ( complete_Sup_Sup @ A @ A4 ) @ ( complete_Sup_Sup @ A @ B3 ) ) ) ) ).
% Sup_inter_less_eq
thf(fact_4089_SUP__subset__mono,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,B3: set @ B,F2: B > A,G: B > A] :
( ( ord_less_eq @ ( set @ B ) @ A4 @ B3 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ G @ B3 ) ) ) ) ) ) ).
% SUP_subset_mono
thf(fact_4090_SUP__empty,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: B > A] :
( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ ( bot_bot @ ( set @ B ) ) ) )
= ( bot_bot @ A ) ) ) ).
% SUP_empty
thf(fact_4091_SUP__constant,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,C2: A] :
( ( ( A4
= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Sup_Sup @ A
@ ( image2 @ B @ A
@ ^ [Y2: B] : C2
@ A4 ) )
= ( bot_bot @ A ) ) )
& ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Sup_Sup @ A
@ ( image2 @ B @ A
@ ^ [Y2: B] : C2
@ A4 ) )
= C2 ) ) ) ) ).
% SUP_constant
thf(fact_4092_UNION__singleton__eq__range,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B] :
( ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [X2: B] : ( insert2 @ A @ ( F2 @ X2 ) @ ( bot_bot @ ( set @ A ) ) )
@ A4 ) )
= ( image2 @ B @ A @ F2 @ A4 ) ) ).
% UNION_singleton_eq_range
thf(fact_4093_ccpo__Sup__singleton,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [X: A] :
( ( complete_Sup_Sup @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= X ) ) ).
% ccpo_Sup_singleton
thf(fact_4094_card__UNION,axiom,
! [A: $tType,A4: set @ ( set @ A )] :
( ( finite_finite @ ( set @ A ) @ A4 )
=> ( ! [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ A4 )
=> ( finite_finite @ A @ X5 ) )
=> ( ( finite_card @ A @ ( complete_Sup_Sup @ ( set @ A ) @ A4 ) )
= ( nat2
@ ( groups7311177749621191930dd_sum @ ( set @ ( set @ A ) ) @ int
@ ^ [I8: set @ ( set @ A )] : ( times_times @ int @ ( power_power @ int @ ( uminus_uminus @ int @ ( one_one @ int ) ) @ ( plus_plus @ nat @ ( finite_card @ ( set @ A ) @ I8 ) @ ( one_one @ nat ) ) ) @ ( semiring_1_of_nat @ int @ ( finite_card @ A @ ( complete_Inf_Inf @ ( set @ A ) @ I8 ) ) ) )
@ ( collect @ ( set @ ( set @ A ) )
@ ^ [I8: set @ ( set @ A )] :
( ( ord_less_eq @ ( set @ ( set @ A ) ) @ I8 @ A4 )
& ( I8
!= ( bot_bot @ ( set @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ).
% card_UNION
thf(fact_4095_UN__image__subset,axiom,
! [C: $tType,A: $tType,B: $tType,F2: B > ( set @ A ),G: C > ( set @ B ),X: C,X7: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ F2 @ ( G @ X ) ) ) @ X7 )
= ( ord_less_eq @ ( set @ B ) @ ( G @ X )
@ ( collect @ B
@ ^ [X2: B] : ( ord_less_eq @ ( set @ A ) @ ( F2 @ X2 ) @ X7 ) ) ) ) ).
% UN_image_subset
thf(fact_4096_length__remdups__concat,axiom,
! [A: $tType,Xss: list @ ( list @ A )] :
( ( size_size @ ( list @ A ) @ ( remdups @ A @ ( concat @ A @ Xss ) ) )
= ( finite_card @ A @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ ( list @ A ) @ ( set @ A ) @ ( set2 @ A ) @ ( set2 @ ( list @ A ) @ Xss ) ) ) ) ) ).
% length_remdups_concat
thf(fact_4097_remdups__eq__nil__right__iff,axiom,
! [A: $tType,X: list @ A] :
( ( ( nil @ A )
= ( remdups @ A @ X ) )
= ( X
= ( nil @ A ) ) ) ).
% remdups_eq_nil_right_iff
thf(fact_4098_remdups__eq__nil__iff,axiom,
! [A: $tType,X: list @ A] :
( ( ( remdups @ A @ X )
= ( nil @ A ) )
= ( X
= ( nil @ A ) ) ) ).
% remdups_eq_nil_iff
thf(fact_4099_set__remdups,axiom,
! [A: $tType,Xs: list @ A] :
( ( set2 @ A @ ( remdups @ A @ Xs ) )
= ( set2 @ A @ Xs ) ) ).
% set_remdups
thf(fact_4100_length__remdups__eq,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( size_size @ ( list @ A ) @ ( remdups @ A @ Xs ) )
= ( size_size @ ( list @ A ) @ Xs ) )
= ( ( remdups @ A @ Xs )
= Xs ) ) ).
% length_remdups_eq
thf(fact_4101_remdups__id__iff__distinct,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( remdups @ A @ Xs )
= Xs )
= ( distinct @ A @ Xs ) ) ).
% remdups_id_iff_distinct
thf(fact_4102_distinct__remdups,axiom,
! [A: $tType,Xs: list @ A] : ( distinct @ A @ ( remdups @ A @ Xs ) ) ).
% distinct_remdups
thf(fact_4103_Inf__eq__bot__iff,axiom,
! [A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [A4: set @ A] :
( ( ( complete_Inf_Inf @ A @ A4 )
= ( bot_bot @ A ) )
= ( ! [X2: A] :
( ( ord_less @ A @ ( bot_bot @ A ) @ X2 )
=> ? [Y2: A] :
( ( member2 @ A @ Y2 @ A4 )
& ( ord_less @ A @ Y2 @ X2 ) ) ) ) ) ) ).
% Inf_eq_bot_iff
thf(fact_4104_Inf__atLeastAtMost,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( complete_Inf_Inf @ A @ ( set_or1337092689740270186AtMost @ A @ X @ Y ) )
= X ) ) ) ).
% Inf_atLeastAtMost
thf(fact_4105_cInf__atLeastAtMost,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ Y @ X )
=> ( ( complete_Inf_Inf @ A @ ( set_or1337092689740270186AtMost @ A @ Y @ X ) )
= Y ) ) ) ).
% cInf_atLeastAtMost
thf(fact_4106_cInf__singleton,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X: A] :
( ( complete_Inf_Inf @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= X ) ) ).
% cInf_singleton
thf(fact_4107_Inf__atLeastLessThan,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( ( complete_Inf_Inf @ A @ ( set_or7035219750837199246ssThan @ A @ X @ Y ) )
= X ) ) ) ).
% Inf_atLeastLessThan
thf(fact_4108_cInf__atLeastLessThan,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [Y: A,X: A] :
( ( ord_less @ A @ Y @ X )
=> ( ( complete_Inf_Inf @ A @ ( set_or7035219750837199246ssThan @ A @ Y @ X ) )
= Y ) ) ) ).
% cInf_atLeastLessThan
thf(fact_4109_Inf__atMost,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [X: A] :
( ( complete_Inf_Inf @ A @ ( set_ord_atMost @ A @ X ) )
= ( bot_bot @ A ) ) ) ).
% Inf_atMost
thf(fact_4110_length__remdups__leq,axiom,
! [A: $tType,Xs: list @ A] : ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ ( remdups @ A @ Xs ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ).
% length_remdups_leq
thf(fact_4111_cINF__const,axiom,
! [B: $tType,A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,C2: A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Inf_Inf @ A
@ ( image2 @ B @ A
@ ^ [X2: B] : C2
@ A4 ) )
= C2 ) ) ) ).
% cINF_const
thf(fact_4112_INF__const,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,F2: A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Inf_Inf @ A
@ ( image2 @ B @ A
@ ^ [I5: B] : F2
@ A4 ) )
= F2 ) ) ) ).
% INF_const
thf(fact_4113_ccINF__const,axiom,
! [B: $tType,A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,F2: A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Inf_Inf @ A
@ ( image2 @ B @ A
@ ^ [I5: B] : F2
@ A4 ) )
= F2 ) ) ) ).
% ccINF_const
thf(fact_4114_INF__eq__bot__iff,axiom,
! [B: $tType,A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [F2: B > A,A4: set @ B] :
( ( ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
= ( bot_bot @ A ) )
= ( ! [X2: A] :
( ( ord_less @ A @ ( bot_bot @ A ) @ X2 )
=> ? [Y2: B] :
( ( member2 @ B @ Y2 @ A4 )
& ( ord_less @ A @ ( F2 @ Y2 ) @ X2 ) ) ) ) ) ) ).
% INF_eq_bot_iff
thf(fact_4115_remdups_Osimps_I1_J,axiom,
! [A: $tType] :
( ( remdups @ A @ ( nil @ A ) )
= ( nil @ A ) ) ).
% remdups.simps(1)
thf(fact_4116_Inter__subset,axiom,
! [A: $tType,A4: set @ ( set @ A ),B3: set @ A] :
( ! [X9: set @ A] :
( ( member2 @ ( set @ A ) @ X9 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ X9 @ B3 ) )
=> ( ( A4
!= ( bot_bot @ ( set @ ( set @ A ) ) ) )
=> ( ord_less_eq @ ( set @ A ) @ ( complete_Inf_Inf @ ( set @ A ) @ A4 ) @ B3 ) ) ) ).
% Inter_subset
thf(fact_4117_Inter__greatest,axiom,
! [A: $tType,A4: set @ ( set @ A ),C5: set @ A] :
( ! [X9: set @ A] :
( ( member2 @ ( set @ A ) @ X9 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ C5 @ X9 ) )
=> ( ord_less_eq @ ( set @ A ) @ C5 @ ( complete_Inf_Inf @ ( set @ A ) @ A4 ) ) ) ).
% Inter_greatest
thf(fact_4118_Inter__lower,axiom,
! [A: $tType,B3: set @ A,A4: set @ ( set @ A )] :
( ( member2 @ ( set @ A ) @ B3 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ ( complete_Inf_Inf @ ( set @ A ) @ A4 ) @ B3 ) ) ).
% Inter_lower
thf(fact_4119_Inf__eqI,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A,X: A] :
( ! [I3: A] :
( ( member2 @ A @ I3 @ A4 )
=> ( ord_less_eq @ A @ X @ I3 ) )
=> ( ! [Y4: A] :
( ! [I4: A] :
( ( member2 @ A @ I4 @ A4 )
=> ( ord_less_eq @ A @ Y4 @ I4 ) )
=> ( ord_less_eq @ A @ Y4 @ X ) )
=> ( ( complete_Inf_Inf @ A @ A4 )
= X ) ) ) ) ).
% Inf_eqI
thf(fact_4120_Inf__mono,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ! [B5: A] :
( ( member2 @ A @ B5 @ B3 )
=> ? [X3: A] :
( ( member2 @ A @ X3 @ A4 )
& ( ord_less_eq @ A @ X3 @ B5 ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ ( complete_Inf_Inf @ A @ B3 ) ) ) ) ).
% Inf_mono
thf(fact_4121_Inf__lower,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [X: A,A4: set @ A] :
( ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ X ) ) ) ).
% Inf_lower
thf(fact_4122_Inf__lower2,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [U: A,A4: set @ A,V2: A] :
( ( member2 @ A @ U @ A4 )
=> ( ( ord_less_eq @ A @ U @ V2 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ V2 ) ) ) ) ).
% Inf_lower2
thf(fact_4123_le__Inf__iff,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [B2: A,A4: set @ A] :
( ( ord_less_eq @ A @ B2 @ ( complete_Inf_Inf @ A @ A4 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ B2 @ X2 ) ) ) ) ) ).
% le_Inf_iff
thf(fact_4124_Inf__greatest,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A,Z: A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ A @ Z @ X5 ) )
=> ( ord_less_eq @ A @ Z @ ( complete_Inf_Inf @ A @ A4 ) ) ) ) ).
% Inf_greatest
thf(fact_4125_Inf__less__iff,axiom,
! [A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [S3: set @ A,A3: A] :
( ( ord_less @ A @ ( complete_Inf_Inf @ A @ S3 ) @ A3 )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ S3 )
& ( ord_less @ A @ X2 @ A3 ) ) ) ) ) ).
% Inf_less_iff
thf(fact_4126_cInf__eq__minimum,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [Z: A,X7: set @ A] :
( ( member2 @ A @ Z @ X7 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ( ord_less_eq @ A @ Z @ X5 ) )
=> ( ( complete_Inf_Inf @ A @ X7 )
= Z ) ) ) ) ).
% cInf_eq_minimum
thf(fact_4127_cInf__eq,axiom,
! [A: $tType] :
( ( ( condit1219197933456340205attice @ A )
& ( no_top @ A ) )
=> ! [X7: set @ A,A3: A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ( ord_less_eq @ A @ A3 @ X5 ) )
=> ( ! [Y4: A] :
( ! [X3: A] :
( ( member2 @ A @ X3 @ X7 )
=> ( ord_less_eq @ A @ Y4 @ X3 ) )
=> ( ord_less_eq @ A @ Y4 @ A3 ) )
=> ( ( complete_Inf_Inf @ A @ X7 )
= A3 ) ) ) ) ).
% cInf_eq
thf(fact_4128_distinct__remdups__id,axiom,
! [A: $tType,Xs: list @ A] :
( ( distinct @ A @ Xs )
=> ( ( remdups @ A @ Xs )
= Xs ) ) ).
% distinct_remdups_id
thf(fact_4129_remdups__remdups,axiom,
! [A: $tType,Xs: list @ A] :
( ( remdups @ A @ ( remdups @ A @ Xs ) )
= ( remdups @ A @ Xs ) ) ).
% remdups_remdups
thf(fact_4130_insert__remdups,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( insert @ A @ X @ ( remdups @ A @ Xs ) )
= ( remdups @ A @ ( insert @ A @ X @ Xs ) ) ) ).
% insert_remdups
thf(fact_4131_Inf__le__iff,axiom,
! [A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [A4: set @ A,X: A] :
( ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ X )
= ( ! [Y2: A] :
( ( ord_less @ A @ X @ Y2 )
=> ? [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( ord_less @ A @ X2 @ Y2 ) ) ) ) ) ) ).
% Inf_le_iff
thf(fact_4132_INF__eq,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,B3: set @ C,G: C > A,F2: B > A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ? [X3: C] :
( ( member2 @ C @ X3 @ B3 )
& ( ord_less_eq @ A @ ( G @ X3 ) @ ( F2 @ I3 ) ) ) )
=> ( ! [J2: C] :
( ( member2 @ C @ J2 @ B3 )
=> ? [X3: B] :
( ( member2 @ B @ X3 @ A4 )
& ( ord_less_eq @ A @ ( F2 @ X3 ) @ ( G @ J2 ) ) ) )
=> ( ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
= ( complete_Inf_Inf @ A @ ( image2 @ C @ A @ G @ B3 ) ) ) ) ) ) ).
% INF_eq
thf(fact_4133_cInf__eq__non__empty,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A,A3: A] :
( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ( ord_less_eq @ A @ A3 @ X5 ) )
=> ( ! [Y4: A] :
( ! [X3: A] :
( ( member2 @ A @ X3 @ X7 )
=> ( ord_less_eq @ A @ Y4 @ X3 ) )
=> ( ord_less_eq @ A @ Y4 @ A3 ) )
=> ( ( complete_Inf_Inf @ A @ X7 )
= A3 ) ) ) ) ) ).
% cInf_eq_non_empty
thf(fact_4134_cInf__greatest,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A,Z: A] :
( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ( ord_less_eq @ A @ Z @ X5 ) )
=> ( ord_less_eq @ A @ Z @ ( complete_Inf_Inf @ A @ X7 ) ) ) ) ) ).
% cInf_greatest
thf(fact_4135_Inf__less__eq,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A,U: A] :
( ! [V3: A] :
( ( member2 @ A @ V3 @ A4 )
=> ( ord_less_eq @ A @ V3 @ U ) )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ U ) ) ) ) ).
% Inf_less_eq
thf(fact_4136_cInf__le__finite,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A,X: A] :
( ( finite_finite @ A @ X7 )
=> ( ( member2 @ A @ X @ X7 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ X7 ) @ X ) ) ) ) ).
% cInf_le_finite
thf(fact_4137_Inf__superset__mono,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ ( complete_Inf_Inf @ A @ B3 ) ) ) ) ).
% Inf_superset_mono
thf(fact_4138_cInf__lessD,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [X7: set @ A,Z: A] :
( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less @ A @ ( complete_Inf_Inf @ A @ X7 ) @ Z )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ X7 )
& ( ord_less @ A @ X5 @ Z ) ) ) ) ) ).
% cInf_lessD
thf(fact_4139_finite__imp__less__Inf,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [X7: set @ A,X: A,A3: A] :
( ( finite_finite @ A @ X7 )
=> ( ( member2 @ A @ X @ X7 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ( ord_less @ A @ A3 @ X5 ) )
=> ( ord_less @ A @ A3 @ ( complete_Inf_Inf @ A @ X7 ) ) ) ) ) ) ).
% finite_imp_less_Inf
thf(fact_4140_INF__eq__const,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [I6: set @ B,F2: B > A,X: A] :
( ( I6
!= ( bot_bot @ ( set @ B ) ) )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ I6 )
=> ( ( F2 @ I3 )
= X ) )
=> ( ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ I6 ) )
= X ) ) ) ) ).
% INF_eq_const
thf(fact_4141_Inter__anti__mono,axiom,
! [A: $tType,B3: set @ ( set @ A ),A4: set @ ( set @ A )] :
( ( ord_less_eq @ ( set @ ( set @ A ) ) @ B3 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ ( complete_Inf_Inf @ ( set @ A ) @ A4 ) @ ( complete_Inf_Inf @ ( set @ A ) @ B3 ) ) ) ).
% Inter_anti_mono
thf(fact_4142_INF__eqI,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,X: A,F2: B > A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ord_less_eq @ A @ X @ ( F2 @ I3 ) ) )
=> ( ! [Y4: A] :
( ! [I4: B] :
( ( member2 @ B @ I4 @ A4 )
=> ( ord_less_eq @ A @ Y4 @ ( F2 @ I4 ) ) )
=> ( ord_less_eq @ A @ Y4 @ X ) )
=> ( ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
= X ) ) ) ) ).
% INF_eqI
thf(fact_4143_INF__mono,axiom,
! [C: $tType,A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [B3: set @ B,A4: set @ C,F2: C > A,G: B > A] :
( ! [M3: B] :
( ( member2 @ B @ M3 @ B3 )
=> ? [X3: C] :
( ( member2 @ C @ X3 @ A4 )
& ( ord_less_eq @ A @ ( F2 @ X3 ) @ ( G @ M3 ) ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ C @ A @ F2 @ A4 ) ) @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ G @ B3 ) ) ) ) ) ).
% INF_mono
thf(fact_4144_INF__lower,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [I: B,A4: set @ B,F2: B > A] :
( ( member2 @ B @ I @ A4 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( F2 @ I ) ) ) ) ).
% INF_lower
thf(fact_4145_INF__mono_H,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: B > A,G: B > A,A4: set @ B] :
( ! [X5: B] : ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( G @ X5 ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ G @ A4 ) ) ) ) ) ).
% INF_mono'
thf(fact_4146_INF__lower2,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [I: B,A4: set @ B,F2: B > A,U: A] :
( ( member2 @ B @ I @ A4 )
=> ( ( ord_less_eq @ A @ ( F2 @ I ) @ U )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ U ) ) ) ) ).
% INF_lower2
thf(fact_4147_le__INF__iff,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [U: A,F2: B > A,A4: set @ B] :
( ( ord_less_eq @ A @ U @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( ord_less_eq @ A @ U @ ( F2 @ X2 ) ) ) ) ) ) ).
% le_INF_iff
thf(fact_4148_INF__greatest,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,U: A,F2: B > A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ord_less_eq @ A @ U @ ( F2 @ I3 ) ) )
=> ( ord_less_eq @ A @ U @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ).
% INF_greatest
thf(fact_4149_less__INF__D,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [Y: A,F2: B > A,A4: set @ B,I: B] :
( ( ord_less @ A @ Y @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) )
=> ( ( member2 @ B @ I @ A4 )
=> ( ord_less @ A @ Y @ ( F2 @ I ) ) ) ) ) ).
% less_INF_D
thf(fact_4150_INF__less__iff,axiom,
! [A: $tType,B: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [F2: B > A,A4: set @ B,A3: A] :
( ( ord_less @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ A3 )
= ( ? [X2: B] :
( ( member2 @ B @ X2 @ A4 )
& ( ord_less @ A @ ( F2 @ X2 ) @ A3 ) ) ) ) ) ).
% INF_less_iff
thf(fact_4151_INT__lower,axiom,
! [B: $tType,A: $tType,A3: A,A4: set @ A,B3: A > ( set @ B )] :
( ( member2 @ A @ A3 @ A4 )
=> ( ord_less_eq @ ( set @ B ) @ ( complete_Inf_Inf @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ B3 @ A4 ) ) @ ( B3 @ A3 ) ) ) ).
% INT_lower
thf(fact_4152_INT__greatest,axiom,
! [B: $tType,A: $tType,A4: set @ A,C5: set @ B,B3: A > ( set @ B )] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ ( set @ B ) @ C5 @ ( B3 @ X5 ) ) )
=> ( ord_less_eq @ ( set @ B ) @ C5 @ ( complete_Inf_Inf @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ B3 @ A4 ) ) ) ) ).
% INT_greatest
thf(fact_4153_INT__anti__mono,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ A,F2: A > ( set @ B ),G: A > ( set @ B )] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ ( set @ B ) @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ord_less_eq @ ( set @ B ) @ ( complete_Inf_Inf @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ F2 @ B3 ) ) @ ( complete_Inf_Inf @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ G @ A4 ) ) ) ) ) ).
% INT_anti_mono
thf(fact_4154_INT__subset__iff,axiom,
! [A: $tType,B: $tType,B3: set @ A,A4: B > ( set @ A ),I6: set @ B] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ ( complete_Inf_Inf @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ A4 @ I6 ) ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ I6 )
=> ( ord_less_eq @ ( set @ A ) @ B3 @ ( A4 @ X2 ) ) ) ) ) ).
% INT_subset_iff
thf(fact_4155_Int__Inter__eq_I2_J,axiom,
! [A: $tType,B10: set @ ( set @ A ),A4: set @ A] :
( ( ( B10
= ( bot_bot @ ( set @ ( set @ A ) ) ) )
=> ( ( inf_inf @ ( set @ A ) @ ( complete_Inf_Inf @ ( set @ A ) @ B10 ) @ A4 )
= A4 ) )
& ( ( B10
!= ( bot_bot @ ( set @ ( set @ A ) ) ) )
=> ( ( inf_inf @ ( set @ A ) @ ( complete_Inf_Inf @ ( set @ A ) @ B10 ) @ A4 )
= ( complete_Inf_Inf @ ( set @ A )
@ ( image2 @ ( set @ A ) @ ( set @ A )
@ ^ [B6: set @ A] : ( inf_inf @ ( set @ A ) @ B6 @ A4 )
@ B10 ) ) ) ) ) ).
% Int_Inter_eq(2)
thf(fact_4156_Int__Inter__eq_I1_J,axiom,
! [A: $tType,B10: set @ ( set @ A ),A4: set @ A] :
( ( ( B10
= ( bot_bot @ ( set @ ( set @ A ) ) ) )
=> ( ( inf_inf @ ( set @ A ) @ A4 @ ( complete_Inf_Inf @ ( set @ A ) @ B10 ) )
= A4 ) )
& ( ( B10
!= ( bot_bot @ ( set @ ( set @ A ) ) ) )
=> ( ( inf_inf @ ( set @ A ) @ A4 @ ( complete_Inf_Inf @ ( set @ A ) @ B10 ) )
= ( complete_Inf_Inf @ ( set @ A ) @ ( image2 @ ( set @ A ) @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ A4 ) @ B10 ) ) ) ) ) ).
% Int_Inter_eq(1)
thf(fact_4157_remove1__remdups,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( distinct @ A @ Xs )
=> ( ( remove1 @ A @ X @ ( remdups @ A @ Xs ) )
= ( remdups @ A @ ( remove1 @ A @ X @ Xs ) ) ) ) ).
% remove1_remdups
thf(fact_4158_INF__le__iff,axiom,
! [B: $tType,A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [F2: B > A,A4: set @ B,X: A] :
( ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ X )
= ( ! [Y2: A] :
( ( ord_less @ A @ X @ Y2 )
=> ? [X2: B] :
( ( member2 @ B @ X2 @ A4 )
& ( ord_less @ A @ ( F2 @ X2 ) @ Y2 ) ) ) ) ) ) ).
% INF_le_iff
thf(fact_4159_cINF__greatest,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,M: A,F2: B > A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ M @ ( F2 @ X5 ) ) )
=> ( ord_less_eq @ A @ M @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ) ).
% cINF_greatest
thf(fact_4160_INF__eq__iff,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [I6: set @ B,F2: B > A,C2: A] :
( ( I6
!= ( bot_bot @ ( set @ B ) ) )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ I6 )
=> ( ord_less_eq @ A @ ( F2 @ I3 ) @ C2 ) )
=> ( ( ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ I6 ) )
= C2 )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ I6 )
=> ( ( F2 @ X2 )
= C2 ) ) ) ) ) ) ) ).
% INF_eq_iff
thf(fact_4161_finite__less__Inf__iff,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [X7: set @ A,A3: A] :
( ( finite_finite @ A @ X7 )
=> ( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less @ A @ A3 @ ( complete_Inf_Inf @ A @ X7 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ X7 )
=> ( ord_less @ A @ A3 @ X2 ) ) ) ) ) ) ) ).
% finite_less_Inf_iff
thf(fact_4162_Inf__le__Sup,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ).
% Inf_le_Sup
thf(fact_4163_cInf__abs__ge,axiom,
! [A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( linordered_idom @ A ) )
=> ! [S3: set @ A,A3: A] :
( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ S3 )
=> ( ord_less_eq @ A @ ( abs_abs @ A @ X5 ) @ A3 ) )
=> ( ord_less_eq @ A @ ( abs_abs @ A @ ( complete_Inf_Inf @ A @ S3 ) ) @ A3 ) ) ) ) ).
% cInf_abs_ge
thf(fact_4164_finite__Inf__in,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ( member2 @ A @ Y4 @ A4 )
=> ( member2 @ A @ ( inf_inf @ A @ X5 @ Y4 ) @ A4 ) ) )
=> ( member2 @ A @ ( complete_Inf_Inf @ A @ A4 ) @ A4 ) ) ) ) ) ).
% finite_Inf_in
thf(fact_4165_INF__superset__mono,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [B3: set @ B,A4: set @ B,F2: B > A,G: B > A] :
( ( ord_less_eq @ ( set @ B ) @ B3 @ A4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ B3 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ G @ B3 ) ) ) ) ) ) ).
% INF_superset_mono
thf(fact_4166_INF__inf__const1,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [I6: set @ B,X: A,F2: B > A] :
( ( I6
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Inf_Inf @ A
@ ( image2 @ B @ A
@ ^ [I5: B] : ( inf_inf @ A @ X @ ( F2 @ I5 ) )
@ I6 ) )
= ( inf_inf @ A @ X @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ I6 ) ) ) ) ) ) ).
% INF_inf_const1
thf(fact_4167_INF__inf__const2,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [I6: set @ B,F2: B > A,X: A] :
( ( I6
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Inf_Inf @ A
@ ( image2 @ B @ A
@ ^ [I5: B] : ( inf_inf @ A @ ( F2 @ I5 ) @ X )
@ I6 ) )
= ( inf_inf @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ I6 ) ) @ X ) ) ) ) ).
% INF_inf_const2
thf(fact_4168_INT__extend__simps_I1_J,axiom,
! [B: $tType,A: $tType,C5: set @ A,A4: A > ( set @ B ),B3: set @ B] :
( ( ( C5
= ( bot_bot @ ( set @ A ) ) )
=> ( ( inf_inf @ ( set @ B ) @ ( complete_Inf_Inf @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ A4 @ C5 ) ) @ B3 )
= B3 ) )
& ( ( C5
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( inf_inf @ ( set @ B ) @ ( complete_Inf_Inf @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ A4 @ C5 ) ) @ B3 )
= ( complete_Inf_Inf @ ( set @ B )
@ ( image2 @ A @ ( set @ B )
@ ^ [X2: A] : ( inf_inf @ ( set @ B ) @ ( A4 @ X2 ) @ B3 )
@ C5 ) ) ) ) ) ).
% INT_extend_simps(1)
thf(fact_4169_INT__extend__simps_I2_J,axiom,
! [C: $tType,D: $tType,C5: set @ D,A4: set @ C,B3: D > ( set @ C )] :
( ( ( C5
= ( bot_bot @ ( set @ D ) ) )
=> ( ( inf_inf @ ( set @ C ) @ A4 @ ( complete_Inf_Inf @ ( set @ C ) @ ( image2 @ D @ ( set @ C ) @ B3 @ C5 ) ) )
= A4 ) )
& ( ( C5
!= ( bot_bot @ ( set @ D ) ) )
=> ( ( inf_inf @ ( set @ C ) @ A4 @ ( complete_Inf_Inf @ ( set @ C ) @ ( image2 @ D @ ( set @ C ) @ B3 @ C5 ) ) )
= ( complete_Inf_Inf @ ( set @ C )
@ ( image2 @ D @ ( set @ C )
@ ^ [X2: D] : ( inf_inf @ ( set @ C ) @ A4 @ ( B3 @ X2 ) )
@ C5 ) ) ) ) ) ).
% INT_extend_simps(2)
thf(fact_4170_length__remdups__card__conv,axiom,
! [A: $tType,Xs: list @ A] :
( ( size_size @ ( list @ A ) @ ( remdups @ A @ Xs ) )
= ( finite_card @ A @ ( set2 @ A @ Xs ) ) ) ).
% length_remdups_card_conv
thf(fact_4171_INF__le__SUP,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,F2: B > A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ).
% INF_le_SUP
thf(fact_4172_cInf__asclose,axiom,
! [A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( linordered_idom @ A ) )
=> ! [S3: set @ A,L: A,E3: A] :
( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ S3 )
=> ( ord_less_eq @ A @ ( abs_abs @ A @ ( minus_minus @ A @ X5 @ L ) ) @ E3 ) )
=> ( ord_less_eq @ A @ ( abs_abs @ A @ ( minus_minus @ A @ ( complete_Inf_Inf @ A @ S3 ) @ L ) ) @ E3 ) ) ) ) ).
% cInf_asclose
thf(fact_4173_INT__extend__simps_I4_J,axiom,
! [G3: $tType,H4: $tType,C5: set @ H4,A4: set @ G3,B3: H4 > ( set @ G3 )] :
( ( ( C5
= ( bot_bot @ ( set @ H4 ) ) )
=> ( ( minus_minus @ ( set @ G3 ) @ A4 @ ( complete_Sup_Sup @ ( set @ G3 ) @ ( image2 @ H4 @ ( set @ G3 ) @ B3 @ C5 ) ) )
= A4 ) )
& ( ( C5
!= ( bot_bot @ ( set @ H4 ) ) )
=> ( ( minus_minus @ ( set @ G3 ) @ A4 @ ( complete_Sup_Sup @ ( set @ G3 ) @ ( image2 @ H4 @ ( set @ G3 ) @ B3 @ C5 ) ) )
= ( complete_Inf_Inf @ ( set @ G3 )
@ ( image2 @ H4 @ ( set @ G3 )
@ ^ [X2: H4] : ( minus_minus @ ( set @ G3 ) @ A4 @ ( B3 @ X2 ) )
@ C5 ) ) ) ) ) ).
% INT_extend_simps(4)
thf(fact_4174_conj__subset__def,axiom,
! [A: $tType,A4: set @ A,P2: A > $o,Q: A > $o] :
( ( ord_less_eq @ ( set @ A ) @ A4
@ ( collect @ A
@ ^ [X2: A] :
( ( P2 @ X2 )
& ( Q @ X2 ) ) ) )
= ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( collect @ A @ P2 ) )
& ( ord_less_eq @ ( set @ A ) @ A4 @ ( collect @ A @ Q ) ) ) ) ).
% conj_subset_def
thf(fact_4175_INF__nat__binary,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: A,B3: A] :
( ( inf_inf @ A @ A4
@ ( complete_Inf_Inf @ A
@ ( image2 @ nat @ A
@ ^ [X2: nat] : B3
@ ( collect @ nat @ ( ord_less @ nat @ ( zero_zero @ nat ) ) ) ) ) )
= ( inf_inf @ A @ A4 @ B3 ) ) ) ).
% INF_nat_binary
thf(fact_4176_finite__mono__strict__prefix__implies__finite__fixpoint,axiom,
! [A: $tType,F2: nat > ( set @ A ),S3: set @ A] :
( ! [I3: nat] : ( ord_less_eq @ ( set @ A ) @ ( F2 @ I3 ) @ S3 )
=> ( ( finite_finite @ A @ S3 )
=> ( ? [N8: nat] :
( ! [N3: nat] :
( ( ord_less_eq @ nat @ N3 @ N8 )
=> ! [M3: nat] :
( ( ord_less_eq @ nat @ M3 @ N8 )
=> ( ( ord_less @ nat @ M3 @ N3 )
=> ( ord_less @ ( set @ A ) @ ( F2 @ M3 ) @ ( F2 @ N3 ) ) ) ) )
& ! [N3: nat] :
( ( ord_less_eq @ nat @ N8 @ N3 )
=> ( ( F2 @ N8 )
= ( F2 @ N3 ) ) ) )
=> ( ( F2 @ ( finite_card @ A @ S3 ) )
= ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ F2 @ ( top_top @ ( set @ nat ) ) ) ) ) ) ) ) ).
% finite_mono_strict_prefix_implies_finite_fixpoint
thf(fact_4177_listset_Osimps_I1_J,axiom,
! [A: $tType] :
( ( listset @ A @ ( nil @ ( set @ A ) ) )
= ( insert2 @ ( list @ A ) @ ( nil @ A ) @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) ) ).
% listset.simps(1)
thf(fact_4178_lex__take__index,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( lex @ A @ R2 ) )
=> ~ ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ord_less @ nat @ I3 @ ( size_size @ ( list @ A ) @ Ys ) )
=> ( ( ( take @ A @ I3 @ Xs )
= ( take @ A @ I3 @ Ys ) )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ ( nth @ A @ Xs @ I3 ) @ ( nth @ A @ Ys @ I3 ) ) @ R2 ) ) ) ) ) ).
% lex_take_index
thf(fact_4179_inf__top__left,axiom,
! [A: $tType] :
( ( bounde4346867609351753570nf_top @ A )
=> ! [X: A] :
( ( inf_inf @ A @ ( top_top @ A ) @ X )
= X ) ) ).
% inf_top_left
thf(fact_4180_inf__top__right,axiom,
! [A: $tType] :
( ( bounde4346867609351753570nf_top @ A )
=> ! [X: A] :
( ( inf_inf @ A @ X @ ( top_top @ A ) )
= X ) ) ).
% inf_top_right
thf(fact_4181_inf__eq__top__iff,axiom,
! [A: $tType] :
( ( bounde4346867609351753570nf_top @ A )
=> ! [X: A,Y: A] :
( ( ( inf_inf @ A @ X @ Y )
= ( top_top @ A ) )
= ( ( X
= ( top_top @ A ) )
& ( Y
= ( top_top @ A ) ) ) ) ) ).
% inf_eq_top_iff
thf(fact_4182_top__eq__inf__iff,axiom,
! [A: $tType] :
( ( bounde4346867609351753570nf_top @ A )
=> ! [X: A,Y: A] :
( ( ( top_top @ A )
= ( inf_inf @ A @ X @ Y ) )
= ( ( X
= ( top_top @ A ) )
& ( Y
= ( top_top @ A ) ) ) ) ) ).
% top_eq_inf_iff
thf(fact_4183_inf__top_Oeq__neutr__iff,axiom,
! [A: $tType] :
( ( bounde4346867609351753570nf_top @ A )
=> ! [A3: A,B2: A] :
( ( ( inf_inf @ A @ A3 @ B2 )
= ( top_top @ A ) )
= ( ( A3
= ( top_top @ A ) )
& ( B2
= ( top_top @ A ) ) ) ) ) ).
% inf_top.eq_neutr_iff
thf(fact_4184_inf__top_Oleft__neutral,axiom,
! [A: $tType] :
( ( bounde4346867609351753570nf_top @ A )
=> ! [A3: A] :
( ( inf_inf @ A @ ( top_top @ A ) @ A3 )
= A3 ) ) ).
% inf_top.left_neutral
thf(fact_4185_inf__top_Oneutr__eq__iff,axiom,
! [A: $tType] :
( ( bounde4346867609351753570nf_top @ A )
=> ! [A3: A,B2: A] :
( ( ( top_top @ A )
= ( inf_inf @ A @ A3 @ B2 ) )
= ( ( A3
= ( top_top @ A ) )
& ( B2
= ( top_top @ A ) ) ) ) ) ).
% inf_top.neutr_eq_iff
thf(fact_4186_inf__top_Oright__neutral,axiom,
! [A: $tType] :
( ( bounde4346867609351753570nf_top @ A )
=> ! [A3: A] :
( ( inf_inf @ A @ A3 @ ( top_top @ A ) )
= A3 ) ) ).
% inf_top.right_neutral
thf(fact_4187_max__top,axiom,
! [A: $tType] :
( ( order_top @ A )
=> ! [X: A] :
( ( ord_max @ A @ ( top_top @ A ) @ X )
= ( top_top @ A ) ) ) ).
% max_top
thf(fact_4188_max__top2,axiom,
! [A: $tType] :
( ( order_top @ A )
=> ! [X: A] :
( ( ord_max @ A @ X @ ( top_top @ A ) )
= ( top_top @ A ) ) ) ).
% max_top2
thf(fact_4189_Collect__const,axiom,
! [A: $tType,P2: $o] :
( ( P2
=> ( ( collect @ A
@ ^ [S7: A] : P2 )
= ( top_top @ ( set @ A ) ) ) )
& ( ~ P2
=> ( ( collect @ A
@ ^ [S7: A] : P2 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% Collect_const
thf(fact_4190_range__add,axiom,
! [A: $tType] :
( ( group_add @ A )
=> ! [A3: A] :
( ( image2 @ A @ A @ ( plus_plus @ A @ A3 ) @ ( top_top @ ( set @ A ) ) )
= ( top_top @ ( set @ A ) ) ) ) ).
% range_add
thf(fact_4191_surj__plus,axiom,
! [A: $tType] :
( ( ab_group_add @ A )
=> ! [A3: A] :
( ( image2 @ A @ A @ ( plus_plus @ A @ A3 ) @ ( top_top @ ( set @ A ) ) )
= ( top_top @ ( set @ A ) ) ) ) ).
% surj_plus
thf(fact_4192_Sup__eq__top__iff,axiom,
! [A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [A4: set @ A] :
( ( ( complete_Sup_Sup @ A @ A4 )
= ( top_top @ A ) )
= ( ! [X2: A] :
( ( ord_less @ A @ X2 @ ( top_top @ A ) )
=> ? [Y2: A] :
( ( member2 @ A @ Y2 @ A4 )
& ( ord_less @ A @ X2 @ Y2 ) ) ) ) ) ) ).
% Sup_eq_top_iff
thf(fact_4193_boolean__algebra_Ocompl__one,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ( ( uminus_uminus @ A @ ( top_top @ A ) )
= ( bot_bot @ A ) ) ) ).
% boolean_algebra.compl_one
thf(fact_4194_boolean__algebra_Ocompl__zero,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ( ( uminus_uminus @ A @ ( bot_bot @ A ) )
= ( top_top @ A ) ) ) ).
% boolean_algebra.compl_zero
thf(fact_4195_Inf__UNIV,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ( ( complete_Inf_Inf @ A @ ( top_top @ ( set @ A ) ) )
= ( bot_bot @ A ) ) ) ).
% Inf_UNIV
thf(fact_4196_ccInf__empty,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ( ( complete_Inf_Inf @ A @ ( bot_bot @ ( set @ A ) ) )
= ( top_top @ A ) ) ) ).
% ccInf_empty
thf(fact_4197_Inf__empty,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ( ( complete_Inf_Inf @ A @ ( bot_bot @ ( set @ A ) ) )
= ( top_top @ A ) ) ) ).
% Inf_empty
thf(fact_4198_Diff__UNIV,axiom,
! [A: $tType,A4: set @ A] :
( ( minus_minus @ ( set @ A ) @ A4 @ ( top_top @ ( set @ A ) ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% Diff_UNIV
thf(fact_4199_surj__fn,axiom,
! [A: $tType,F2: A > A,N2: nat] :
( ( ( image2 @ A @ A @ F2 @ ( top_top @ ( set @ A ) ) )
= ( top_top @ ( set @ A ) ) )
=> ( ( image2 @ A @ A @ ( compow @ ( A > A ) @ N2 @ F2 ) @ ( top_top @ ( set @ A ) ) )
= ( top_top @ ( set @ A ) ) ) ) ).
% surj_fn
thf(fact_4200_SUP__eq__top__iff,axiom,
! [B: $tType,A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [F2: B > A,A4: set @ B] :
( ( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
= ( top_top @ A ) )
= ( ! [X2: A] :
( ( ord_less @ A @ X2 @ ( top_top @ A ) )
=> ? [Y2: B] :
( ( member2 @ B @ Y2 @ A4 )
& ( ord_less @ A @ X2 @ ( F2 @ Y2 ) ) ) ) ) ) ) ).
% SUP_eq_top_iff
thf(fact_4201_range__constant,axiom,
! [B: $tType,A: $tType,X: A] :
( ( image2 @ B @ A
@ ^ [Uu3: B] : X
@ ( top_top @ ( set @ B ) ) )
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ).
% range_constant
thf(fact_4202_ccINF__empty,axiom,
! [B: $tType,A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [F2: B > A] :
( ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ ( bot_bot @ ( set @ B ) ) ) )
= ( top_top @ A ) ) ) ).
% ccINF_empty
thf(fact_4203_INT__constant,axiom,
! [B: $tType,A: $tType,A4: set @ B,C2: set @ A] :
( ( ( A4
= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Inf_Inf @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [Y2: B] : C2
@ A4 ) )
= ( top_top @ ( set @ A ) ) ) )
& ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Inf_Inf @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [Y2: B] : C2
@ A4 ) )
= C2 ) ) ) ).
% INT_constant
thf(fact_4204_Inf__atMostLessThan,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [X: A] :
( ( ord_less @ A @ ( top_top @ A ) @ X )
=> ( ( complete_Inf_Inf @ A @ ( set_ord_lessThan @ A @ X ) )
= ( bot_bot @ A ) ) ) ) ).
% Inf_atMostLessThan
thf(fact_4205_INT__simps_I1_J,axiom,
! [A: $tType,B: $tType,C5: set @ A,A4: A > ( set @ B ),B3: set @ B] :
( ( ( C5
= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Inf_Inf @ ( set @ B )
@ ( image2 @ A @ ( set @ B )
@ ^ [X2: A] : ( inf_inf @ ( set @ B ) @ ( A4 @ X2 ) @ B3 )
@ C5 ) )
= ( top_top @ ( set @ B ) ) ) )
& ( ( C5
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Inf_Inf @ ( set @ B )
@ ( image2 @ A @ ( set @ B )
@ ^ [X2: A] : ( inf_inf @ ( set @ B ) @ ( A4 @ X2 ) @ B3 )
@ C5 ) )
= ( inf_inf @ ( set @ B ) @ ( complete_Inf_Inf @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ A4 @ C5 ) ) @ B3 ) ) ) ) ).
% INT_simps(1)
thf(fact_4206_INT__simps_I2_J,axiom,
! [C: $tType,D: $tType,C5: set @ D,A4: set @ C,B3: D > ( set @ C )] :
( ( ( C5
= ( bot_bot @ ( set @ D ) ) )
=> ( ( complete_Inf_Inf @ ( set @ C )
@ ( image2 @ D @ ( set @ C )
@ ^ [X2: D] : ( inf_inf @ ( set @ C ) @ A4 @ ( B3 @ X2 ) )
@ C5 ) )
= ( top_top @ ( set @ C ) ) ) )
& ( ( C5
!= ( bot_bot @ ( set @ D ) ) )
=> ( ( complete_Inf_Inf @ ( set @ C )
@ ( image2 @ D @ ( set @ C )
@ ^ [X2: D] : ( inf_inf @ ( set @ C ) @ A4 @ ( B3 @ X2 ) )
@ C5 ) )
= ( inf_inf @ ( set @ C ) @ A4 @ ( complete_Inf_Inf @ ( set @ C ) @ ( image2 @ D @ ( set @ C ) @ B3 @ C5 ) ) ) ) ) ) ).
% INT_simps(2)
thf(fact_4207_INT__simps_I3_J,axiom,
! [E2: $tType,F: $tType,C5: set @ E2,A4: E2 > ( set @ F ),B3: set @ F] :
( ( ( C5
= ( bot_bot @ ( set @ E2 ) ) )
=> ( ( complete_Inf_Inf @ ( set @ F )
@ ( image2 @ E2 @ ( set @ F )
@ ^ [X2: E2] : ( minus_minus @ ( set @ F ) @ ( A4 @ X2 ) @ B3 )
@ C5 ) )
= ( top_top @ ( set @ F ) ) ) )
& ( ( C5
!= ( bot_bot @ ( set @ E2 ) ) )
=> ( ( complete_Inf_Inf @ ( set @ F )
@ ( image2 @ E2 @ ( set @ F )
@ ^ [X2: E2] : ( minus_minus @ ( set @ F ) @ ( A4 @ X2 ) @ B3 )
@ C5 ) )
= ( minus_minus @ ( set @ F ) @ ( complete_Inf_Inf @ ( set @ F ) @ ( image2 @ E2 @ ( set @ F ) @ A4 @ C5 ) ) @ B3 ) ) ) ) ).
% INT_simps(3)
thf(fact_4208_INT__simps_I4_J,axiom,
! [G3: $tType,H4: $tType,C5: set @ H4,A4: set @ G3,B3: H4 > ( set @ G3 )] :
( ( ( C5
= ( bot_bot @ ( set @ H4 ) ) )
=> ( ( complete_Inf_Inf @ ( set @ G3 )
@ ( image2 @ H4 @ ( set @ G3 )
@ ^ [X2: H4] : ( minus_minus @ ( set @ G3 ) @ A4 @ ( B3 @ X2 ) )
@ C5 ) )
= ( top_top @ ( set @ G3 ) ) ) )
& ( ( C5
!= ( bot_bot @ ( set @ H4 ) ) )
=> ( ( complete_Inf_Inf @ ( set @ G3 )
@ ( image2 @ H4 @ ( set @ G3 )
@ ^ [X2: H4] : ( minus_minus @ ( set @ G3 ) @ A4 @ ( B3 @ X2 ) )
@ C5 ) )
= ( minus_minus @ ( set @ G3 ) @ A4 @ ( complete_Sup_Sup @ ( set @ G3 ) @ ( image2 @ H4 @ ( set @ G3 ) @ B3 @ C5 ) ) ) ) ) ) ).
% INT_simps(4)
thf(fact_4209_atLeastAtMost__eq__UNIV__iff,axiom,
! [A: $tType] :
( ( bounded_lattice @ A )
=> ! [X: A,Y: A] :
( ( ( set_or1337092689740270186AtMost @ A @ X @ Y )
= ( top_top @ ( set @ A ) ) )
= ( ( X
= ( bot_bot @ A ) )
& ( Y
= ( top_top @ A ) ) ) ) ) ).
% atLeastAtMost_eq_UNIV_iff
thf(fact_4210_empty__not__UNIV,axiom,
! [A: $tType] :
( ( bot_bot @ ( set @ A ) )
!= ( top_top @ ( set @ A ) ) ) ).
% empty_not_UNIV
thf(fact_4211_Inf__nat__def1,axiom,
! [K5: set @ nat] :
( ( K5
!= ( bot_bot @ ( set @ nat ) ) )
=> ( member2 @ nat @ ( complete_Inf_Inf @ nat @ K5 ) @ K5 ) ) ).
% Inf_nat_def1
thf(fact_4212_top_Oextremum__strict,axiom,
! [A: $tType] :
( ( order_top @ A )
=> ! [A3: A] :
~ ( ord_less @ A @ ( top_top @ A ) @ A3 ) ) ).
% top.extremum_strict
thf(fact_4213_top_Onot__eq__extremum,axiom,
! [A: $tType] :
( ( order_top @ A )
=> ! [A3: A] :
( ( A3
!= ( top_top @ A ) )
= ( ord_less @ A @ A3 @ ( top_top @ A ) ) ) ) ).
% top.not_eq_extremum
thf(fact_4214_subset__UNIV,axiom,
! [A: $tType,A4: set @ A] : ( ord_less_eq @ ( set @ A ) @ A4 @ ( top_top @ ( set @ A ) ) ) ).
% subset_UNIV
thf(fact_4215_top_Oextremum__uniqueI,axiom,
! [A: $tType] :
( ( order_top @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( top_top @ A ) @ A3 )
=> ( A3
= ( top_top @ A ) ) ) ) ).
% top.extremum_uniqueI
thf(fact_4216_top_Oextremum__unique,axiom,
! [A: $tType] :
( ( order_top @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( top_top @ A ) @ A3 )
= ( A3
= ( top_top @ A ) ) ) ) ).
% top.extremum_unique
thf(fact_4217_top__greatest,axiom,
! [A: $tType] :
( ( order_top @ A )
=> ! [A3: A] : ( ord_less_eq @ A @ A3 @ ( top_top @ A ) ) ) ).
% top_greatest
thf(fact_4218_UNIV__option__conv,axiom,
! [A: $tType] :
( ( top_top @ ( set @ ( option @ A ) ) )
= ( insert2 @ ( option @ A ) @ ( none @ A ) @ ( image2 @ A @ ( option @ A ) @ ( some @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ).
% UNIV_option_conv
thf(fact_4219_finite__fun__UNIVD1,axiom,
! [B: $tType,A: $tType] :
( ( finite_finite @ ( A > B ) @ ( top_top @ ( set @ ( A > B ) ) ) )
=> ( ( ( finite_card @ B @ ( top_top @ ( set @ B ) ) )
!= ( suc @ ( zero_zero @ nat ) ) )
=> ( finite_finite @ A @ ( top_top @ ( set @ A ) ) ) ) ) ).
% finite_fun_UNIVD1
thf(fact_4220_range__subsetD,axiom,
! [B: $tType,A: $tType,F2: B > A,B3: set @ A,I: B] :
( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ F2 @ ( top_top @ ( set @ B ) ) ) @ B3 )
=> ( member2 @ A @ ( F2 @ I ) @ B3 ) ) ).
% range_subsetD
thf(fact_4221_perfect__space__class_OUNIV__not__singleton,axiom,
! [A: $tType] :
( ( topolo8386298272705272623_space @ A )
=> ! [X: A] :
( ( top_top @ ( set @ A ) )
!= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% perfect_space_class.UNIV_not_singleton
thf(fact_4222_not__UNIV__le__Icc,axiom,
! [A: $tType] :
( ( no_top @ A )
=> ! [L: A,H2: A] :
~ ( ord_less_eq @ ( set @ A ) @ ( top_top @ ( set @ A ) ) @ ( set_or1337092689740270186AtMost @ A @ L @ H2 ) ) ) ).
% not_UNIV_le_Icc
thf(fact_4223_not__UNIV__le__Iic,axiom,
! [A: $tType] :
( ( no_top @ A )
=> ! [H2: A] :
~ ( ord_less_eq @ ( set @ A ) @ ( top_top @ ( set @ A ) ) @ ( set_ord_atMost @ A @ H2 ) ) ) ).
% not_UNIV_le_Iic
thf(fact_4224_Compl__UNIV__eq,axiom,
! [A: $tType] :
( ( uminus_uminus @ ( set @ A ) @ ( top_top @ ( set @ A ) ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% Compl_UNIV_eq
thf(fact_4225_Compl__empty__eq,axiom,
! [A: $tType] :
( ( uminus_uminus @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) )
= ( top_top @ ( set @ A ) ) ) ).
% Compl_empty_eq
thf(fact_4226_INF__filter__not__bot,axiom,
! [I7: $tType,A: $tType,B3: set @ I7,F5: I7 > ( filter @ A )] :
( ! [X9: set @ I7] :
( ( ord_less_eq @ ( set @ I7 ) @ X9 @ B3 )
=> ( ( finite_finite @ I7 @ X9 )
=> ( ( complete_Inf_Inf @ ( filter @ A ) @ ( image2 @ I7 @ ( filter @ A ) @ F5 @ X9 ) )
!= ( bot_bot @ ( filter @ A ) ) ) ) )
=> ( ( complete_Inf_Inf @ ( filter @ A ) @ ( image2 @ I7 @ ( filter @ A ) @ F5 @ B3 ) )
!= ( bot_bot @ ( filter @ A ) ) ) ) ).
% INF_filter_not_bot
thf(fact_4227_Inter__empty,axiom,
! [A: $tType] :
( ( complete_Inf_Inf @ ( set @ A ) @ ( bot_bot @ ( set @ ( set @ A ) ) ) )
= ( top_top @ ( set @ A ) ) ) ).
% Inter_empty
thf(fact_4228_Nil__notin__lex,axiom,
! [A: $tType,Ys: list @ A,R2: set @ ( product_prod @ A @ A )] :
~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Ys ) @ ( lex @ A @ R2 ) ) ).
% Nil_notin_lex
thf(fact_4229_Nil2__notin__lex,axiom,
! [A: $tType,Xs: list @ A,R2: set @ ( product_prod @ A @ A )] :
~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ ( nil @ A ) ) @ ( lex @ A @ R2 ) ) ).
% Nil2_notin_lex
thf(fact_4230_range__eq__singletonD,axiom,
! [B: $tType,A: $tType,F2: B > A,A3: A,X: B] :
( ( ( image2 @ B @ A @ F2 @ ( top_top @ ( set @ B ) ) )
= ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) )
=> ( ( F2 @ X )
= A3 ) ) ).
% range_eq_singletonD
thf(fact_4231_INF__empty,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: B > A] :
( ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ ( bot_bot @ ( set @ B ) ) ) )
= ( top_top @ A ) ) ) ).
% INF_empty
thf(fact_4232_INF__constant,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,C2: A] :
( ( ( A4
= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Inf_Inf @ A
@ ( image2 @ B @ A
@ ^ [Y2: B] : C2
@ A4 ) )
= ( top_top @ A ) ) )
& ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( complete_Inf_Inf @ A
@ ( image2 @ B @ A
@ ^ [Y2: B] : C2
@ A4 ) )
= C2 ) ) ) ) ).
% INF_constant
thf(fact_4233_INF__Int__eq2,axiom,
! [B: $tType,A: $tType,S3: set @ ( set @ ( product_prod @ A @ B ) )] :
( ( complete_Inf_Inf @ ( A > B > $o )
@ ( image2 @ ( set @ ( product_prod @ A @ B ) ) @ ( A > B > $o )
@ ^ [I5: set @ ( product_prod @ A @ B ),X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ I5 )
@ S3 ) )
= ( ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( complete_Inf_Inf @ ( set @ ( product_prod @ A @ B ) ) @ S3 ) ) ) ) ).
% INF_Int_eq2
thf(fact_4234_surj__Compl__image__subset,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B] :
( ( ( image2 @ B @ A @ F2 @ ( top_top @ ( set @ B ) ) )
= ( top_top @ ( set @ A ) ) )
=> ( ord_less_eq @ ( set @ A ) @ ( uminus_uminus @ ( set @ A ) @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( image2 @ B @ A @ F2 @ ( uminus_uminus @ ( set @ B ) @ A4 ) ) ) ) ).
% surj_Compl_image_subset
thf(fact_4235_INF__INT__eq2,axiom,
! [B: $tType,C: $tType,A: $tType,R2: C > ( set @ ( product_prod @ A @ B ) ),S3: set @ C] :
( ( complete_Inf_Inf @ ( A > B > $o )
@ ( image2 @ C @ ( A > B > $o )
@ ^ [I5: C,X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( R2 @ I5 ) )
@ S3 ) )
= ( ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( complete_Inf_Inf @ ( set @ ( product_prod @ A @ B ) ) @ ( image2 @ C @ ( set @ ( product_prod @ A @ B ) ) @ R2 @ S3 ) ) ) ) ) ).
% INF_INT_eq2
thf(fact_4236_finite__range__Some,axiom,
! [A: $tType] :
( ( finite_finite @ ( option @ A ) @ ( image2 @ A @ ( option @ A ) @ ( some @ A ) @ ( top_top @ ( set @ A ) ) ) )
= ( finite_finite @ A @ ( top_top @ ( set @ A ) ) ) ) ).
% finite_range_Some
thf(fact_4237_notin__range__Some,axiom,
! [A: $tType,X: option @ A] :
( ( ~ ( member2 @ ( option @ A ) @ X @ ( image2 @ A @ ( option @ A ) @ ( some @ A ) @ ( top_top @ ( set @ A ) ) ) ) )
= ( X
= ( none @ A ) ) ) ).
% notin_range_Some
thf(fact_4238_INT__empty,axiom,
! [B: $tType,A: $tType,B3: B > ( set @ A )] :
( ( complete_Inf_Inf @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ B3 @ ( bot_bot @ ( set @ B ) ) ) )
= ( top_top @ ( set @ A ) ) ) ).
% INT_empty
thf(fact_4239_inf__top_Osemilattice__neutr__order__axioms,axiom,
! [A: $tType] :
( ( bounde4346867609351753570nf_top @ A )
=> ( semila1105856199041335345_order @ A @ ( inf_inf @ A ) @ ( top_top @ A ) @ ( ord_less_eq @ A ) @ ( ord_less @ A ) ) ) ).
% inf_top.semilattice_neutr_order_axioms
thf(fact_4240_finite__UNIV__card__ge__0,axiom,
! [A: $tType] :
( ( finite_finite @ A @ ( top_top @ ( set @ A ) ) )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ ( finite_card @ A @ ( top_top @ ( set @ A ) ) ) ) ) ).
% finite_UNIV_card_ge_0
thf(fact_4241_UNIV__nat__eq,axiom,
( ( top_top @ ( set @ nat ) )
= ( insert2 @ nat @ ( zero_zero @ nat ) @ ( image2 @ nat @ nat @ suc @ ( top_top @ ( set @ nat ) ) ) ) ) ).
% UNIV_nat_eq
thf(fact_4242_INT__extend__simps_I3_J,axiom,
! [F: $tType,E2: $tType,C5: set @ E2,A4: E2 > ( set @ F ),B3: set @ F] :
( ( ( C5
= ( bot_bot @ ( set @ E2 ) ) )
=> ( ( minus_minus @ ( set @ F ) @ ( complete_Inf_Inf @ ( set @ F ) @ ( image2 @ E2 @ ( set @ F ) @ A4 @ C5 ) ) @ B3 )
= ( minus_minus @ ( set @ F ) @ ( top_top @ ( set @ F ) ) @ B3 ) ) )
& ( ( C5
!= ( bot_bot @ ( set @ E2 ) ) )
=> ( ( minus_minus @ ( set @ F ) @ ( complete_Inf_Inf @ ( set @ F ) @ ( image2 @ E2 @ ( set @ F ) @ A4 @ C5 ) ) @ B3 )
= ( complete_Inf_Inf @ ( set @ F )
@ ( image2 @ E2 @ ( set @ F )
@ ^ [X2: E2] : ( minus_minus @ ( set @ F ) @ ( A4 @ X2 ) @ B3 )
@ C5 ) ) ) ) ) ).
% INT_extend_simps(3)
thf(fact_4243_UN__UN__finite__eq,axiom,
! [A: $tType,A4: nat > ( set @ A )] :
( ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ nat @ ( set @ A )
@ ^ [N: nat] : ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ A4 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N ) ) )
@ ( top_top @ ( set @ nat ) ) ) )
= ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ A4 @ ( top_top @ ( set @ nat ) ) ) ) ) ).
% UN_UN_finite_eq
thf(fact_4244_card__range__greater__zero,axiom,
! [A: $tType,B: $tType,F2: B > A] :
( ( finite_finite @ A @ ( image2 @ B @ A @ F2 @ ( top_top @ ( set @ B ) ) ) )
=> ( ord_less @ nat @ ( zero_zero @ nat ) @ ( finite_card @ A @ ( image2 @ B @ A @ F2 @ ( top_top @ ( set @ B ) ) ) ) ) ) ).
% card_range_greater_zero
thf(fact_4245_UN__finite__subset,axiom,
! [A: $tType,A4: nat > ( set @ A ),C5: set @ A] :
( ! [N3: nat] : ( ord_less_eq @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ A4 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N3 ) ) ) @ C5 )
=> ( ord_less_eq @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ A4 @ ( top_top @ ( set @ nat ) ) ) ) @ C5 ) ) ).
% UN_finite_subset
thf(fact_4246_UN__finite2__eq,axiom,
! [A: $tType,A4: nat > ( set @ A ),B3: nat > ( set @ A ),K: nat] :
( ! [N3: nat] :
( ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ A4 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N3 ) ) )
= ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ B3 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( plus_plus @ nat @ N3 @ K ) ) ) ) )
=> ( ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ A4 @ ( top_top @ ( set @ nat ) ) ) )
= ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ B3 @ ( top_top @ ( set @ nat ) ) ) ) ) ) ).
% UN_finite2_eq
thf(fact_4247_range__mod,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( image2 @ nat @ nat
@ ^ [M2: nat] : ( modulo_modulo @ nat @ M2 @ N2 )
@ ( top_top @ ( set @ nat ) ) )
= ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ).
% range_mod
thf(fact_4248_Inf__INT__eq2,axiom,
! [B: $tType,A: $tType] :
( ( complete_Inf_Inf @ ( A > B > $o ) )
= ( ^ [S8: set @ ( A > B > $o ),X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( complete_Inf_Inf @ ( set @ ( product_prod @ A @ B ) ) @ ( image2 @ ( ( product_prod @ A @ B ) > $o ) @ ( set @ ( product_prod @ A @ B ) ) @ ( collect @ ( product_prod @ A @ B ) ) @ ( image2 @ ( A > B > $o ) @ ( ( product_prod @ A @ B ) > $o ) @ ( product_case_prod @ A @ B @ $o ) @ S8 ) ) ) ) ) ) ).
% Inf_INT_eq2
thf(fact_4249_UN__finite2__subset,axiom,
! [A: $tType,A4: nat > ( set @ A ),B3: nat > ( set @ A ),K: nat] :
( ! [N3: nat] : ( ord_less_eq @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ A4 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N3 ) ) ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ B3 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( plus_plus @ nat @ N3 @ K ) ) ) ) )
=> ( ord_less_eq @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ A4 @ ( top_top @ ( set @ nat ) ) ) ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ B3 @ ( top_top @ ( set @ nat ) ) ) ) ) ) ).
% UN_finite2_subset
thf(fact_4250_Inf__finite__empty,axiom,
! [A: $tType] :
( ( finite_lattice @ A )
=> ( ( complete_Inf_Inf @ A @ ( bot_bot @ ( set @ A ) ) )
= ( complete_Sup_Sup @ A @ ( top_top @ ( set @ A ) ) ) ) ) ).
% Inf_finite_empty
thf(fact_4251_Sup__finite__empty,axiom,
! [A: $tType] :
( ( finite_lattice @ A )
=> ( ( complete_Sup_Sup @ A @ ( bot_bot @ ( set @ A ) ) )
= ( complete_Inf_Inf @ A @ ( top_top @ ( set @ A ) ) ) ) ) ).
% Sup_finite_empty
thf(fact_4252_cclfp__def,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ( ( order_532582986084564980_cclfp @ A )
= ( ^ [F3: A > A] :
( complete_Sup_Sup @ A
@ ( image2 @ nat @ A
@ ^ [I5: nat] : ( compow @ ( A > A ) @ I5 @ F3 @ ( bot_bot @ A ) )
@ ( top_top @ ( set @ nat ) ) ) ) ) ) ) ).
% cclfp_def
thf(fact_4253_bot__finite__def,axiom,
! [A: $tType] :
( ( finite_lattice @ A )
=> ( ( bot_bot @ A )
= ( complete_Inf_Inf @ A @ ( top_top @ ( set @ A ) ) ) ) ) ).
% bot_finite_def
thf(fact_4254_range__mult,axiom,
! [A3: real] :
( ( ( A3
= ( zero_zero @ real ) )
=> ( ( image2 @ real @ real @ ( times_times @ real @ A3 ) @ ( top_top @ ( set @ real ) ) )
= ( insert2 @ real @ ( zero_zero @ real ) @ ( bot_bot @ ( set @ real ) ) ) ) )
& ( ( A3
!= ( zero_zero @ real ) )
=> ( ( image2 @ real @ real @ ( times_times @ real @ A3 ) @ ( top_top @ ( set @ real ) ) )
= ( top_top @ ( set @ real ) ) ) ) ) ).
% range_mult
thf(fact_4255_Collect__const__case__prod,axiom,
! [B: $tType,A: $tType,P2: $o] :
( ( P2
=> ( ( collect @ ( product_prod @ A @ B )
@ ( product_case_prod @ A @ B @ $o
@ ^ [A5: A,B4: B] : P2 ) )
= ( top_top @ ( set @ ( product_prod @ A @ B ) ) ) ) )
& ( ~ P2
=> ( ( collect @ ( product_prod @ A @ B )
@ ( product_case_prod @ A @ B @ $o
@ ^ [A5: A,B4: B] : P2 ) )
= ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) ) ) ) ).
% Collect_const_case_prod
thf(fact_4256_INF__filter__bot__base,axiom,
! [B: $tType,A: $tType,I6: set @ A,F5: A > ( filter @ B )] :
( ! [I3: A] :
( ( member2 @ A @ I3 @ I6 )
=> ! [J2: A] :
( ( member2 @ A @ J2 @ I6 )
=> ? [X3: A] :
( ( member2 @ A @ X3 @ I6 )
& ( ord_less_eq @ ( filter @ B ) @ ( F5 @ X3 ) @ ( inf_inf @ ( filter @ B ) @ ( F5 @ I3 ) @ ( F5 @ J2 ) ) ) ) ) )
=> ( ( ( complete_Inf_Inf @ ( filter @ B ) @ ( image2 @ A @ ( filter @ B ) @ F5 @ I6 ) )
= ( bot_bot @ ( filter @ B ) ) )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ I6 )
& ( ( F5 @ X2 )
= ( bot_bot @ ( filter @ B ) ) ) ) ) ) ) ).
% INF_filter_bot_base
thf(fact_4257_Inf__filter__not__bot,axiom,
! [A: $tType,B3: set @ ( filter @ A )] :
( ! [X9: set @ ( filter @ A )] :
( ( ord_less_eq @ ( set @ ( filter @ A ) ) @ X9 @ B3 )
=> ( ( finite_finite @ ( filter @ A ) @ X9 )
=> ( ( complete_Inf_Inf @ ( filter @ A ) @ X9 )
!= ( bot_bot @ ( filter @ A ) ) ) ) )
=> ( ( complete_Inf_Inf @ ( filter @ A ) @ B3 )
!= ( bot_bot @ ( filter @ A ) ) ) ) ).
% Inf_filter_not_bot
thf(fact_4258_top__empty__eq2,axiom,
! [B: $tType,A: $tType] :
( ( top_top @ ( A > B > $o ) )
= ( ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( top_top @ ( set @ ( product_prod @ A @ B ) ) ) ) ) ) ).
% top_empty_eq2
thf(fact_4259_infinite__UNIV__int,axiom,
~ ( finite_finite @ int @ ( top_top @ ( set @ int ) ) ) ).
% infinite_UNIV_int
thf(fact_4260_infinite__UNIV__listI,axiom,
! [A: $tType] :
~ ( finite_finite @ ( list @ A ) @ ( top_top @ ( set @ ( list @ A ) ) ) ) ).
% infinite_UNIV_listI
thf(fact_4261_Inter__UNIV,axiom,
! [A: $tType] :
( ( complete_Inf_Inf @ ( set @ A ) @ ( top_top @ ( set @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% Inter_UNIV
thf(fact_4262_int__in__range__abs,axiom,
! [N2: nat] : ( member2 @ int @ ( semiring_1_of_nat @ int @ N2 ) @ ( image2 @ int @ int @ ( abs_abs @ int ) @ ( top_top @ ( set @ int ) ) ) ) ).
% int_in_range_abs
thf(fact_4263_root__def,axiom,
( root
= ( ^ [N: nat,X2: real] :
( if @ real
@ ( N
= ( zero_zero @ nat ) )
@ ( zero_zero @ real )
@ ( the_inv_into @ real @ real @ ( top_top @ ( set @ real ) )
@ ^ [Y2: real] : ( times_times @ real @ ( sgn_sgn @ real @ Y2 ) @ ( power_power @ real @ ( abs_abs @ real @ Y2 ) @ N ) )
@ X2 ) ) ) ) ).
% root_def
thf(fact_4264_mlex__eq,axiom,
! [A: $tType] :
( ( mlex_prod @ A )
= ( ^ [F3: A > nat,R5: set @ ( product_prod @ A @ A )] :
( collect @ ( product_prod @ A @ A )
@ ( product_case_prod @ A @ A @ $o
@ ^ [X2: A,Y2: A] :
( ( ord_less @ nat @ ( F3 @ X2 ) @ ( F3 @ Y2 ) )
| ( ( ord_less_eq @ nat @ ( F3 @ X2 ) @ ( F3 @ Y2 ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R5 ) ) ) ) ) ) ) ).
% mlex_eq
thf(fact_4265_these__insert__Some,axiom,
! [A: $tType,X: A,A4: set @ ( option @ A )] :
( ( these @ A @ ( insert2 @ ( option @ A ) @ ( some @ A @ X ) @ A4 ) )
= ( insert2 @ A @ X @ ( these @ A @ A4 ) ) ) ).
% these_insert_Some
thf(fact_4266_DERIV__even__real__root,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( ord_less @ real @ X @ ( zero_zero @ real ) )
=> ( has_field_derivative @ real @ ( root @ N2 ) @ ( inverse_inverse @ real @ ( times_times @ real @ ( uminus_uminus @ real @ ( semiring_1_of_nat @ real @ N2 ) ) @ ( power_power @ real @ ( root @ N2 @ X ) @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) @ ( topolo174197925503356063within @ real @ X @ ( top_top @ ( set @ real ) ) ) ) ) ) ) ).
% DERIV_even_real_root
thf(fact_4267_these__empty,axiom,
! [A: $tType] :
( ( these @ A @ ( bot_bot @ ( set @ ( option @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% these_empty
thf(fact_4268_at__within__empty,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [A3: A] :
( ( topolo174197925503356063within @ A @ A3 @ ( bot_bot @ ( set @ A ) ) )
= ( bot_bot @ ( filter @ A ) ) ) ) ).
% at_within_empty
thf(fact_4269_these__image__Some__eq,axiom,
! [A: $tType,A4: set @ A] :
( ( these @ A @ ( image2 @ A @ ( option @ A ) @ ( some @ A ) @ A4 ) )
= A4 ) ).
% these_image_Some_eq
thf(fact_4270_at__discrete,axiom,
! [A: $tType] :
( ( topolo8865339358273720382pology @ A )
=> ( ( topolo174197925503356063within @ A )
= ( ^ [X2: A,S8: set @ A] : ( bot_bot @ ( filter @ A ) ) ) ) ) ).
% at_discrete
thf(fact_4271_at__le,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S: set @ A,T2: set @ A,X: A] :
( ( ord_less_eq @ ( set @ A ) @ S @ T2 )
=> ( ord_less_eq @ ( filter @ A ) @ ( topolo174197925503356063within @ A @ X @ S ) @ ( topolo174197925503356063within @ A @ X @ T2 ) ) ) ) ).
% at_le
thf(fact_4272_in__these__eq,axiom,
! [A: $tType,X: A,A4: set @ ( option @ A )] :
( ( member2 @ A @ X @ ( these @ A @ A4 ) )
= ( member2 @ ( option @ A ) @ ( some @ A @ X ) @ A4 ) ) ).
% in_these_eq
thf(fact_4273_at__neq__bot,axiom,
! [A: $tType] :
( ( topolo8386298272705272623_space @ A )
=> ! [A3: A] :
( ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) )
!= ( bot_bot @ ( filter @ A ) ) ) ) ).
% at_neq_bot
thf(fact_4274_trivial__limit__at__left__real,axiom,
! [A: $tType] :
( ( ( dense_order @ A )
& ( no_bot @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [X: A] :
( ( topolo174197925503356063within @ A @ X @ ( set_ord_lessThan @ A @ X ) )
!= ( bot_bot @ ( filter @ A ) ) ) ) ).
% trivial_limit_at_left_real
thf(fact_4275_DERIV__cos__add,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [K: A,Xa2: A] :
( has_field_derivative @ A
@ ^ [X2: A] : ( cos @ A @ ( plus_plus @ A @ X2 @ K ) )
@ ( uminus_uminus @ A @ ( sin @ A @ ( plus_plus @ A @ Xa2 @ K ) ) )
@ ( topolo174197925503356063within @ A @ Xa2 @ ( top_top @ ( set @ A ) ) ) ) ) ).
% DERIV_cos_add
thf(fact_4276_at__within__Icc__at,axiom,
! [A: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [A3: A,X: A,B2: A] :
( ( ord_less @ A @ A3 @ X )
=> ( ( ord_less @ A @ X @ B2 )
=> ( ( topolo174197925503356063within @ A @ X @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ).
% at_within_Icc_at
thf(fact_4277_at__within__Icc__at__left,axiom,
! [A: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( topolo174197925503356063within @ A @ B2 @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( topolo174197925503356063within @ A @ B2 @ ( set_ord_lessThan @ A @ B2 ) ) ) ) ) ).
% at_within_Icc_at_left
thf(fact_4278_trivial__limit__at__left__bot,axiom,
! [A: $tType] :
( ( ( order_bot @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ( ( topolo174197925503356063within @ A @ ( bot_bot @ A ) @ ( set_ord_lessThan @ A @ ( bot_bot @ A ) ) )
= ( bot_bot @ ( filter @ A ) ) ) ) ).
% trivial_limit_at_left_bot
thf(fact_4279_DERIV__tan,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ( cos @ A @ X )
!= ( zero_zero @ A ) )
=> ( has_field_derivative @ A @ ( tan @ A ) @ ( inverse_inverse @ A @ ( power_power @ A @ ( cos @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% DERIV_tan
thf(fact_4280_has__field__derivative__tanh,axiom,
! [A10: $tType] :
( ( ( real_Vector_banach @ A10 )
& ( real_V3459762299906320749_field @ A10 ) )
=> ! [G: A10 > A10,X: A10,Db: A10,S: set @ A10] :
( ( ( cosh @ A10 @ ( G @ X ) )
!= ( zero_zero @ A10 ) )
=> ( ( has_field_derivative @ A10 @ G @ Db @ ( topolo174197925503356063within @ A10 @ X @ S ) )
=> ( has_field_derivative @ A10
@ ^ [X2: A10] : ( tanh @ A10 @ ( G @ X2 ) )
@ ( times_times @ A10 @ ( minus_minus @ A10 @ ( one_one @ A10 ) @ ( power_power @ A10 @ ( tanh @ A10 @ ( G @ X ) ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) @ Db )
@ ( topolo174197925503356063within @ A10 @ X @ S ) ) ) ) ) ).
% has_field_derivative_tanh
thf(fact_4281_DERIV__real__root,axiom,
! [N2: nat,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ X )
=> ( has_field_derivative @ real @ ( root @ N2 ) @ ( inverse_inverse @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ N2 ) @ ( power_power @ real @ ( root @ N2 @ X ) @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) @ ( topolo174197925503356063within @ real @ X @ ( top_top @ ( set @ real ) ) ) ) ) ) ).
% DERIV_real_root
thf(fact_4282_Maclaurin__all__le,axiom,
! [Diff: nat > real > real,F2: real > real,X: real,N2: nat] :
( ( ( Diff @ ( zero_zero @ nat ) )
= F2 )
=> ( ! [M3: nat,X5: real] : ( has_field_derivative @ real @ ( Diff @ M3 ) @ ( Diff @ ( suc @ M3 ) @ X5 ) @ ( topolo174197925503356063within @ real @ X5 @ ( top_top @ ( set @ real ) ) ) )
=> ? [T7: real] :
( ( ord_less_eq @ real @ ( abs_abs @ real @ T7 ) @ ( abs_abs @ real @ X ) )
& ( ( F2 @ X )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ M2 @ ( zero_zero @ real ) ) @ ( semiring_char_0_fact @ real @ M2 ) ) @ ( power_power @ real @ X @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( Diff @ N2 @ T7 ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ X @ N2 ) ) ) ) ) ) ) ).
% Maclaurin_all_le
thf(fact_4283_Maclaurin__all__le__objl,axiom,
! [Diff: nat > real > real,F2: real > real,X: real,N2: nat] :
( ( ( ( Diff @ ( zero_zero @ nat ) )
= F2 )
& ! [M3: nat,X5: real] : ( has_field_derivative @ real @ ( Diff @ M3 ) @ ( Diff @ ( suc @ M3 ) @ X5 ) @ ( topolo174197925503356063within @ real @ X5 @ ( top_top @ ( set @ real ) ) ) ) )
=> ? [T7: real] :
( ( ord_less_eq @ real @ ( abs_abs @ real @ T7 ) @ ( abs_abs @ real @ X ) )
& ( ( F2 @ X )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ M2 @ ( zero_zero @ real ) ) @ ( semiring_char_0_fact @ real @ M2 ) ) @ ( power_power @ real @ X @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( Diff @ N2 @ T7 ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ X @ N2 ) ) ) ) ) ) ).
% Maclaurin_all_le_objl
thf(fact_4284_DERIV__odd__real__root,axiom,
! [N2: nat,X: real] :
( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( X
!= ( zero_zero @ real ) )
=> ( has_field_derivative @ real @ ( root @ N2 ) @ ( inverse_inverse @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ N2 ) @ ( power_power @ real @ ( root @ N2 @ X ) @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) @ ( topolo174197925503356063within @ real @ X @ ( top_top @ ( set @ real ) ) ) ) ) ) ).
% DERIV_odd_real_root
thf(fact_4285_these__not__empty__eq,axiom,
! [A: $tType,B3: set @ ( option @ A )] :
( ( ( these @ A @ B3 )
!= ( bot_bot @ ( set @ A ) ) )
= ( ( B3
!= ( bot_bot @ ( set @ ( option @ A ) ) ) )
& ( B3
!= ( insert2 @ ( option @ A ) @ ( none @ A ) @ ( bot_bot @ ( set @ ( option @ A ) ) ) ) ) ) ) ).
% these_not_empty_eq
thf(fact_4286_these__empty__eq,axiom,
! [A: $tType,B3: set @ ( option @ A )] :
( ( ( these @ A @ B3 )
= ( bot_bot @ ( set @ A ) ) )
= ( ( B3
= ( bot_bot @ ( set @ ( option @ A ) ) ) )
| ( B3
= ( insert2 @ ( option @ A ) @ ( none @ A ) @ ( bot_bot @ ( set @ ( option @ A ) ) ) ) ) ) ) ).
% these_empty_eq
thf(fact_4287_Maclaurin,axiom,
! [H2: real,N2: nat,Diff: nat > real > real,F2: real > real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ H2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ( Diff @ ( zero_zero @ nat ) )
= F2 )
=> ( ! [M3: nat,T7: real] :
( ( ( ord_less @ nat @ M3 @ N2 )
& ( ord_less_eq @ real @ ( zero_zero @ real ) @ T7 )
& ( ord_less_eq @ real @ T7 @ H2 ) )
=> ( has_field_derivative @ real @ ( Diff @ M3 ) @ ( Diff @ ( suc @ M3 ) @ T7 ) @ ( topolo174197925503356063within @ real @ T7 @ ( top_top @ ( set @ real ) ) ) ) )
=> ? [T7: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ T7 )
& ( ord_less @ real @ T7 @ H2 )
& ( ( F2 @ H2 )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ M2 @ ( zero_zero @ real ) ) @ ( semiring_char_0_fact @ real @ M2 ) ) @ ( power_power @ real @ H2 @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( Diff @ N2 @ T7 ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ H2 @ N2 ) ) ) ) ) ) ) ) ) ).
% Maclaurin
thf(fact_4288_Maclaurin2,axiom,
! [H2: real,Diff: nat > real > real,F2: real > real,N2: nat] :
( ( ord_less @ real @ ( zero_zero @ real ) @ H2 )
=> ( ( ( Diff @ ( zero_zero @ nat ) )
= F2 )
=> ( ! [M3: nat,T7: real] :
( ( ( ord_less @ nat @ M3 @ N2 )
& ( ord_less_eq @ real @ ( zero_zero @ real ) @ T7 )
& ( ord_less_eq @ real @ T7 @ H2 ) )
=> ( has_field_derivative @ real @ ( Diff @ M3 ) @ ( Diff @ ( suc @ M3 ) @ T7 ) @ ( topolo174197925503356063within @ real @ T7 @ ( top_top @ ( set @ real ) ) ) ) )
=> ? [T7: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ T7 )
& ( ord_less_eq @ real @ T7 @ H2 )
& ( ( F2 @ H2 )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ M2 @ ( zero_zero @ real ) ) @ ( semiring_char_0_fact @ real @ M2 ) ) @ ( power_power @ real @ H2 @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( Diff @ N2 @ T7 ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ H2 @ N2 ) ) ) ) ) ) ) ) ).
% Maclaurin2
thf(fact_4289_Maclaurin__minus,axiom,
! [H2: real,N2: nat,Diff: nat > real > real,F2: real > real] :
( ( ord_less @ real @ H2 @ ( zero_zero @ real ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ( Diff @ ( zero_zero @ nat ) )
= F2 )
=> ( ! [M3: nat,T7: real] :
( ( ( ord_less @ nat @ M3 @ N2 )
& ( ord_less_eq @ real @ H2 @ T7 )
& ( ord_less_eq @ real @ T7 @ ( zero_zero @ real ) ) )
=> ( has_field_derivative @ real @ ( Diff @ M3 ) @ ( Diff @ ( suc @ M3 ) @ T7 ) @ ( topolo174197925503356063within @ real @ T7 @ ( top_top @ ( set @ real ) ) ) ) )
=> ? [T7: real] :
( ( ord_less @ real @ H2 @ T7 )
& ( ord_less @ real @ T7 @ ( zero_zero @ real ) )
& ( ( F2 @ H2 )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ M2 @ ( zero_zero @ real ) ) @ ( semiring_char_0_fact @ real @ M2 ) ) @ ( power_power @ real @ H2 @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( Diff @ N2 @ T7 ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ H2 @ N2 ) ) ) ) ) ) ) ) ) ).
% Maclaurin_minus
thf(fact_4290_Maclaurin__all__lt,axiom,
! [Diff: nat > real > real,F2: real > real,N2: nat,X: real] :
( ( ( Diff @ ( zero_zero @ nat ) )
= F2 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( X
!= ( zero_zero @ real ) )
=> ( ! [M3: nat,X5: real] : ( has_field_derivative @ real @ ( Diff @ M3 ) @ ( Diff @ ( suc @ M3 ) @ X5 ) @ ( topolo174197925503356063within @ real @ X5 @ ( top_top @ ( set @ real ) ) ) )
=> ? [T7: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ ( abs_abs @ real @ T7 ) )
& ( ord_less @ real @ ( abs_abs @ real @ T7 ) @ ( abs_abs @ real @ X ) )
& ( ( F2 @ X )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ M2 @ ( zero_zero @ real ) ) @ ( semiring_char_0_fact @ real @ M2 ) ) @ ( power_power @ real @ X @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( Diff @ N2 @ T7 ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ X @ N2 ) ) ) ) ) ) ) ) ) ).
% Maclaurin_all_lt
thf(fact_4291_Maclaurin__bi__le,axiom,
! [Diff: nat > real > real,F2: real > real,N2: nat,X: real] :
( ( ( Diff @ ( zero_zero @ nat ) )
= F2 )
=> ( ! [M3: nat,T7: real] :
( ( ( ord_less @ nat @ M3 @ N2 )
& ( ord_less_eq @ real @ ( abs_abs @ real @ T7 ) @ ( abs_abs @ real @ X ) ) )
=> ( has_field_derivative @ real @ ( Diff @ M3 ) @ ( Diff @ ( suc @ M3 ) @ T7 ) @ ( topolo174197925503356063within @ real @ T7 @ ( top_top @ ( set @ real ) ) ) ) )
=> ? [T7: real] :
( ( ord_less_eq @ real @ ( abs_abs @ real @ T7 ) @ ( abs_abs @ real @ X ) )
& ( ( F2 @ X )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ M2 @ ( zero_zero @ real ) ) @ ( semiring_char_0_fact @ real @ M2 ) ) @ ( power_power @ real @ X @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( Diff @ N2 @ T7 ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ X @ N2 ) ) ) ) ) ) ) ).
% Maclaurin_bi_le
thf(fact_4292_Taylor__down,axiom,
! [N2: nat,Diff: nat > real > real,F2: real > real,A3: real,B2: real,C2: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ( Diff @ ( zero_zero @ nat ) )
= F2 )
=> ( ! [M3: nat,T7: real] :
( ( ( ord_less @ nat @ M3 @ N2 )
& ( ord_less_eq @ real @ A3 @ T7 )
& ( ord_less_eq @ real @ T7 @ B2 ) )
=> ( has_field_derivative @ real @ ( Diff @ M3 ) @ ( Diff @ ( suc @ M3 ) @ T7 ) @ ( topolo174197925503356063within @ real @ T7 @ ( top_top @ ( set @ real ) ) ) ) )
=> ( ( ord_less @ real @ A3 @ C2 )
=> ( ( ord_less_eq @ real @ C2 @ B2 )
=> ? [T7: real] :
( ( ord_less @ real @ A3 @ T7 )
& ( ord_less @ real @ T7 @ C2 )
& ( ( F2 @ A3 )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ M2 @ C2 ) @ ( semiring_char_0_fact @ real @ M2 ) ) @ ( power_power @ real @ ( minus_minus @ real @ A3 @ C2 ) @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( Diff @ N2 @ T7 ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ ( minus_minus @ real @ A3 @ C2 ) @ N2 ) ) ) ) ) ) ) ) ) ) ).
% Taylor_down
thf(fact_4293_Taylor__up,axiom,
! [N2: nat,Diff: nat > real > real,F2: real > real,A3: real,B2: real,C2: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ( Diff @ ( zero_zero @ nat ) )
= F2 )
=> ( ! [M3: nat,T7: real] :
( ( ( ord_less @ nat @ M3 @ N2 )
& ( ord_less_eq @ real @ A3 @ T7 )
& ( ord_less_eq @ real @ T7 @ B2 ) )
=> ( has_field_derivative @ real @ ( Diff @ M3 ) @ ( Diff @ ( suc @ M3 ) @ T7 ) @ ( topolo174197925503356063within @ real @ T7 @ ( top_top @ ( set @ real ) ) ) ) )
=> ( ( ord_less_eq @ real @ A3 @ C2 )
=> ( ( ord_less @ real @ C2 @ B2 )
=> ? [T7: real] :
( ( ord_less @ real @ C2 @ T7 )
& ( ord_less @ real @ T7 @ B2 )
& ( ( F2 @ B2 )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ M2 @ C2 ) @ ( semiring_char_0_fact @ real @ M2 ) ) @ ( power_power @ real @ ( minus_minus @ real @ B2 @ C2 ) @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( Diff @ N2 @ T7 ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ ( minus_minus @ real @ B2 @ C2 ) @ N2 ) ) ) ) ) ) ) ) ) ) ).
% Taylor_up
thf(fact_4294_Taylor,axiom,
! [N2: nat,Diff: nat > real > real,F2: real > real,A3: real,B2: real,C2: real,X: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( ( Diff @ ( zero_zero @ nat ) )
= F2 )
=> ( ! [M3: nat,T7: real] :
( ( ( ord_less @ nat @ M3 @ N2 )
& ( ord_less_eq @ real @ A3 @ T7 )
& ( ord_less_eq @ real @ T7 @ B2 ) )
=> ( has_field_derivative @ real @ ( Diff @ M3 ) @ ( Diff @ ( suc @ M3 ) @ T7 ) @ ( topolo174197925503356063within @ real @ T7 @ ( top_top @ ( set @ real ) ) ) ) )
=> ( ( ord_less_eq @ real @ A3 @ C2 )
=> ( ( ord_less_eq @ real @ C2 @ B2 )
=> ( ( ord_less_eq @ real @ A3 @ X )
=> ( ( ord_less_eq @ real @ X @ B2 )
=> ( ( X != C2 )
=> ? [T7: real] :
( ( ( ord_less @ real @ X @ C2 )
=> ( ( ord_less @ real @ X @ T7 )
& ( ord_less @ real @ T7 @ C2 ) ) )
& ( ~ ( ord_less @ real @ X @ C2 )
=> ( ( ord_less @ real @ C2 @ T7 )
& ( ord_less @ real @ T7 @ X ) ) )
& ( ( F2 @ X )
= ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [M2: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ M2 @ C2 ) @ ( semiring_char_0_fact @ real @ M2 ) ) @ ( power_power @ real @ ( minus_minus @ real @ X @ C2 ) @ M2 ) )
@ ( set_ord_lessThan @ nat @ N2 ) )
@ ( times_times @ real @ ( divide_divide @ real @ ( Diff @ N2 @ T7 ) @ ( semiring_char_0_fact @ real @ N2 ) ) @ ( power_power @ real @ ( minus_minus @ real @ X @ C2 ) @ N2 ) ) ) ) ) ) ) ) ) ) ) ) ) ).
% Taylor
thf(fact_4295_Some__image__these__eq,axiom,
! [A: $tType,A4: set @ ( option @ A )] :
( ( image2 @ A @ ( option @ A ) @ ( some @ A ) @ ( these @ A @ A4 ) )
= ( collect @ ( option @ A )
@ ^ [X2: option @ A] :
( ( member2 @ ( option @ A ) @ X2 @ A4 )
& ( X2
!= ( none @ A ) ) ) ) ) ).
% Some_image_these_eq
thf(fact_4296_Maclaurin__lemma2,axiom,
! [N2: nat,H2: real,Diff: nat > real > real,K: nat,B3: real] :
( ! [M3: nat,T7: real] :
( ( ( ord_less @ nat @ M3 @ N2 )
& ( ord_less_eq @ real @ ( zero_zero @ real ) @ T7 )
& ( ord_less_eq @ real @ T7 @ H2 ) )
=> ( has_field_derivative @ real @ ( Diff @ M3 ) @ ( Diff @ ( suc @ M3 ) @ T7 ) @ ( topolo174197925503356063within @ real @ T7 @ ( top_top @ ( set @ real ) ) ) ) )
=> ( ( N2
= ( suc @ K ) )
=> ! [M4: nat,T8: real] :
( ( ( ord_less @ nat @ M4 @ N2 )
& ( ord_less_eq @ real @ ( zero_zero @ real ) @ T8 )
& ( ord_less_eq @ real @ T8 @ H2 ) )
=> ( has_field_derivative @ real
@ ^ [U2: real] :
( minus_minus @ real @ ( Diff @ M4 @ U2 )
@ ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [P6: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ ( plus_plus @ nat @ M4 @ P6 ) @ ( zero_zero @ real ) ) @ ( semiring_char_0_fact @ real @ P6 ) ) @ ( power_power @ real @ U2 @ P6 ) )
@ ( set_ord_lessThan @ nat @ ( minus_minus @ nat @ N2 @ M4 ) ) )
@ ( times_times @ real @ B3 @ ( divide_divide @ real @ ( power_power @ real @ U2 @ ( minus_minus @ nat @ N2 @ M4 ) ) @ ( semiring_char_0_fact @ real @ ( minus_minus @ nat @ N2 @ M4 ) ) ) ) ) )
@ ( minus_minus @ real @ ( Diff @ ( suc @ M4 ) @ T8 )
@ ( plus_plus @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [P6: nat] : ( times_times @ real @ ( divide_divide @ real @ ( Diff @ ( plus_plus @ nat @ ( suc @ M4 ) @ P6 ) @ ( zero_zero @ real ) ) @ ( semiring_char_0_fact @ real @ P6 ) ) @ ( power_power @ real @ T8 @ P6 ) )
@ ( set_ord_lessThan @ nat @ ( minus_minus @ nat @ N2 @ ( suc @ M4 ) ) ) )
@ ( times_times @ real @ B3 @ ( divide_divide @ real @ ( power_power @ real @ T8 @ ( minus_minus @ nat @ N2 @ ( suc @ M4 ) ) ) @ ( semiring_char_0_fact @ real @ ( minus_minus @ nat @ N2 @ ( suc @ M4 ) ) ) ) ) ) )
@ ( topolo174197925503356063within @ real @ T8 @ ( top_top @ ( set @ real ) ) ) ) ) ) ) ).
% Maclaurin_lemma2
thf(fact_4297_DERIV__arctan__series,axiom,
! [X: real] :
( ( ord_less @ real @ ( abs_abs @ real @ X ) @ ( one_one @ real ) )
=> ( has_field_derivative @ real
@ ^ [X10: real] :
( suminf @ real
@ ^ [K2: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ K2 ) @ ( times_times @ real @ ( divide_divide @ real @ ( one_one @ real ) @ ( semiring_1_of_nat @ real @ ( plus_plus @ nat @ ( times_times @ nat @ K2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) ) @ ( power_power @ real @ X10 @ ( plus_plus @ nat @ ( times_times @ nat @ K2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) ) ) )
@ ( suminf @ real
@ ^ [K2: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ K2 ) @ ( power_power @ real @ X @ ( times_times @ nat @ K2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
@ ( topolo174197925503356063within @ real @ X @ ( top_top @ ( set @ real ) ) ) ) ) ).
% DERIV_arctan_series
thf(fact_4298_DERIV__real__root__generic,axiom,
! [N2: nat,X: real,D6: real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( X
!= ( zero_zero @ real ) )
=> ( ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ X )
=> ( D6
= ( inverse_inverse @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ N2 ) @ ( power_power @ real @ ( root @ N2 @ X ) @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ) ) )
=> ( ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( ( ord_less @ real @ X @ ( zero_zero @ real ) )
=> ( D6
= ( uminus_uminus @ real @ ( inverse_inverse @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ N2 ) @ ( power_power @ real @ ( root @ N2 @ X ) @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ) ) ) )
=> ( ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( D6
= ( inverse_inverse @ real @ ( times_times @ real @ ( semiring_1_of_nat @ real @ N2 ) @ ( power_power @ real @ ( root @ N2 @ X ) @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ) )
=> ( has_field_derivative @ real @ ( root @ N2 ) @ D6 @ ( topolo174197925503356063within @ real @ X @ ( top_top @ ( set @ real ) ) ) ) ) ) ) ) ) ).
% DERIV_real_root_generic
thf(fact_4299_DERIV__inverse__fun,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D2: A,X: A,S: set @ A] :
( ( has_field_derivative @ A @ F2 @ D2 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ( F2 @ X )
!= ( zero_zero @ A ) )
=> ( has_field_derivative @ A
@ ^ [X2: A] : ( inverse_inverse @ A @ ( F2 @ X2 ) )
@ ( uminus_uminus @ A @ ( times_times @ A @ D2 @ ( inverse_inverse @ A @ ( power_power @ A @ ( F2 @ X ) @ ( suc @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ).
% DERIV_inverse_fun
thf(fact_4300_DERIV__quotient,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D2: A,X: A,S: set @ A,G: A > A,E3: A] :
( ( has_field_derivative @ A @ F2 @ D2 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( has_field_derivative @ A @ G @ E3 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ( G @ X )
!= ( zero_zero @ A ) )
=> ( has_field_derivative @ A
@ ^ [Y2: A] : ( divide_divide @ A @ ( F2 @ Y2 ) @ ( G @ Y2 ) )
@ ( divide_divide @ A @ ( minus_minus @ A @ ( times_times @ A @ D2 @ ( G @ X ) ) @ ( times_times @ A @ E3 @ ( F2 @ X ) ) ) @ ( power_power @ A @ ( G @ X ) @ ( suc @ ( suc @ ( zero_zero @ nat ) ) ) ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ) ).
% DERIV_quotient
thf(fact_4301_DERIV__pow,axiom,
! [N2: nat,X: real,S: set @ real] :
( has_field_derivative @ real
@ ^ [X2: real] : ( power_power @ real @ X2 @ N2 )
@ ( times_times @ real @ ( semiring_1_of_nat @ real @ N2 ) @ ( power_power @ real @ X @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) )
@ ( topolo174197925503356063within @ real @ X @ S ) ) ).
% DERIV_pow
thf(fact_4302_DERIV__power,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D6: A,X: A,S: set @ A,N2: nat] :
( ( has_field_derivative @ A @ F2 @ D6 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( has_field_derivative @ A
@ ^ [X2: A] : ( power_power @ A @ ( F2 @ X2 ) @ N2 )
@ ( times_times @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( times_times @ A @ D6 @ ( power_power @ A @ ( F2 @ X ) @ ( minus_minus @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ) ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ).
% DERIV_power
thf(fact_4303_DERIV__const,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [K: A,F5: filter @ A] :
( has_field_derivative @ A
@ ^ [X2: A] : K
@ ( zero_zero @ A )
@ F5 ) ) ).
% DERIV_const
thf(fact_4304_field__differentiable__add,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,F8: A,F5: filter @ A,G: A > A,G6: A] :
( ( has_field_derivative @ A @ F2 @ F8 @ F5 )
=> ( ( has_field_derivative @ A @ G @ G6 @ F5 )
=> ( has_field_derivative @ A
@ ^ [Z6: A] : ( plus_plus @ A @ ( F2 @ Z6 ) @ ( G @ Z6 ) )
@ ( plus_plus @ A @ F8 @ G6 )
@ F5 ) ) ) ) ).
% field_differentiable_add
thf(fact_4305_has__field__derivative__subset,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,Y: A,X: A,S: set @ A,T2: set @ A] :
( ( has_field_derivative @ A @ F2 @ Y @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ord_less_eq @ ( set @ A ) @ T2 @ S )
=> ( has_field_derivative @ A @ F2 @ Y @ ( topolo174197925503356063within @ A @ X @ T2 ) ) ) ) ) ).
% has_field_derivative_subset
thf(fact_4306_DERIV__subset,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,F8: A,X: A,S: set @ A,T2: set @ A] :
( ( has_field_derivative @ A @ F2 @ F8 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ord_less_eq @ ( set @ A ) @ T2 @ S )
=> ( has_field_derivative @ A @ F2 @ F8 @ ( topolo174197925503356063within @ A @ X @ T2 ) ) ) ) ) ).
% DERIV_subset
thf(fact_4307_DERIV__add,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D6: A,X: A,S: set @ A,G: A > A,E5: A] :
( ( has_field_derivative @ A @ F2 @ D6 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( has_field_derivative @ A @ G @ E5 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( has_field_derivative @ A
@ ^ [X2: A] : ( plus_plus @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( plus_plus @ A @ D6 @ E5 )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ).
% DERIV_add
thf(fact_4308_DERIV__mult,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,Da: A,X: A,S: set @ A,G: A > A,Db: A] :
( ( has_field_derivative @ A @ F2 @ Da @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( has_field_derivative @ A @ G @ Db @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( has_field_derivative @ A
@ ^ [X2: A] : ( times_times @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( plus_plus @ A @ ( times_times @ A @ Da @ ( G @ X ) ) @ ( times_times @ A @ Db @ ( F2 @ X ) ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ).
% DERIV_mult
thf(fact_4309_DERIV__mult_H,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D6: A,X: A,S: set @ A,G: A > A,E5: A] :
( ( has_field_derivative @ A @ F2 @ D6 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( has_field_derivative @ A @ G @ E5 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( has_field_derivative @ A
@ ^ [X2: A] : ( times_times @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( plus_plus @ A @ ( times_times @ A @ ( F2 @ X ) @ E5 ) @ ( times_times @ A @ D6 @ ( G @ X ) ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ).
% DERIV_mult'
thf(fact_4310_DERIV__at__within__shift,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,Y: A,Z: A,X: A,S3: set @ A] :
( ( has_field_derivative @ A @ F2 @ Y @ ( topolo174197925503356063within @ A @ ( plus_plus @ A @ Z @ X ) @ ( image2 @ A @ A @ ( plus_plus @ A @ Z ) @ S3 ) ) )
= ( has_field_derivative @ A
@ ^ [X2: A] : ( F2 @ ( plus_plus @ A @ Z @ X2 ) )
@ Y
@ ( topolo174197925503356063within @ A @ X @ S3 ) ) ) ) ).
% DERIV_at_within_shift
thf(fact_4311_DERIV__shift,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,Y: A,X: A,Z: A] :
( ( has_field_derivative @ A @ F2 @ Y @ ( topolo174197925503356063within @ A @ ( plus_plus @ A @ X @ Z ) @ ( top_top @ ( set @ A ) ) ) )
= ( has_field_derivative @ A
@ ^ [X2: A] : ( F2 @ ( plus_plus @ A @ X2 @ Z ) )
@ Y
@ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% DERIV_shift
thf(fact_4312_DERIV__divide,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D6: A,X: A,S: set @ A,G: A > A,E5: A] :
( ( has_field_derivative @ A @ F2 @ D6 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( has_field_derivative @ A @ G @ E5 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ( G @ X )
!= ( zero_zero @ A ) )
=> ( has_field_derivative @ A
@ ^ [X2: A] : ( divide_divide @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( divide_divide @ A @ ( minus_minus @ A @ ( times_times @ A @ D6 @ ( G @ X ) ) @ ( times_times @ A @ ( F2 @ X ) @ E5 ) ) @ ( times_times @ A @ ( G @ X ) @ ( G @ X ) ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ) ).
% DERIV_divide
thf(fact_4313_DERIV__inverse_H,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D6: A,X: A,S: set @ A] :
( ( has_field_derivative @ A @ F2 @ D6 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ( F2 @ X )
!= ( zero_zero @ A ) )
=> ( has_field_derivative @ A
@ ^ [X2: A] : ( inverse_inverse @ A @ ( F2 @ X2 ) )
@ ( uminus_uminus @ A @ ( times_times @ A @ ( times_times @ A @ ( inverse_inverse @ A @ ( F2 @ X ) ) @ D6 ) @ ( inverse_inverse @ A @ ( F2 @ X ) ) ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ).
% DERIV_inverse'
thf(fact_4314_DERIV__power__Suc,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D6: A,X: A,S: set @ A,N2: nat] :
( ( has_field_derivative @ A @ F2 @ D6 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( has_field_derivative @ A
@ ^ [X2: A] : ( power_power @ A @ ( F2 @ X2 ) @ ( suc @ N2 ) )
@ ( times_times @ A @ ( plus_plus @ A @ ( one_one @ A ) @ ( semiring_1_of_nat @ A @ N2 ) ) @ ( times_times @ A @ D6 @ ( power_power @ A @ ( F2 @ X ) @ N2 ) ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ).
% DERIV_power_Suc
thf(fact_4315_DERIV__inverse,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [X: A,S: set @ A] :
( ( X
!= ( zero_zero @ A ) )
=> ( has_field_derivative @ A @ ( inverse_inverse @ A ) @ ( uminus_uminus @ A @ ( power_power @ A @ ( inverse_inverse @ A @ X ) @ ( suc @ ( suc @ ( zero_zero @ nat ) ) ) ) ) @ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ).
% DERIV_inverse
thf(fact_4316_DERIV__cot,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ( sin @ A @ X )
!= ( zero_zero @ A ) )
=> ( has_field_derivative @ A @ ( cot @ A ) @ ( uminus_uminus @ A @ ( inverse_inverse @ A @ ( power_power @ A @ ( sin @ A @ X ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% DERIV_cot
thf(fact_4317_DERIV__power__series_H,axiom,
! [R: real,F2: nat > real,X0: real] :
( ! [X5: real] :
( ( member2 @ real @ X5 @ ( set_or5935395276787703475ssThan @ real @ ( uminus_uminus @ real @ R ) @ R ) )
=> ( summable @ real
@ ^ [N: nat] : ( times_times @ real @ ( times_times @ real @ ( F2 @ N ) @ ( semiring_1_of_nat @ real @ ( suc @ N ) ) ) @ ( power_power @ real @ X5 @ N ) ) ) )
=> ( ( member2 @ real @ X0 @ ( set_or5935395276787703475ssThan @ real @ ( uminus_uminus @ real @ R ) @ R ) )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ R )
=> ( has_field_derivative @ real
@ ^ [X2: real] :
( suminf @ real
@ ^ [N: nat] : ( times_times @ real @ ( F2 @ N ) @ ( power_power @ real @ X2 @ ( suc @ N ) ) ) )
@ ( suminf @ real
@ ^ [N: nat] : ( times_times @ real @ ( times_times @ real @ ( F2 @ N ) @ ( semiring_1_of_nat @ real @ ( suc @ N ) ) ) @ ( power_power @ real @ X0 @ N ) ) )
@ ( topolo174197925503356063within @ real @ X0 @ ( top_top @ ( set @ real ) ) ) ) ) ) ) ).
% DERIV_power_series'
thf(fact_4318_mlex__leq,axiom,
! [A: $tType,F2: A > nat,X: A,Y: A,R: set @ ( product_prod @ A @ A )] :
( ( ord_less_eq @ nat @ ( F2 @ X ) @ ( F2 @ Y ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( mlex_prod @ A @ F2 @ R ) ) ) ) ).
% mlex_leq
thf(fact_4319_mlex__iff,axiom,
! [A: $tType,X: A,Y: A,F2: A > nat,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( mlex_prod @ A @ F2 @ R ) )
= ( ( ord_less @ nat @ ( F2 @ X ) @ ( F2 @ Y ) )
| ( ( ( F2 @ X )
= ( F2 @ Y ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R ) ) ) ) ).
% mlex_iff
thf(fact_4320_greaterThanLessThan__iff,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [I: A,L: A,U: A] :
( ( member2 @ A @ I @ ( set_or5935395276787703475ssThan @ A @ L @ U ) )
= ( ( ord_less @ A @ L @ I )
& ( ord_less @ A @ I @ U ) ) ) ) ).
% greaterThanLessThan_iff
thf(fact_4321_cot__zero,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ( ( cot @ A @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% cot_zero
thf(fact_4322_greaterThanLessThan__empty,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,K: A] :
( ( ord_less_eq @ A @ L @ K )
=> ( ( set_or5935395276787703475ssThan @ A @ K @ L )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% greaterThanLessThan_empty
thf(fact_4323_greaterThanLessThan__empty__iff,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A] :
( ( ( set_or5935395276787703475ssThan @ A @ A3 @ B2 )
= ( bot_bot @ ( set @ A ) ) )
= ( ord_less_eq @ A @ B2 @ A3 ) ) ) ).
% greaterThanLessThan_empty_iff
thf(fact_4324_greaterThanLessThan__empty__iff2,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A] :
( ( ( bot_bot @ ( set @ A ) )
= ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) )
= ( ord_less_eq @ A @ B2 @ A3 ) ) ) ).
% greaterThanLessThan_empty_iff2
thf(fact_4325_infinite__Ioo__iff,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A] :
( ( ~ ( finite_finite @ A @ ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) ) )
= ( ord_less @ A @ A3 @ B2 ) ) ) ).
% infinite_Ioo_iff
thf(fact_4326_cSup__greaterThanLessThan,axiom,
! [A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( dense_linorder @ A ) )
=> ! [Y: A,X: A] :
( ( ord_less @ A @ Y @ X )
=> ( ( complete_Sup_Sup @ A @ ( set_or5935395276787703475ssThan @ A @ Y @ X ) )
= X ) ) ) ).
% cSup_greaterThanLessThan
thf(fact_4327_Sup__greaterThanLessThan,axiom,
! [A: $tType] :
( ( ( comple6319245703460814977attice @ A )
& ( dense_linorder @ A ) )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( ( complete_Sup_Sup @ A @ ( set_or5935395276787703475ssThan @ A @ X @ Y ) )
= Y ) ) ) ).
% Sup_greaterThanLessThan
thf(fact_4328_cInf__greaterThanLessThan,axiom,
! [A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( dense_linorder @ A ) )
=> ! [Y: A,X: A] :
( ( ord_less @ A @ Y @ X )
=> ( ( complete_Inf_Inf @ A @ ( set_or5935395276787703475ssThan @ A @ Y @ X ) )
= Y ) ) ) ).
% cInf_greaterThanLessThan
thf(fact_4329_Inf__greaterThanLessThan,axiom,
! [A: $tType] :
( ( ( comple6319245703460814977attice @ A )
& ( dense_linorder @ A ) )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( ( complete_Inf_Inf @ A @ ( set_or5935395276787703475ssThan @ A @ X @ Y ) )
= X ) ) ) ).
% Inf_greaterThanLessThan
thf(fact_4330_infinite__Ioo,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ~ ( finite_finite @ A @ ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) ) ) ) ).
% infinite_Ioo
thf(fact_4331_greaterThanLessThan__subseteq__greaterThanLessThan,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) @ ( set_or5935395276787703475ssThan @ A @ C2 @ D2 ) )
= ( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less_eq @ A @ B2 @ D2 ) ) ) ) ) ).
% greaterThanLessThan_subseteq_greaterThanLessThan
thf(fact_4332_ivl__disj__int__two_I4_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,M: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ L @ M ) @ ( set_or5935395276787703475ssThan @ A @ M @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_two(4)
thf(fact_4333_ivl__disj__int__two_I5_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,M: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ L @ M ) @ ( set_or1337092689740270186AtMost @ A @ M @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_two(5)
thf(fact_4334_ivl__disj__int__two_I1_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,M: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ L @ M ) @ ( set_or7035219750837199246ssThan @ A @ M @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_two(1)
thf(fact_4335_ivl__disj__int__one_I1_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_ord_atMost @ A @ L ) @ ( set_or5935395276787703475ssThan @ A @ L @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_one(1)
thf(fact_4336_greaterThanLessThan__subseteq__atLeastAtMost__iff,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) @ ( set_or1337092689740270186AtMost @ A @ C2 @ D2 ) )
= ( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less_eq @ A @ B2 @ D2 ) ) ) ) ) ).
% greaterThanLessThan_subseteq_atLeastAtMost_iff
thf(fact_4337_greaterThanLessThan__subseteq__atLeastLessThan__iff,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) @ ( set_or7035219750837199246ssThan @ A @ C2 @ D2 ) )
= ( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less_eq @ A @ B2 @ D2 ) ) ) ) ) ).
% greaterThanLessThan_subseteq_atLeastLessThan_iff
thf(fact_4338_atLeastAtMost__diff__ends,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( minus_minus @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ ( insert2 @ A @ A3 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) ) ) ).
% atLeastAtMost_diff_ends
thf(fact_4339_mlex__less,axiom,
! [A: $tType,F2: A > nat,X: A,Y: A,R: set @ ( product_prod @ A @ A )] :
( ( ord_less @ nat @ ( F2 @ X ) @ ( F2 @ Y ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( mlex_prod @ A @ F2 @ R ) ) ) ).
% mlex_less
thf(fact_4340_in__measure,axiom,
! [A: $tType,X: A,Y: A,F2: A > nat] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( measure @ A @ F2 ) )
= ( ord_less @ nat @ ( F2 @ X ) @ ( F2 @ Y ) ) ) ).
% in_measure
thf(fact_4341_termdiffs__aux,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [C2: nat > A,K5: A,X: A] :
( ( summable @ A
@ ^ [N: nat] : ( times_times @ A @ ( diffs @ A @ ( diffs @ A @ C2 ) @ N ) @ ( power_power @ A @ K5 @ N ) ) )
=> ( ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ X ) @ ( real_V7770717601297561774m_norm @ A @ K5 ) )
=> ( filterlim @ A @ A
@ ^ [H: A] :
( suminf @ A
@ ^ [N: nat] : ( times_times @ A @ ( C2 @ N ) @ ( minus_minus @ A @ ( divide_divide @ A @ ( minus_minus @ A @ ( power_power @ A @ ( plus_plus @ A @ X @ H ) @ N ) @ ( power_power @ A @ X @ N ) ) @ H ) @ ( times_times @ A @ ( semiring_1_of_nat @ A @ N ) @ ( power_power @ A @ X @ ( minus_minus @ nat @ N @ ( suc @ ( zero_zero @ nat ) ) ) ) ) ) ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ).
% termdiffs_aux
thf(fact_4342_lex__prod__def,axiom,
! [B: $tType,A: $tType] :
( ( lex_prod @ A @ B )
= ( ^ [Ra: set @ ( product_prod @ A @ A ),Rb: set @ ( product_prod @ B @ B )] :
( collect @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) )
@ ( product_case_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ $o
@ ( product_case_prod @ A @ B @ ( ( product_prod @ A @ B ) > $o )
@ ^ [A5: A,B4: B] :
( product_case_prod @ A @ B @ $o
@ ^ [A11: A,B11: B] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A5 @ A11 ) @ Ra )
| ( ( A5 = A11 )
& ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ B4 @ B11 ) @ Rb ) ) ) ) ) ) ) ) ) ).
% lex_prod_def
thf(fact_4343_image__Fpow__mono,axiom,
! [B: $tType,A: $tType,F2: B > A,A4: set @ B,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ F2 @ A4 ) @ B3 )
=> ( ord_less_eq @ ( set @ ( set @ A ) ) @ ( image2 @ ( set @ B ) @ ( set @ A ) @ ( image2 @ B @ A @ F2 ) @ ( finite_Fpow @ B @ A4 ) ) @ ( finite_Fpow @ A @ B3 ) ) ) ).
% image_Fpow_mono
thf(fact_4344_card__greaterThanLessThan,axiom,
! [L: nat,U: nat] :
( ( finite_card @ nat @ ( set_or5935395276787703475ssThan @ nat @ L @ U ) )
= ( minus_minus @ nat @ U @ ( suc @ L ) ) ) ).
% card_greaterThanLessThan
thf(fact_4345_in__lex__prod,axiom,
! [A: $tType,B: $tType,A3: A,B2: B,A8: A,B7: B,R2: set @ ( product_prod @ A @ A ),S: set @ ( product_prod @ B @ B )] :
( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ ( product_Pair @ A @ B @ A8 @ B7 ) ) @ ( lex_prod @ A @ B @ R2 @ S ) )
= ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ A8 ) @ R2 )
| ( ( A3 = A8 )
& ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ B2 @ B7 ) @ S ) ) ) ) ).
% in_lex_prod
thf(fact_4346_tendsto__mult__right__iff,axiom,
! [A: $tType,B: $tType] :
( ( ( field @ A )
& ( topolo4211221413907600880p_mult @ A ) )
=> ! [C2: A,F2: B > A,L: A,F5: filter @ B] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( filterlim @ B @ A
@ ^ [X2: B] : ( times_times @ A @ ( F2 @ X2 ) @ C2 )
@ ( topolo7230453075368039082e_nhds @ A @ ( times_times @ A @ L @ C2 ) )
@ F5 )
= ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ F5 ) ) ) ) ).
% tendsto_mult_right_iff
thf(fact_4347_tendsto__mult__left__iff,axiom,
! [A: $tType,B: $tType] :
( ( ( field @ A )
& ( topolo4211221413907600880p_mult @ A ) )
=> ! [C2: A,F2: B > A,L: A,F5: filter @ B] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( filterlim @ B @ A
@ ^ [X2: B] : ( times_times @ A @ C2 @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( times_times @ A @ C2 @ L ) )
@ F5 )
= ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ F5 ) ) ) ) ).
% tendsto_mult_left_iff
thf(fact_4348_power__tendsto__0__iff,axiom,
! [A: $tType,N2: nat,F2: A > real,F5: filter @ A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( filterlim @ A @ real
@ ^ [X2: A] : ( power_power @ real @ ( F2 @ X2 ) @ N2 )
@ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) )
@ F5 )
= ( filterlim @ A @ real @ F2 @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ F5 ) ) ) ).
% power_tendsto_0_iff
thf(fact_4349_tendsto__inverse,axiom,
! [A: $tType,B: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [F2: B > A,A3: A,F5: filter @ B] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
=> ( ( A3
!= ( zero_zero @ A ) )
=> ( filterlim @ B @ A
@ ^ [X2: B] : ( inverse_inverse @ A @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( inverse_inverse @ A @ A3 ) )
@ F5 ) ) ) ) ).
% tendsto_inverse
thf(fact_4350_tendsto__Pair,axiom,
! [C: $tType,B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ B )
& ( topolo4958980785337419405_space @ C ) )
=> ! [F2: A > B,A3: B,F5: filter @ A,G: A > C,B2: C] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ A3 ) @ F5 )
=> ( ( filterlim @ A @ C @ G @ ( topolo7230453075368039082e_nhds @ C @ B2 ) @ F5 )
=> ( filterlim @ A @ ( product_prod @ B @ C )
@ ^ [X2: A] : ( product_Pair @ B @ C @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ ( product_prod @ B @ C ) @ ( product_Pair @ B @ C @ A3 @ B2 ) )
@ F5 ) ) ) ) ).
% tendsto_Pair
thf(fact_4351_tendsto__max,axiom,
! [A: $tType,B: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [X7: B > A,X: A,Net: filter @ B,Y6: B > A,Y: A] :
( ( filterlim @ B @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ Net )
=> ( ( filterlim @ B @ A @ Y6 @ ( topolo7230453075368039082e_nhds @ A @ Y ) @ Net )
=> ( filterlim @ B @ A
@ ^ [X2: B] : ( ord_max @ A @ ( X7 @ X2 ) @ ( Y6 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( ord_max @ A @ X @ Y ) )
@ Net ) ) ) ) ).
% tendsto_max
thf(fact_4352_tendsto__mult__right__zero,axiom,
! [A: $tType,D: $tType] :
( ( real_V4412858255891104859lgebra @ A )
=> ! [F2: D > A,F5: filter @ D,C2: A] :
( ( filterlim @ D @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ F5 )
=> ( filterlim @ D @ A
@ ^ [X2: D] : ( times_times @ A @ C2 @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ F5 ) ) ) ).
% tendsto_mult_right_zero
thf(fact_4353_tendsto__mult__left__zero,axiom,
! [A: $tType,D: $tType] :
( ( real_V4412858255891104859lgebra @ A )
=> ! [F2: D > A,F5: filter @ D,C2: A] :
( ( filterlim @ D @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ F5 )
=> ( filterlim @ D @ A
@ ^ [X2: D] : ( times_times @ A @ ( F2 @ X2 ) @ C2 )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ F5 ) ) ) ).
% tendsto_mult_left_zero
thf(fact_4354_tendsto__mult__zero,axiom,
! [A: $tType,D: $tType] :
( ( real_V4412858255891104859lgebra @ A )
=> ! [F2: D > A,F5: filter @ D,G: D > A] :
( ( filterlim @ D @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ F5 )
=> ( ( filterlim @ D @ A @ G @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ F5 )
=> ( filterlim @ D @ A
@ ^ [X2: D] : ( times_times @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ F5 ) ) ) ) ).
% tendsto_mult_zero
thf(fact_4355_tendsto__add__zero,axiom,
! [B: $tType,D: $tType] :
( ( topolo6943815403480290642id_add @ B )
=> ! [F2: D > B,F5: filter @ D,G: D > B] :
( ( filterlim @ D @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) ) @ F5 )
=> ( ( filterlim @ D @ B @ G @ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) ) @ F5 )
=> ( filterlim @ D @ B
@ ^ [X2: D] : ( plus_plus @ B @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ F5 ) ) ) ) ).
% tendsto_add_zero
thf(fact_4356_LIM__zero,axiom,
! [B: $tType,A: $tType] :
( ( real_V822414075346904944vector @ B )
=> ! [F2: A > B,L: B,F5: filter @ A] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L ) @ F5 )
=> ( filterlim @ A @ B
@ ^ [X2: A] : ( minus_minus @ B @ ( F2 @ X2 ) @ L )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ F5 ) ) ) ).
% LIM_zero
thf(fact_4357_LIM__zero__iff,axiom,
! [B: $tType,A: $tType] :
( ( real_V822414075346904944vector @ B )
=> ! [F2: A > B,L: B,F5: filter @ A] :
( ( filterlim @ A @ B
@ ^ [X2: A] : ( minus_minus @ B @ ( F2 @ X2 ) @ L )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ F5 )
= ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L ) @ F5 ) ) ) ).
% LIM_zero_iff
thf(fact_4358_Lim__transform,axiom,
! [A: $tType,B: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [G: B > A,A3: A,F5: filter @ B,F2: B > A] :
( ( filterlim @ B @ A @ G @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
=> ( ( filterlim @ B @ A
@ ^ [X2: B] : ( minus_minus @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ F5 )
=> ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 ) ) ) ) ).
% Lim_transform
thf(fact_4359_Lim__transform2,axiom,
! [A: $tType,B: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: B > A,A3: A,F5: filter @ B,G: B > A] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
=> ( ( filterlim @ B @ A
@ ^ [X2: B] : ( minus_minus @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ F5 )
=> ( filterlim @ B @ A @ G @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 ) ) ) ) ).
% Lim_transform2
thf(fact_4360_LIM__zero__cancel,axiom,
! [B: $tType,A: $tType] :
( ( real_V822414075346904944vector @ B )
=> ! [F2: A > B,L: B,F5: filter @ A] :
( ( filterlim @ A @ B
@ ^ [X2: A] : ( minus_minus @ B @ ( F2 @ X2 ) @ L )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ F5 )
=> ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L ) @ F5 ) ) ) ).
% LIM_zero_cancel
thf(fact_4361_Lim__transform__eq,axiom,
! [A: $tType,B: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: B > A,G: B > A,F5: filter @ B,A3: A] :
( ( filterlim @ B @ A
@ ^ [X2: B] : ( minus_minus @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ F5 )
=> ( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
= ( filterlim @ B @ A @ G @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 ) ) ) ) ).
% Lim_transform_eq
thf(fact_4362_tendsto__add__const__iff,axiom,
! [A: $tType,B: $tType] :
( ( topolo1633459387980952147up_add @ A )
=> ! [C2: A,F2: B > A,D2: A,F5: filter @ B] :
( ( filterlim @ B @ A
@ ^ [X2: B] : ( plus_plus @ A @ C2 @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( plus_plus @ A @ C2 @ D2 ) )
@ F5 )
= ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ D2 ) @ F5 ) ) ) ).
% tendsto_add_const_iff
thf(fact_4363_tendsto__add,axiom,
! [A: $tType,B: $tType] :
( ( topolo6943815403480290642id_add @ A )
=> ! [F2: B > A,A3: A,F5: filter @ B,G: B > A,B2: A] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
=> ( ( filterlim @ B @ A @ G @ ( topolo7230453075368039082e_nhds @ A @ B2 ) @ F5 )
=> ( filterlim @ B @ A
@ ^ [X2: B] : ( plus_plus @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( plus_plus @ A @ A3 @ B2 ) )
@ F5 ) ) ) ) ).
% tendsto_add
thf(fact_4364_tendsto__norm__zero__cancel,axiom,
! [B: $tType,A: $tType] :
( ( real_V822414075346904944vector @ B )
=> ! [F2: A > B,F5: filter @ A] :
( ( filterlim @ A @ real
@ ^ [X2: A] : ( real_V7770717601297561774m_norm @ B @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) )
@ F5 )
=> ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) ) @ F5 ) ) ) ).
% tendsto_norm_zero_cancel
thf(fact_4365_tendsto__norm__zero__iff,axiom,
! [B: $tType,A: $tType] :
( ( real_V822414075346904944vector @ B )
=> ! [F2: A > B,F5: filter @ A] :
( ( filterlim @ A @ real
@ ^ [X2: A] : ( real_V7770717601297561774m_norm @ B @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) )
@ F5 )
= ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) ) @ F5 ) ) ) ).
% tendsto_norm_zero_iff
thf(fact_4366_tendsto__norm__zero,axiom,
! [B: $tType,A: $tType] :
( ( real_V822414075346904944vector @ B )
=> ! [F2: A > B,F5: filter @ A] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) ) @ F5 )
=> ( filterlim @ A @ real
@ ^ [X2: A] : ( real_V7770717601297561774m_norm @ B @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) )
@ F5 ) ) ) ).
% tendsto_norm_zero
thf(fact_4367_tendsto__divide,axiom,
! [A: $tType,B: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: B > A,A3: A,F5: filter @ B,G: B > A,B2: A] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
=> ( ( filterlim @ B @ A @ G @ ( topolo7230453075368039082e_nhds @ A @ B2 ) @ F5 )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( filterlim @ B @ A
@ ^ [X2: B] : ( divide_divide @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( divide_divide @ A @ A3 @ B2 ) )
@ F5 ) ) ) ) ) ).
% tendsto_divide
thf(fact_4368_tendsto__divide__zero,axiom,
! [A: $tType,B: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: B > A,F5: filter @ B,C2: A] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ F5 )
=> ( filterlim @ B @ A
@ ^ [X2: B] : ( divide_divide @ A @ ( F2 @ X2 ) @ C2 )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ F5 ) ) ) ).
% tendsto_divide_zero
thf(fact_4369_tendsto__sgn,axiom,
! [A: $tType,B: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: B > A,L: A,F5: filter @ B] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ F5 )
=> ( ( L
!= ( zero_zero @ A ) )
=> ( filterlim @ B @ A
@ ^ [X2: B] : ( sgn_sgn @ A @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( sgn_sgn @ A @ L ) )
@ F5 ) ) ) ) ).
% tendsto_sgn
thf(fact_4370_tendsto__null__sum,axiom,
! [C: $tType,B: $tType,A: $tType] :
( ( topolo5987344860129210374id_add @ C )
=> ! [I6: set @ B,F2: A > B > C,F5: filter @ A] :
( ! [I3: B] :
( ( member2 @ B @ I3 @ I6 )
=> ( filterlim @ A @ C
@ ^ [X2: A] : ( F2 @ X2 @ I3 )
@ ( topolo7230453075368039082e_nhds @ C @ ( zero_zero @ C ) )
@ F5 ) )
=> ( filterlim @ A @ C
@ ^ [I5: A] : ( groups7311177749621191930dd_sum @ B @ C @ ( F2 @ I5 ) @ I6 )
@ ( topolo7230453075368039082e_nhds @ C @ ( zero_zero @ C ) )
@ F5 ) ) ) ).
% tendsto_null_sum
thf(fact_4371_nhds__neq__bot,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [A3: A] :
( ( topolo7230453075368039082e_nhds @ A @ A3 )
!= ( bot_bot @ ( filter @ A ) ) ) ) ).
% nhds_neq_bot
thf(fact_4372_tendsto__bot,axiom,
! [A: $tType,B: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [F2: B > A,A3: A] : ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ ( bot_bot @ ( filter @ B ) ) ) ) ).
% tendsto_bot
thf(fact_4373_tendsto__unique,axiom,
! [B: $tType,A: $tType] :
( ( topological_t2_space @ A )
=> ! [F5: filter @ B,F2: B > A,A3: A,B2: A] :
( ( F5
!= ( bot_bot @ ( filter @ B ) ) )
=> ( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
=> ( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ B2 ) @ F5 )
=> ( A3 = B2 ) ) ) ) ) ).
% tendsto_unique
thf(fact_4374_tendsto__const__iff,axiom,
! [B: $tType,A: $tType] :
( ( topological_t2_space @ A )
=> ! [F5: filter @ B,A3: A,B2: A] :
( ( F5
!= ( bot_bot @ ( filter @ B ) ) )
=> ( ( filterlim @ B @ A
@ ^ [X2: B] : A3
@ ( topolo7230453075368039082e_nhds @ A @ B2 )
@ F5 )
= ( A3 = B2 ) ) ) ) ).
% tendsto_const_iff
thf(fact_4375_LIM__not__zero,axiom,
! [Aa: $tType,A: $tType] :
( ( ( topolo8386298272705272623_space @ A )
& ( zero @ Aa )
& ( topological_t2_space @ Aa ) )
=> ! [K: Aa,A3: A] :
( ( K
!= ( zero_zero @ Aa ) )
=> ~ ( filterlim @ A @ Aa
@ ^ [X2: A] : K
@ ( topolo7230453075368039082e_nhds @ Aa @ ( zero_zero @ Aa ) )
@ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% LIM_not_zero
thf(fact_4376_tendsto__tan,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [F2: A > A,A3: A,F5: filter @ A] :
( ( filterlim @ A @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
=> ( ( ( cos @ A @ A3 )
!= ( zero_zero @ A ) )
=> ( filterlim @ A @ A
@ ^ [X2: A] : ( tan @ A @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( tan @ A @ A3 ) )
@ F5 ) ) ) ) ).
% tendsto_tan
thf(fact_4377_tendsto__cot,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [F2: A > A,A3: A,F5: filter @ A] :
( ( filterlim @ A @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
=> ( ( ( sin @ A @ A3 )
!= ( zero_zero @ A ) )
=> ( filterlim @ A @ A
@ ^ [X2: A] : ( cot @ A @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( cot @ A @ A3 ) )
@ F5 ) ) ) ) ).
% tendsto_cot
thf(fact_4378_tendsto__tanh,axiom,
! [A: $tType,C: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [F2: C > A,A3: A,F5: filter @ C] :
( ( filterlim @ C @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
=> ( ( ( cosh @ A @ A3 )
!= ( zero_zero @ A ) )
=> ( filterlim @ C @ A
@ ^ [X2: C] : ( tanh @ A @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( tanh @ A @ A3 ) )
@ F5 ) ) ) ) ).
% tendsto_tanh
thf(fact_4379_tendsto__within__subset,axiom,
! [B: $tType,A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [F2: A > B,L: filter @ B,X: A,S3: set @ A,T4: set @ A] :
( ( filterlim @ A @ B @ F2 @ L @ ( topolo174197925503356063within @ A @ X @ S3 ) )
=> ( ( ord_less_eq @ ( set @ A ) @ T4 @ S3 )
=> ( filterlim @ A @ B @ F2 @ L @ ( topolo174197925503356063within @ A @ X @ T4 ) ) ) ) ) ).
% tendsto_within_subset
thf(fact_4380_LIM__isCont__iff,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [F2: A > B,A3: A] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( F2 @ A3 ) ) @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) )
= ( filterlim @ A @ B
@ ^ [H: A] : ( F2 @ ( plus_plus @ A @ A3 @ H ) )
@ ( topolo7230453075368039082e_nhds @ B @ ( F2 @ A3 ) )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% LIM_isCont_iff
thf(fact_4381_LIM__offset__zero,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [F2: A > B,L5: B,A3: A] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L5 ) @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) )
=> ( filterlim @ A @ B
@ ^ [H: A] : ( F2 @ ( plus_plus @ A @ A3 @ H ) )
@ ( topolo7230453075368039082e_nhds @ B @ L5 )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% LIM_offset_zero
thf(fact_4382_LIM__offset__zero__cancel,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [F2: A > B,A3: A,L5: B] :
( ( filterlim @ A @ B
@ ^ [H: A] : ( F2 @ ( plus_plus @ A @ A3 @ H ) )
@ ( topolo7230453075368039082e_nhds @ B @ L5 )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) )
=> ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L5 ) @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% LIM_offset_zero_cancel
thf(fact_4383_tendsto__null__power,axiom,
! [B: $tType,A: $tType] :
( ( real_V2822296259951069270ebra_1 @ B )
=> ! [F2: A > B,F5: filter @ A,N2: nat] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) ) @ F5 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( filterlim @ A @ B
@ ^ [X2: A] : ( power_power @ B @ ( F2 @ X2 ) @ N2 )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ F5 ) ) ) ) ).
% tendsto_null_power
thf(fact_4384_LIM__offset,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [F2: A > B,L5: B,A3: A,K: A] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L5 ) @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) )
=> ( filterlim @ A @ B
@ ^ [X2: A] : ( F2 @ ( plus_plus @ A @ X2 @ K ) )
@ ( topolo7230453075368039082e_nhds @ B @ L5 )
@ ( topolo174197925503356063within @ A @ ( minus_minus @ A @ A3 @ K ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% LIM_offset
thf(fact_4385_empty__in__Fpow,axiom,
! [A: $tType,A4: set @ A] : ( member2 @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) @ ( finite_Fpow @ A @ A4 ) ) ).
% empty_in_Fpow
thf(fact_4386_atLeastSucLessThan__greaterThanLessThan,axiom,
! [L: nat,U: nat] :
( ( set_or7035219750837199246ssThan @ nat @ ( suc @ L ) @ U )
= ( set_or5935395276787703475ssThan @ nat @ L @ U ) ) ).
% atLeastSucLessThan_greaterThanLessThan
thf(fact_4387_Fpow__not__empty,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_Fpow @ A @ A4 )
!= ( bot_bot @ ( set @ ( set @ A ) ) ) ) ).
% Fpow_not_empty
thf(fact_4388_DERIV__LIM__iff,axiom,
! [A: $tType] :
( ( ( inverse @ A )
& ( real_V822414075346904944vector @ A ) )
=> ! [F2: A > A,A3: A,D6: A] :
( ( filterlim @ A @ A
@ ^ [H: A] : ( divide_divide @ A @ ( minus_minus @ A @ ( F2 @ ( plus_plus @ A @ A3 @ H ) ) @ ( F2 @ A3 ) ) @ H )
@ ( topolo7230453075368039082e_nhds @ A @ D6 )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) )
= ( filterlim @ A @ A
@ ^ [X2: A] : ( divide_divide @ A @ ( minus_minus @ A @ ( F2 @ X2 ) @ ( F2 @ A3 ) ) @ ( minus_minus @ A @ X2 @ A3 ) )
@ ( topolo7230453075368039082e_nhds @ A @ D6 )
@ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% DERIV_LIM_iff
thf(fact_4389_DERIV__D,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D6: A,X: A] :
( ( has_field_derivative @ A @ F2 @ D6 @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) )
=> ( filterlim @ A @ A
@ ^ [H: A] : ( divide_divide @ A @ ( minus_minus @ A @ ( F2 @ ( plus_plus @ A @ X @ H ) ) @ ( F2 @ X ) ) @ H )
@ ( topolo7230453075368039082e_nhds @ A @ D6 )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% DERIV_D
thf(fact_4390_DERIV__def,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D6: A,X: A] :
( ( has_field_derivative @ A @ F2 @ D6 @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) )
= ( filterlim @ A @ A
@ ^ [H: A] : ( divide_divide @ A @ ( minus_minus @ A @ ( F2 @ ( plus_plus @ A @ X @ H ) ) @ ( F2 @ X ) ) @ H )
@ ( topolo7230453075368039082e_nhds @ A @ D6 )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% DERIV_def
thf(fact_4391_lim__exp__minus__1,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ( filterlim @ A @ A
@ ^ [Z6: A] : ( divide_divide @ A @ ( minus_minus @ A @ ( exp @ A @ Z6 ) @ ( one_one @ A ) ) @ Z6 )
@ ( topolo7230453075368039082e_nhds @ A @ ( one_one @ A ) )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ).
% lim_exp_minus_1
thf(fact_4392_lemma__termdiff4,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [K: real,F2: A > B,K5: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ K )
=> ( ! [H5: A] :
( ( H5
!= ( zero_zero @ A ) )
=> ( ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ H5 ) @ K )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ B @ ( F2 @ H5 ) ) @ ( times_times @ real @ K5 @ ( real_V7770717601297561774m_norm @ A @ H5 ) ) ) ) )
=> ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) ) @ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ).
% lemma_termdiff4
thf(fact_4393_Fpow__mono,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ ( set @ ( set @ A ) ) @ ( finite_Fpow @ A @ A4 ) @ ( finite_Fpow @ A @ B3 ) ) ) ).
% Fpow_mono
thf(fact_4394_filterlim__at__to__0,axiom,
! [B: $tType,A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: A > B,F5: filter @ B,A3: A] :
( ( filterlim @ A @ B @ F2 @ F5 @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) )
= ( filterlim @ A @ B
@ ^ [X2: A] : ( F2 @ ( plus_plus @ A @ X2 @ A3 ) )
@ F5
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% filterlim_at_to_0
thf(fact_4395_nth__sorted__list__of__set__greaterThanLessThan,axiom,
! [N2: nat,J: nat,I: nat] :
( ( ord_less @ nat @ N2 @ ( minus_minus @ nat @ J @ ( suc @ I ) ) )
=> ( ( nth @ nat @ ( linord4507533701916653071of_set @ nat @ ( set_or5935395276787703475ssThan @ nat @ I @ J ) ) @ N2 )
= ( suc @ ( plus_plus @ nat @ I @ N2 ) ) ) ) ).
% nth_sorted_list_of_set_greaterThanLessThan
thf(fact_4396_Fpow__def,axiom,
! [A: $tType] :
( ( finite_Fpow @ A )
= ( ^ [A6: set @ A] :
( collect @ ( set @ A )
@ ^ [X8: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ X8 @ A6 )
& ( finite_finite @ A @ X8 ) ) ) ) ) ).
% Fpow_def
thf(fact_4397_powser__limit__0__strong,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [S: real,A3: nat > A,F2: A > A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ S )
=> ( ! [X5: A] :
( ( X5
!= ( zero_zero @ A ) )
=> ( ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ X5 ) @ S )
=> ( sums @ A
@ ^ [N: nat] : ( times_times @ A @ ( A3 @ N ) @ ( power_power @ A @ X5 @ N ) )
@ ( F2 @ X5 ) ) ) )
=> ( filterlim @ A @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ ( A3 @ ( zero_zero @ nat ) ) ) @ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ).
% powser_limit_0_strong
thf(fact_4398_powser__limit__0,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [S: real,A3: nat > A,F2: A > A] :
( ( ord_less @ real @ ( zero_zero @ real ) @ S )
=> ( ! [X5: A] :
( ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ X5 ) @ S )
=> ( sums @ A
@ ^ [N: nat] : ( times_times @ A @ ( A3 @ N ) @ ( power_power @ A @ X5 @ N ) )
@ ( F2 @ X5 ) ) )
=> ( filterlim @ A @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ ( A3 @ ( zero_zero @ nat ) ) ) @ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ).
% powser_limit_0
thf(fact_4399_lemma__termdiff5,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_Vector_banach @ B ) )
=> ! [K: real,F2: nat > real,G: A > nat > B] :
( ( ord_less @ real @ ( zero_zero @ real ) @ K )
=> ( ( summable @ real @ F2 )
=> ( ! [H5: A,N3: nat] :
( ( H5
!= ( zero_zero @ A ) )
=> ( ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ H5 ) @ K )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ B @ ( G @ H5 @ N3 ) ) @ ( times_times @ real @ ( F2 @ N3 ) @ ( real_V7770717601297561774m_norm @ A @ H5 ) ) ) ) )
=> ( filterlim @ A @ B
@ ^ [H: A] : ( suminf @ B @ ( G @ H ) )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ) ).
% lemma_termdiff5
thf(fact_4400_summable__Leibniz_I3_J,axiom,
! [A3: nat > real] :
( ( filterlim @ nat @ real @ A3 @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ ( at_top @ nat ) )
=> ( ( topological_monoseq @ real @ A3 )
=> ( ( ord_less @ real @ ( A3 @ ( zero_zero @ nat ) ) @ ( zero_zero @ real ) )
=> ! [N5: nat] :
( member2 @ real
@ ( suminf @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) ) )
@ ( set_or1337092689740270186AtMost @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N5 ) @ ( one_one @ nat ) ) ) )
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N5 ) ) ) ) ) ) ) ) ).
% summable_Leibniz(3)
thf(fact_4401_summable__Leibniz_I2_J,axiom,
! [A3: nat > real] :
( ( filterlim @ nat @ real @ A3 @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ ( at_top @ nat ) )
=> ( ( topological_monoseq @ real @ A3 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ ( A3 @ ( zero_zero @ nat ) ) )
=> ! [N5: nat] :
( member2 @ real
@ ( suminf @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) ) )
@ ( set_or1337092689740270186AtMost @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N5 ) ) )
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N5 ) @ ( one_one @ nat ) ) ) ) ) ) ) ) ) ).
% summable_Leibniz(2)
thf(fact_4402_summable__Leibniz_H_I5_J,axiom,
! [A3: nat > real] :
( ( filterlim @ nat @ real @ A3 @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ ( at_top @ nat ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( zero_zero @ real ) @ ( A3 @ N3 ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( A3 @ ( suc @ N3 ) ) @ ( A3 @ N3 ) )
=> ( filterlim @ nat @ real
@ ^ [N: nat] :
( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) @ ( one_one @ nat ) ) ) )
@ ( topolo7230453075368039082e_nhds @ real
@ ( suminf @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) ) ) )
@ ( at_top @ nat ) ) ) ) ) ).
% summable_Leibniz'(5)
thf(fact_4403_summable__Leibniz_H_I4_J,axiom,
! [A3: nat > real,N2: nat] :
( ( filterlim @ nat @ real @ A3 @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ ( at_top @ nat ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( zero_zero @ real ) @ ( A3 @ N3 ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( A3 @ ( suc @ N3 ) ) @ ( A3 @ N3 ) )
=> ( ord_less_eq @ real
@ ( suminf @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) ) )
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) @ ( one_one @ nat ) ) ) ) ) ) ) ) ).
% summable_Leibniz'(4)
thf(fact_4404_trivial__limit__sequentially,axiom,
( ( at_top @ nat )
!= ( bot_bot @ ( filter @ nat ) ) ) ).
% trivial_limit_sequentially
thf(fact_4405_tendsto__zero__mult__right__iff,axiom,
! [A: $tType] :
( ( ( field @ A )
& ( topolo4211221413907600880p_mult @ A ) )
=> ! [C2: A,A3: nat > A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( filterlim @ nat @ A
@ ^ [N: nat] : ( times_times @ A @ ( A3 @ N ) @ C2 )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ ( at_top @ nat ) )
= ( filterlim @ nat @ A @ A3 @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ ( at_top @ nat ) ) ) ) ) ).
% tendsto_zero_mult_right_iff
thf(fact_4406_tendsto__zero__mult__left__iff,axiom,
! [A: $tType] :
( ( ( field @ A )
& ( topolo4211221413907600880p_mult @ A ) )
=> ! [C2: A,A3: nat > A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( filterlim @ nat @ A
@ ^ [N: nat] : ( times_times @ A @ C2 @ ( A3 @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ ( at_top @ nat ) )
= ( filterlim @ nat @ A @ A3 @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ ( at_top @ nat ) ) ) ) ) ).
% tendsto_zero_mult_left_iff
thf(fact_4407_tendsto__zero__divide__iff,axiom,
! [A: $tType] :
( ( ( field @ A )
& ( topolo4211221413907600880p_mult @ A ) )
=> ! [C2: A,A3: nat > A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( filterlim @ nat @ A
@ ^ [N: nat] : ( divide_divide @ A @ ( A3 @ N ) @ C2 )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ ( at_top @ nat ) )
= ( filterlim @ nat @ A @ A3 @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ ( at_top @ nat ) ) ) ) ) ).
% tendsto_zero_divide_iff
thf(fact_4408_filterlim__sequentially__Suc,axiom,
! [A: $tType,F2: nat > A,F5: filter @ A] :
( ( filterlim @ nat @ A
@ ^ [X2: nat] : ( F2 @ ( suc @ X2 ) )
@ F5
@ ( at_top @ nat ) )
= ( filterlim @ nat @ A @ F2 @ F5 @ ( at_top @ nat ) ) ) ).
% filterlim_sequentially_Suc
thf(fact_4409_filterlim__Suc,axiom,
filterlim @ nat @ nat @ suc @ ( at_top @ nat ) @ ( at_top @ nat ) ).
% filterlim_Suc
thf(fact_4410_trivial__limit__at__top__linorder,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( at_top @ A )
!= ( bot_bot @ ( filter @ A ) ) ) ) ).
% trivial_limit_at_top_linorder
thf(fact_4411_approx__from__below__dense__linorder,axiom,
! [A: $tType] :
( ( ( dense_linorder @ A )
& ( topolo3112930676232923870pology @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [Y: A,X: A] :
( ( ord_less @ A @ Y @ X )
=> ? [U4: nat > A] :
( ! [N5: nat] : ( ord_less @ A @ ( U4 @ N5 ) @ X )
& ( filterlim @ nat @ A @ U4 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ ( at_top @ nat ) ) ) ) ) ).
% approx_from_below_dense_linorder
thf(fact_4412_approx__from__above__dense__linorder,axiom,
! [A: $tType] :
( ( ( dense_linorder @ A )
& ( topolo3112930676232923870pology @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ? [U4: nat > A] :
( ! [N5: nat] : ( ord_less @ A @ X @ ( U4 @ N5 ) )
& ( filterlim @ nat @ A @ U4 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ ( at_top @ nat ) ) ) ) ) ).
% approx_from_above_dense_linorder
thf(fact_4413_LIMSEQ__Suc,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [F2: nat > A,L: A] :
( ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ ( at_top @ nat ) )
=> ( filterlim @ nat @ A
@ ^ [N: nat] : ( F2 @ ( suc @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ L )
@ ( at_top @ nat ) ) ) ) ).
% LIMSEQ_Suc
thf(fact_4414_LIMSEQ__imp__Suc,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [F2: nat > A,L: A] :
( ( filterlim @ nat @ A
@ ^ [N: nat] : ( F2 @ ( suc @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ L )
@ ( at_top @ nat ) )
=> ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ ( at_top @ nat ) ) ) ) ).
% LIMSEQ_imp_Suc
thf(fact_4415_LIMSEQ__offset,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [F2: nat > A,K: nat,A3: A] :
( ( filterlim @ nat @ A
@ ^ [N: nat] : ( F2 @ ( plus_plus @ nat @ N @ K ) )
@ ( topolo7230453075368039082e_nhds @ A @ A3 )
@ ( at_top @ nat ) )
=> ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ ( at_top @ nat ) ) ) ) ).
% LIMSEQ_offset
thf(fact_4416_LIMSEQ__ignore__initial__segment,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [F2: nat > A,A3: A,K: nat] :
( ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ ( at_top @ nat ) )
=> ( filterlim @ nat @ A
@ ^ [N: nat] : ( F2 @ ( plus_plus @ nat @ N @ K ) )
@ ( topolo7230453075368039082e_nhds @ A @ A3 )
@ ( at_top @ nat ) ) ) ) ).
% LIMSEQ_ignore_initial_segment
thf(fact_4417_lim__mono,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [N7: nat,X7: nat > A,Y6: nat > A,X: A,Y: A] :
( ! [N3: nat] :
( ( ord_less_eq @ nat @ N7 @ N3 )
=> ( ord_less_eq @ A @ ( X7 @ N3 ) @ ( Y6 @ N3 ) ) )
=> ( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ ( at_top @ nat ) )
=> ( ( filterlim @ nat @ A @ Y6 @ ( topolo7230453075368039082e_nhds @ A @ Y ) @ ( at_top @ nat ) )
=> ( ord_less_eq @ A @ X @ Y ) ) ) ) ) ).
% lim_mono
thf(fact_4418_LIMSEQ__le,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [X7: nat > A,X: A,Y6: nat > A,Y: A] :
( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ ( at_top @ nat ) )
=> ( ( filterlim @ nat @ A @ Y6 @ ( topolo7230453075368039082e_nhds @ A @ Y ) @ ( at_top @ nat ) )
=> ( ? [N8: nat] :
! [N3: nat] :
( ( ord_less_eq @ nat @ N8 @ N3 )
=> ( ord_less_eq @ A @ ( X7 @ N3 ) @ ( Y6 @ N3 ) ) )
=> ( ord_less_eq @ A @ X @ Y ) ) ) ) ) ).
% LIMSEQ_le
thf(fact_4419_Lim__bounded,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [F2: nat > A,L: A,M7: nat,C5: A] :
( ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ ( at_top @ nat ) )
=> ( ! [N3: nat] :
( ( ord_less_eq @ nat @ M7 @ N3 )
=> ( ord_less_eq @ A @ ( F2 @ N3 ) @ C5 ) )
=> ( ord_less_eq @ A @ L @ C5 ) ) ) ) ).
% Lim_bounded
thf(fact_4420_Lim__bounded2,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [F2: nat > A,L: A,N7: nat,C5: A] :
( ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ ( at_top @ nat ) )
=> ( ! [N3: nat] :
( ( ord_less_eq @ nat @ N7 @ N3 )
=> ( ord_less_eq @ A @ C5 @ ( F2 @ N3 ) ) )
=> ( ord_less_eq @ A @ C5 @ L ) ) ) ) ).
% Lim_bounded2
thf(fact_4421_LIMSEQ__le__const,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [X7: nat > A,X: A,A3: A] :
( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ ( at_top @ nat ) )
=> ( ? [N8: nat] :
! [N3: nat] :
( ( ord_less_eq @ nat @ N8 @ N3 )
=> ( ord_less_eq @ A @ A3 @ ( X7 @ N3 ) ) )
=> ( ord_less_eq @ A @ A3 @ X ) ) ) ) ).
% LIMSEQ_le_const
thf(fact_4422_LIMSEQ__le__const2,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [X7: nat > A,X: A,A3: A] :
( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ ( at_top @ nat ) )
=> ( ? [N8: nat] :
! [N3: nat] :
( ( ord_less_eq @ nat @ N8 @ N3 )
=> ( ord_less_eq @ A @ ( X7 @ N3 ) @ A3 ) )
=> ( ord_less_eq @ A @ X @ A3 ) ) ) ) ).
% LIMSEQ_le_const2
thf(fact_4423_Sup__lim,axiom,
! [A: $tType] :
( ( ( comple5582772986160207858norder @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [B2: nat > A,S: set @ A,A3: A] :
( ! [N3: nat] : ( member2 @ A @ ( B2 @ N3 ) @ S )
=> ( ( filterlim @ nat @ A @ B2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ ( at_top @ nat ) )
=> ( ord_less_eq @ A @ A3 @ ( complete_Sup_Sup @ A @ S ) ) ) ) ) ).
% Sup_lim
thf(fact_4424_Inf__lim,axiom,
! [A: $tType] :
( ( ( comple5582772986160207858norder @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [B2: nat > A,S: set @ A,A3: A] :
( ! [N3: nat] : ( member2 @ A @ ( B2 @ N3 ) @ S )
=> ( ( filterlim @ nat @ A @ B2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ ( at_top @ nat ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ S ) @ A3 ) ) ) ) ).
% Inf_lim
thf(fact_4425_Inf__as__limit,axiom,
! [A: $tType] :
( ( ( comple5582772986160207858norder @ A )
& ( topolo3112930676232923870pology @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [A4: set @ A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ? [U4: nat > A] :
( ! [N5: nat] : ( member2 @ A @ ( U4 @ N5 ) @ A4 )
& ( filterlim @ nat @ A @ U4 @ ( topolo7230453075368039082e_nhds @ A @ ( complete_Inf_Inf @ A @ A4 ) ) @ ( at_top @ nat ) ) ) ) ) ).
% Inf_as_limit
thf(fact_4426_summable__LIMSEQ__zero,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A] :
( ( summable @ A @ F2 )
=> ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ ( at_top @ nat ) ) ) ) ).
% summable_LIMSEQ_zero
thf(fact_4427_mult__nat__left__at__top,axiom,
! [C2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ C2 )
=> ( filterlim @ nat @ nat @ ( times_times @ nat @ C2 ) @ ( at_top @ nat ) @ ( at_top @ nat ) ) ) ).
% mult_nat_left_at_top
thf(fact_4428_mult__nat__right__at__top,axiom,
! [C2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ C2 )
=> ( filterlim @ nat @ nat
@ ^ [X2: nat] : ( times_times @ nat @ X2 @ C2 )
@ ( at_top @ nat )
@ ( at_top @ nat ) ) ) ).
% mult_nat_right_at_top
thf(fact_4429_monoseq__le,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [A3: nat > A,X: A] :
( ( topological_monoseq @ A @ A3 )
=> ( ( filterlim @ nat @ A @ A3 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ ( at_top @ nat ) )
=> ( ( ! [N5: nat] : ( ord_less_eq @ A @ ( A3 @ N5 ) @ X )
& ! [M4: nat,N5: nat] :
( ( ord_less_eq @ nat @ M4 @ N5 )
=> ( ord_less_eq @ A @ ( A3 @ M4 ) @ ( A3 @ N5 ) ) ) )
| ( ! [N5: nat] : ( ord_less_eq @ A @ X @ ( A3 @ N5 ) )
& ! [M4: nat,N5: nat] :
( ( ord_less_eq @ nat @ M4 @ N5 )
=> ( ord_less_eq @ A @ ( A3 @ N5 ) @ ( A3 @ M4 ) ) ) ) ) ) ) ) ).
% monoseq_le
thf(fact_4430_lim__const__over__n,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [A3: A] :
( filterlim @ nat @ A
@ ^ [N: nat] : ( divide_divide @ A @ A3 @ ( semiring_1_of_nat @ A @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ ( at_top @ nat ) ) ) ).
% lim_const_over_n
thf(fact_4431_lim__inverse__n,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ( filterlim @ nat @ A
@ ^ [N: nat] : ( inverse_inverse @ A @ ( semiring_1_of_nat @ A @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ ( at_top @ nat ) ) ) ).
% lim_inverse_n
thf(fact_4432_LIMSEQ__linear,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [X7: nat > A,X: A,L: nat] :
( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ ( at_top @ nat ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ L )
=> ( filterlim @ nat @ A
@ ^ [N: nat] : ( X7 @ ( times_times @ nat @ N @ L ) )
@ ( topolo7230453075368039082e_nhds @ A @ X )
@ ( at_top @ nat ) ) ) ) ) ).
% LIMSEQ_linear
thf(fact_4433_telescope__summable_H,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,C2: A] :
( ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ ( at_top @ nat ) )
=> ( summable @ A
@ ^ [N: nat] : ( minus_minus @ A @ ( F2 @ N ) @ ( F2 @ ( suc @ N ) ) ) ) ) ) ).
% telescope_summable'
thf(fact_4434_telescope__summable,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,C2: A] :
( ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ ( at_top @ nat ) )
=> ( summable @ A
@ ^ [N: nat] : ( minus_minus @ A @ ( F2 @ ( suc @ N ) ) @ ( F2 @ N ) ) ) ) ) ).
% telescope_summable
thf(fact_4435_nested__sequence__unique,axiom,
! [F2: nat > real,G: nat > real] :
( ! [N3: nat] : ( ord_less_eq @ real @ ( F2 @ N3 ) @ ( F2 @ ( suc @ N3 ) ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( G @ ( suc @ N3 ) ) @ ( G @ N3 ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( F2 @ N3 ) @ ( G @ N3 ) )
=> ( ( filterlim @ nat @ real
@ ^ [N: nat] : ( minus_minus @ real @ ( F2 @ N ) @ ( G @ N ) )
@ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) )
@ ( at_top @ nat ) )
=> ? [L4: real] :
( ! [N5: nat] : ( ord_less_eq @ real @ ( F2 @ N5 ) @ L4 )
& ( filterlim @ nat @ real @ F2 @ ( topolo7230453075368039082e_nhds @ real @ L4 ) @ ( at_top @ nat ) )
& ! [N5: nat] : ( ord_less_eq @ real @ L4 @ ( G @ N5 ) )
& ( filterlim @ nat @ real @ G @ ( topolo7230453075368039082e_nhds @ real @ L4 ) @ ( at_top @ nat ) ) ) ) ) ) ) ).
% nested_sequence_unique
thf(fact_4436_LIMSEQ__inverse__zero,axiom,
! [X7: nat > real] :
( ! [R3: real] :
? [N8: nat] :
! [N3: nat] :
( ( ord_less_eq @ nat @ N8 @ N3 )
=> ( ord_less @ real @ R3 @ ( X7 @ N3 ) ) )
=> ( filterlim @ nat @ real
@ ^ [N: nat] : ( inverse_inverse @ real @ ( X7 @ N ) )
@ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) )
@ ( at_top @ nat ) ) ) ).
% LIMSEQ_inverse_zero
thf(fact_4437_LIMSEQ__inverse__real__of__nat,axiom,
( filterlim @ nat @ real
@ ^ [N: nat] : ( inverse_inverse @ real @ ( semiring_1_of_nat @ real @ ( suc @ N ) ) )
@ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) )
@ ( at_top @ nat ) ) ).
% LIMSEQ_inverse_real_of_nat
thf(fact_4438_LIMSEQ__inverse__real__of__nat__add,axiom,
! [R2: real] :
( filterlim @ nat @ real
@ ^ [N: nat] : ( plus_plus @ real @ R2 @ ( inverse_inverse @ real @ ( semiring_1_of_nat @ real @ ( suc @ N ) ) ) )
@ ( topolo7230453075368039082e_nhds @ real @ R2 )
@ ( at_top @ nat ) ) ).
% LIMSEQ_inverse_real_of_nat_add
thf(fact_4439_increasing__LIMSEQ,axiom,
! [F2: nat > real,L: real] :
( ! [N3: nat] : ( ord_less_eq @ real @ ( F2 @ N3 ) @ ( F2 @ ( suc @ N3 ) ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( F2 @ N3 ) @ L )
=> ( ! [E: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E )
=> ? [N5: nat] : ( ord_less_eq @ real @ L @ ( plus_plus @ real @ ( F2 @ N5 ) @ E ) ) )
=> ( filterlim @ nat @ real @ F2 @ ( topolo7230453075368039082e_nhds @ real @ L ) @ ( at_top @ nat ) ) ) ) ) ).
% increasing_LIMSEQ
thf(fact_4440_lim__1__over__n,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ( filterlim @ nat @ A
@ ^ [N: nat] : ( divide_divide @ A @ ( one_one @ A ) @ ( semiring_1_of_nat @ A @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ ( at_top @ nat ) ) ) ).
% lim_1_over_n
thf(fact_4441_LIMSEQ__n__over__Suc__n,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ( filterlim @ nat @ A
@ ^ [N: nat] : ( divide_divide @ A @ ( semiring_1_of_nat @ A @ N ) @ ( semiring_1_of_nat @ A @ ( suc @ N ) ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( one_one @ A ) )
@ ( at_top @ nat ) ) ) ).
% LIMSEQ_n_over_Suc_n
thf(fact_4442_LIMSEQ__Suc__n__over__n,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ( filterlim @ nat @ A
@ ^ [N: nat] : ( divide_divide @ A @ ( semiring_1_of_nat @ A @ ( suc @ N ) ) @ ( semiring_1_of_nat @ A @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( one_one @ A ) )
@ ( at_top @ nat ) ) ) ).
% LIMSEQ_Suc_n_over_n
thf(fact_4443_telescope__sums_H,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,C2: A] :
( ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ ( at_top @ nat ) )
=> ( sums @ A
@ ^ [N: nat] : ( minus_minus @ A @ ( F2 @ N ) @ ( F2 @ ( suc @ N ) ) )
@ ( minus_minus @ A @ ( F2 @ ( zero_zero @ nat ) ) @ C2 ) ) ) ) ).
% telescope_sums'
thf(fact_4444_telescope__sums,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,C2: A] :
( ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ ( at_top @ nat ) )
=> ( sums @ A
@ ^ [N: nat] : ( minus_minus @ A @ ( F2 @ ( suc @ N ) ) @ ( F2 @ N ) )
@ ( minus_minus @ A @ C2 @ ( F2 @ ( zero_zero @ nat ) ) ) ) ) ) ).
% telescope_sums
thf(fact_4445_sums__def_H,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ( ( sums @ A )
= ( ^ [F3: nat > A,S7: A] :
( filterlim @ nat @ A
@ ^ [N: nat] : ( groups7311177749621191930dd_sum @ nat @ A @ F3 @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ S7 )
@ ( at_top @ nat ) ) ) ) ) ).
% sums_def'
thf(fact_4446_LIMSEQ__inverse__real__of__nat__add__minus,axiom,
! [R2: real] :
( filterlim @ nat @ real
@ ^ [N: nat] : ( plus_plus @ real @ R2 @ ( uminus_uminus @ real @ ( inverse_inverse @ real @ ( semiring_1_of_nat @ real @ ( suc @ N ) ) ) ) )
@ ( topolo7230453075368039082e_nhds @ real @ R2 )
@ ( at_top @ nat ) ) ).
% LIMSEQ_inverse_real_of_nat_add_minus
thf(fact_4447_LIMSEQ__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X7: nat > A,L5: A] :
( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ L5 ) @ ( at_top @ nat ) )
= ( ! [R4: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ R4 )
=> ? [No: nat] :
! [N: nat] :
( ( ord_less_eq @ nat @ No @ N )
=> ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ ( X7 @ N ) @ L5 ) ) @ R4 ) ) ) ) ) ) ).
% LIMSEQ_iff
thf(fact_4448_LIMSEQ__I,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X7: nat > A,L5: A] :
( ! [R3: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ R3 )
=> ? [No2: nat] :
! [N3: nat] :
( ( ord_less_eq @ nat @ No2 @ N3 )
=> ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ ( X7 @ N3 ) @ L5 ) ) @ R3 ) ) )
=> ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ L5 ) @ ( at_top @ nat ) ) ) ) ).
% LIMSEQ_I
thf(fact_4449_LIMSEQ__D,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X7: nat > A,L5: A,R2: real] :
( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ L5 ) @ ( at_top @ nat ) )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ R2 )
=> ? [No3: nat] :
! [N5: nat] :
( ( ord_less_eq @ nat @ No3 @ N5 )
=> ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ ( X7 @ N5 ) @ L5 ) ) @ R2 ) ) ) ) ) ).
% LIMSEQ_D
thf(fact_4450_LIMSEQ__power__zero,axiom,
! [A: $tType] :
( ( real_V2822296259951069270ebra_1 @ A )
=> ! [X: A] :
( ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ X ) @ ( one_one @ real ) )
=> ( filterlim @ nat @ A @ ( power_power @ A @ X ) @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ ( at_top @ nat ) ) ) ) ).
% LIMSEQ_power_zero
thf(fact_4451_tendsto__power__zero,axiom,
! [A: $tType,B: $tType] :
( ( real_V2822296259951069270ebra_1 @ A )
=> ! [F2: B > nat,F5: filter @ B,X: A] :
( ( filterlim @ B @ nat @ F2 @ ( at_top @ nat ) @ F5 )
=> ( ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ X ) @ ( one_one @ real ) )
=> ( filterlim @ B @ A
@ ^ [Y2: B] : ( power_power @ A @ X @ ( F2 @ Y2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ F5 ) ) ) ) ).
% tendsto_power_zero
thf(fact_4452_LIMSEQ__inverse__real__of__nat__add__minus__mult,axiom,
! [R2: real] :
( filterlim @ nat @ real
@ ^ [N: nat] : ( times_times @ real @ R2 @ ( plus_plus @ real @ ( one_one @ real ) @ ( uminus_uminus @ real @ ( inverse_inverse @ real @ ( semiring_1_of_nat @ real @ ( suc @ N ) ) ) ) ) )
@ ( topolo7230453075368039082e_nhds @ real @ R2 )
@ ( at_top @ nat ) ) ).
% LIMSEQ_inverse_real_of_nat_add_minus_mult
thf(fact_4453_LIMSEQ__norm__0,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A] :
( ! [N3: nat] : ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( F2 @ N3 ) ) @ ( divide_divide @ real @ ( one_one @ real ) @ ( semiring_1_of_nat @ real @ ( suc @ N3 ) ) ) )
=> ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ ( at_top @ nat ) ) ) ) ).
% LIMSEQ_norm_0
thf(fact_4454_field__derivative__lim__unique,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,Df: A,Z: A,S: nat > A,A3: A] :
( ( has_field_derivative @ A @ F2 @ Df @ ( topolo174197925503356063within @ A @ Z @ ( top_top @ ( set @ A ) ) ) )
=> ( ( filterlim @ nat @ A @ S @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ ( at_top @ nat ) )
=> ( ! [N3: nat] :
( ( S @ N3 )
!= ( zero_zero @ A ) )
=> ( ( filterlim @ nat @ A
@ ^ [N: nat] : ( divide_divide @ A @ ( minus_minus @ A @ ( F2 @ ( plus_plus @ A @ Z @ ( S @ N ) ) ) @ ( F2 @ Z ) ) @ ( S @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ A3 )
@ ( at_top @ nat ) )
=> ( Df = A3 ) ) ) ) ) ) ).
% field_derivative_lim_unique
thf(fact_4455_powser__times__n__limit__0,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V8999393235501362500lgebra @ A ) )
=> ! [X: A] :
( ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ X ) @ ( one_one @ real ) )
=> ( filterlim @ nat @ A
@ ^ [N: nat] : ( times_times @ A @ ( semiring_1_of_nat @ A @ N ) @ ( power_power @ A @ X @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ ( at_top @ nat ) ) ) ) ).
% powser_times_n_limit_0
thf(fact_4456_lim__n__over__pown,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ord_less @ real @ ( one_one @ real ) @ ( real_V7770717601297561774m_norm @ A @ X ) )
=> ( filterlim @ nat @ A
@ ^ [N: nat] : ( divide_divide @ A @ ( semiring_1_of_nat @ A @ N ) @ ( power_power @ A @ X @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ ( at_top @ nat ) ) ) ) ).
% lim_n_over_pown
thf(fact_4457_summable,axiom,
! [A3: nat > real] :
( ( filterlim @ nat @ real @ A3 @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ ( at_top @ nat ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( zero_zero @ real ) @ ( A3 @ N3 ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( A3 @ ( suc @ N3 ) ) @ ( A3 @ N3 ) )
=> ( summable @ real
@ ^ [N: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ N ) @ ( A3 @ N ) ) ) ) ) ) ).
% summable
thf(fact_4458_zeroseq__arctan__series,axiom,
! [X: real] :
( ( ord_less_eq @ real @ ( abs_abs @ real @ X ) @ ( one_one @ real ) )
=> ( filterlim @ nat @ real
@ ^ [N: nat] : ( times_times @ real @ ( divide_divide @ real @ ( one_one @ real ) @ ( semiring_1_of_nat @ real @ ( plus_plus @ nat @ ( times_times @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) ) @ ( power_power @ real @ X @ ( plus_plus @ nat @ ( times_times @ nat @ N @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ ( one_one @ nat ) ) ) )
@ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) )
@ ( at_top @ nat ) ) ) ).
% zeroseq_arctan_series
thf(fact_4459_summable__Leibniz_H_I3_J,axiom,
! [A3: nat > real] :
( ( filterlim @ nat @ real @ A3 @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ ( at_top @ nat ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( zero_zero @ real ) @ ( A3 @ N3 ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( A3 @ ( suc @ N3 ) ) @ ( A3 @ N3 ) )
=> ( filterlim @ nat @ real
@ ^ [N: nat] :
( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) ) )
@ ( topolo7230453075368039082e_nhds @ real
@ ( suminf @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) ) ) )
@ ( at_top @ nat ) ) ) ) ) ).
% summable_Leibniz'(3)
thf(fact_4460_summable__Leibniz_H_I2_J,axiom,
! [A3: nat > real,N2: nat] :
( ( filterlim @ nat @ real @ A3 @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ ( at_top @ nat ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( zero_zero @ real ) @ ( A3 @ N3 ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( A3 @ ( suc @ N3 ) ) @ ( A3 @ N3 ) )
=> ( ord_less_eq @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) )
@ ( suminf @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) ) ) ) ) ) ) ).
% summable_Leibniz'(2)
thf(fact_4461_sums__alternating__upper__lower,axiom,
! [A3: nat > real] :
( ! [N3: nat] : ( ord_less_eq @ real @ ( A3 @ ( suc @ N3 ) ) @ ( A3 @ N3 ) )
=> ( ! [N3: nat] : ( ord_less_eq @ real @ ( zero_zero @ real ) @ ( A3 @ N3 ) )
=> ( ( filterlim @ nat @ real @ A3 @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ ( at_top @ nat ) )
=> ? [L4: real] :
( ! [N5: nat] :
( ord_less_eq @ real
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N5 ) ) )
@ L4 )
& ( filterlim @ nat @ real
@ ^ [N: nat] :
( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) ) )
@ ( topolo7230453075368039082e_nhds @ real @ L4 )
@ ( at_top @ nat ) )
& ! [N5: nat] :
( ord_less_eq @ real @ L4
@ ( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N5 ) @ ( one_one @ nat ) ) ) ) )
& ( filterlim @ nat @ real
@ ^ [N: nat] :
( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) @ ( one_one @ nat ) ) ) )
@ ( topolo7230453075368039082e_nhds @ real @ L4 )
@ ( at_top @ nat ) ) ) ) ) ) ).
% sums_alternating_upper_lower
thf(fact_4462_summable__Leibniz_I5_J,axiom,
! [A3: nat > real] :
( ( filterlim @ nat @ real @ A3 @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ ( at_top @ nat ) )
=> ( ( topological_monoseq @ real @ A3 )
=> ( filterlim @ nat @ real
@ ^ [N: nat] :
( groups7311177749621191930dd_sum @ nat @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) )
@ ( set_ord_lessThan @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N ) @ ( one_one @ nat ) ) ) )
@ ( topolo7230453075368039082e_nhds @ real
@ ( suminf @ real
@ ^ [I5: nat] : ( times_times @ real @ ( power_power @ real @ ( uminus_uminus @ real @ ( one_one @ real ) ) @ I5 ) @ ( A3 @ I5 ) ) ) )
@ ( at_top @ nat ) ) ) ) ).
% summable_Leibniz(5)
thf(fact_4463_lim__zero__infinity,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,L: A] :
( ( filterlim @ A @ A
@ ^ [X2: A] : ( F2 @ ( divide_divide @ A @ ( one_one @ A ) @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ L )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) )
=> ( filterlim @ A @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ ( at_infinity @ A ) ) ) ) ).
% lim_zero_infinity
thf(fact_4464_LIM__offset__zero__iff,axiom,
! [C: $tType,D: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( topolo4958980785337419405_space @ D )
& ( zero @ C ) )
=> ! [A3: A,F2: A > D,L5: D] :
( ( nO_MATCH @ C @ A @ ( zero_zero @ C ) @ A3 )
=> ( ( filterlim @ A @ D @ F2 @ ( topolo7230453075368039082e_nhds @ D @ L5 ) @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) )
= ( filterlim @ A @ D
@ ^ [H: A] : ( F2 @ ( plus_plus @ A @ A3 @ H ) )
@ ( topolo7230453075368039082e_nhds @ D @ L5 )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ).
% LIM_offset_zero_iff
thf(fact_4465_same__fst__def,axiom,
! [B: $tType,A: $tType] :
( ( same_fst @ A @ B )
= ( ^ [P: A > $o,R5: A > ( set @ ( product_prod @ B @ B ) )] :
( collect @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) )
@ ( product_case_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ $o
@ ( product_case_prod @ A @ B @ ( ( product_prod @ A @ B ) > $o )
@ ^ [X10: A,Y7: B] :
( product_case_prod @ A @ B @ $o
@ ^ [X2: A,Y2: B] :
( ( X10 = X2 )
& ( P @ X2 )
& ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ Y7 @ Y2 ) @ ( R5 @ X2 ) ) ) ) ) ) ) ) ) ).
% same_fst_def
thf(fact_4466_Bfun__inverse,axiom,
! [A: $tType,B: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [F2: B > A,A3: A,F5: filter @ B] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
=> ( ( A3
!= ( zero_zero @ A ) )
=> ( bfun @ B @ A
@ ^ [X2: B] : ( inverse_inverse @ A @ ( F2 @ X2 ) )
@ F5 ) ) ) ) ).
% Bfun_inverse
thf(fact_4467_same__fstI,axiom,
! [B: $tType,A: $tType,P2: A > $o,X: A,Y8: B,Y: B,R: A > ( set @ ( product_prod @ B @ B ) )] :
( ( P2 @ X )
=> ( ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ Y8 @ Y ) @ ( R @ X ) )
=> ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y8 ) @ ( product_Pair @ A @ B @ X @ Y ) ) @ ( same_fst @ A @ B @ P2 @ R ) ) ) ) ).
% same_fstI
thf(fact_4468_Bseq__add__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,C2: A] :
( ( bfun @ nat @ A
@ ^ [X2: nat] : ( plus_plus @ A @ ( F2 @ X2 ) @ C2 )
@ ( at_top @ nat ) )
= ( bfun @ nat @ A @ F2 @ ( at_top @ nat ) ) ) ) ).
% Bseq_add_iff
thf(fact_4469_Bseq__add,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,C2: A] :
( ( bfun @ nat @ A @ F2 @ ( at_top @ nat ) )
=> ( bfun @ nat @ A
@ ^ [X2: nat] : ( plus_plus @ A @ ( F2 @ X2 ) @ C2 )
@ ( at_top @ nat ) ) ) ) ).
% Bseq_add
thf(fact_4470_Bseq__Suc__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A] :
( ( bfun @ nat @ A
@ ^ [N: nat] : ( F2 @ ( suc @ N ) )
@ ( at_top @ nat ) )
= ( bfun @ nat @ A @ F2 @ ( at_top @ nat ) ) ) ) ).
% Bseq_Suc_iff
thf(fact_4471_Bseq__ignore__initial__segment,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ! [X7: nat > A,K: nat] :
( ( bfun @ nat @ A @ X7 @ ( at_top @ nat ) )
=> ( bfun @ nat @ A
@ ^ [N: nat] : ( X7 @ ( plus_plus @ nat @ N @ K ) )
@ ( at_top @ nat ) ) ) ) ).
% Bseq_ignore_initial_segment
thf(fact_4472_Bseq__offset,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ! [X7: nat > A,K: nat] :
( ( bfun @ nat @ A
@ ^ [N: nat] : ( X7 @ ( plus_plus @ nat @ N @ K ) )
@ ( at_top @ nat ) )
=> ( bfun @ nat @ A @ X7 @ ( at_top @ nat ) ) ) ) ).
% Bseq_offset
thf(fact_4473_Bseq__cmult__iff,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [C2: A,F2: nat > A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( bfun @ nat @ A
@ ^ [X2: nat] : ( times_times @ A @ C2 @ ( F2 @ X2 ) )
@ ( at_top @ nat ) )
= ( bfun @ nat @ A @ F2 @ ( at_top @ nat ) ) ) ) ) ).
% Bseq_cmult_iff
thf(fact_4474_not__tendsto__and__filterlim__at__infinity,axiom,
! [A: $tType,B: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F5: filter @ B,F2: B > A,C2: A] :
( ( F5
!= ( bot_bot @ ( filter @ B ) ) )
=> ( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ F5 )
=> ~ ( filterlim @ B @ A @ F2 @ ( at_infinity @ A ) @ F5 ) ) ) ) ).
% not_tendsto_and_filterlim_at_infinity
thf(fact_4475_scale__right__distrib__NO__MATCH,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: A,Y: A,A3: real] :
( ( nO_MATCH @ A @ real @ ( divide_divide @ A @ X @ Y ) @ A3 )
=> ( ( real_V8093663219630862766scaleR @ A @ A3 @ ( plus_plus @ A @ X @ Y ) )
= ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) @ ( real_V8093663219630862766scaleR @ A @ A3 @ Y ) ) ) ) ) ).
% scale_right_distrib_NO_MATCH
thf(fact_4476_distrib__right__NO__MATCH,axiom,
! [B: $tType,A: $tType] :
( ( semiring @ A )
=> ! [X: B,Y: B,C2: A,A3: A,B2: A] :
( ( nO_MATCH @ B @ A @ ( divide_divide @ B @ X @ Y ) @ C2 )
=> ( ( times_times @ A @ ( plus_plus @ A @ A3 @ B2 ) @ C2 )
= ( plus_plus @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) ) ) ) ) ).
% distrib_right_NO_MATCH
thf(fact_4477_distrib__left__NO__MATCH,axiom,
! [B: $tType,A: $tType] :
( ( semiring @ A )
=> ! [X: B,Y: B,A3: A,B2: A,C2: A] :
( ( nO_MATCH @ B @ A @ ( divide_divide @ B @ X @ Y ) @ A3 )
=> ( ( times_times @ A @ A3 @ ( plus_plus @ A @ B2 @ C2 ) )
= ( plus_plus @ A @ ( times_times @ A @ A3 @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) ) ) ) ).
% distrib_left_NO_MATCH
thf(fact_4478_right__diff__distrib__NO__MATCH,axiom,
! [B: $tType,A: $tType] :
( ( ring @ A )
=> ! [X: B,Y: B,A3: A,B2: A,C2: A] :
( ( nO_MATCH @ B @ A @ ( divide_divide @ B @ X @ Y ) @ A3 )
=> ( ( times_times @ A @ A3 @ ( minus_minus @ A @ B2 @ C2 ) )
= ( minus_minus @ A @ ( times_times @ A @ A3 @ B2 ) @ ( times_times @ A @ A3 @ C2 ) ) ) ) ) ).
% right_diff_distrib_NO_MATCH
thf(fact_4479_left__diff__distrib__NO__MATCH,axiom,
! [B: $tType,A: $tType] :
( ( ring @ A )
=> ! [X: B,Y: B,C2: A,A3: A,B2: A] :
( ( nO_MATCH @ B @ A @ ( divide_divide @ B @ X @ Y ) @ C2 )
=> ( ( times_times @ A @ ( minus_minus @ A @ A3 @ B2 ) @ C2 )
= ( minus_minus @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) ) ) ) ) ).
% left_diff_distrib_NO_MATCH
thf(fact_4480_filterlim__pow__at__top,axiom,
! [A: $tType,N2: nat,F2: A > real,F5: filter @ A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( filterlim @ A @ real @ F2 @ ( at_top @ real ) @ F5 )
=> ( filterlim @ A @ real
@ ^ [X2: A] : ( power_power @ real @ ( F2 @ X2 ) @ N2 )
@ ( at_top @ real )
@ F5 ) ) ) ).
% filterlim_pow_at_top
thf(fact_4481_tendsto__add__filterlim__at__infinity_H,axiom,
! [B: $tType,A: $tType] :
( ( real_V822414075346904944vector @ B )
=> ! [F2: A > B,F5: filter @ A,G: A > B,C2: B] :
( ( filterlim @ A @ B @ F2 @ ( at_infinity @ B ) @ F5 )
=> ( ( filterlim @ A @ B @ G @ ( topolo7230453075368039082e_nhds @ B @ C2 ) @ F5 )
=> ( filterlim @ A @ B
@ ^ [X2: A] : ( plus_plus @ B @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( at_infinity @ B )
@ F5 ) ) ) ) ).
% tendsto_add_filterlim_at_infinity'
thf(fact_4482_tendsto__add__filterlim__at__infinity,axiom,
! [B: $tType,A: $tType] :
( ( real_V822414075346904944vector @ B )
=> ! [F2: A > B,C2: B,F5: filter @ A,G: A > B] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ C2 ) @ F5 )
=> ( ( filterlim @ A @ B @ G @ ( at_infinity @ B ) @ F5 )
=> ( filterlim @ A @ B
@ ^ [X2: A] : ( plus_plus @ B @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( at_infinity @ B )
@ F5 ) ) ) ) ).
% tendsto_add_filterlim_at_infinity
thf(fact_4483_tendsto__inverse__0,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ( filterlim @ A @ A @ ( inverse_inverse @ A ) @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ ( at_infinity @ A ) ) ) ).
% tendsto_inverse_0
thf(fact_4484_Bseq__iff1a,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X7: nat > A] :
( ( bfun @ nat @ A @ X7 @ ( at_top @ nat ) )
= ( ? [N6: nat] :
! [N: nat] : ( ord_less @ real @ ( real_V7770717601297561774m_norm @ A @ ( X7 @ N ) ) @ ( semiring_1_of_nat @ real @ ( suc @ N6 ) ) ) ) ) ) ).
% Bseq_iff1a
thf(fact_4485_Bseq__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X7: nat > A] :
( ( bfun @ nat @ A @ X7 @ ( at_top @ nat ) )
= ( ? [N6: nat] :
! [N: nat] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( X7 @ N ) ) @ ( semiring_1_of_nat @ real @ ( suc @ N6 ) ) ) ) ) ) ).
% Bseq_iff
thf(fact_4486_tendsto__mult__filterlim__at__infinity,axiom,
! [A: $tType,B: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: B > A,C2: A,F5: filter @ B,G: B > A] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ F5 )
=> ( ( C2
!= ( zero_zero @ A ) )
=> ( ( filterlim @ B @ A @ G @ ( at_infinity @ A ) @ F5 )
=> ( filterlim @ B @ A
@ ^ [X2: B] : ( times_times @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( at_infinity @ A )
@ F5 ) ) ) ) ) ).
% tendsto_mult_filterlim_at_infinity
thf(fact_4487_tendsto__divide__0,axiom,
! [A: $tType,C: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [F2: C > A,C2: A,F5: filter @ C,G: C > A] :
( ( filterlim @ C @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ F5 )
=> ( ( filterlim @ C @ A @ G @ ( at_infinity @ A ) @ F5 )
=> ( filterlim @ C @ A
@ ^ [X2: C] : ( divide_divide @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) )
@ F5 ) ) ) ) ).
% tendsto_divide_0
thf(fact_4488_filterlim__power__at__infinity,axiom,
! [B: $tType,A: $tType] :
( ( real_V8999393235501362500lgebra @ B )
=> ! [F2: A > B,F5: filter @ A,N2: nat] :
( ( filterlim @ A @ B @ F2 @ ( at_infinity @ B ) @ F5 )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( filterlim @ A @ B
@ ^ [X2: A] : ( power_power @ B @ ( F2 @ X2 ) @ N2 )
@ ( at_infinity @ B )
@ F5 ) ) ) ) ).
% filterlim_power_at_infinity
thf(fact_4489_scale__left__distrib__NO__MATCH,axiom,
! [C: $tType,A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: A,Y: A,C2: C,A3: real,B2: real] :
( ( nO_MATCH @ A @ C @ ( divide_divide @ A @ X @ Y ) @ C2 )
=> ( ( real_V8093663219630862766scaleR @ A @ ( plus_plus @ real @ A3 @ B2 ) @ X )
= ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ A3 @ X ) @ ( real_V8093663219630862766scaleR @ A @ B2 @ X ) ) ) ) ) ).
% scale_left_distrib_NO_MATCH
thf(fact_4490_filterlim__inverse__at__infinity,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ( filterlim @ A @ A @ ( inverse_inverse @ A ) @ ( at_infinity @ A ) @ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ).
% filterlim_inverse_at_infinity
thf(fact_4491_filterlim__inverse__at__iff,axiom,
! [B: $tType,A: $tType] :
( ( real_V8999393235501362500lgebra @ B )
=> ! [G: A > B,F5: filter @ A] :
( ( filterlim @ A @ B
@ ^ [X2: A] : ( inverse_inverse @ B @ ( G @ X2 ) )
@ ( topolo174197925503356063within @ B @ ( zero_zero @ B ) @ ( top_top @ ( set @ B ) ) )
@ F5 )
= ( filterlim @ A @ B @ G @ ( at_infinity @ B ) @ F5 ) ) ) ).
% filterlim_inverse_at_iff
thf(fact_4492_Bseq__iff2,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X7: nat > A] :
( ( bfun @ nat @ A @ X7 @ ( at_top @ nat ) )
= ( ? [K2: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ K2 )
& ? [X2: A] :
! [N: nat] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ ( X7 @ N ) @ ( uminus_uminus @ A @ X2 ) ) ) @ K2 ) ) ) ) ) ).
% Bseq_iff2
thf(fact_4493_Bseq__iff3,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X7: nat > A] :
( ( bfun @ nat @ A @ X7 @ ( at_top @ nat ) )
= ( ? [K2: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ K2 )
& ? [N6: nat] :
! [N: nat] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( plus_plus @ A @ ( X7 @ N ) @ ( uminus_uminus @ A @ ( X7 @ N6 ) ) ) ) @ K2 ) ) ) ) ) ).
% Bseq_iff3
thf(fact_4494_filterlim__divide__at__infinity,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,C2: A,F5: filter @ A,G: A > A] :
( ( filterlim @ A @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ F5 )
=> ( ( filterlim @ A @ A @ G @ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) @ F5 )
=> ( ( C2
!= ( zero_zero @ A ) )
=> ( filterlim @ A @ A
@ ^ [X2: A] : ( divide_divide @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( at_infinity @ A )
@ F5 ) ) ) ) ) ).
% filterlim_divide_at_infinity
thf(fact_4495_div__add__self1__no__field,axiom,
! [B: $tType,A: $tType] :
( ( ( euclid4440199948858584721cancel @ A )
& ( field @ B ) )
=> ! [X: B,B2: A,A3: A] :
( ( nO_MATCH @ B @ A @ X @ B2 )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ B2 @ A3 ) @ B2 )
= ( plus_plus @ A @ ( divide_divide @ A @ A3 @ B2 ) @ ( one_one @ A ) ) ) ) ) ) ).
% div_add_self1_no_field
thf(fact_4496_div__add__self2__no__field,axiom,
! [B: $tType,A: $tType] :
( ( ( euclid4440199948858584721cancel @ A )
& ( field @ B ) )
=> ! [X: B,B2: A,A3: A] :
( ( nO_MATCH @ B @ A @ X @ B2 )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ A3 @ B2 ) @ B2 )
= ( plus_plus @ A @ ( divide_divide @ A @ A3 @ B2 ) @ ( one_one @ A ) ) ) ) ) ) ).
% div_add_self2_no_field
thf(fact_4497_polyfun__extremal,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [C2: nat > A,K: nat,N2: nat,B3: real] :
( ( ( C2 @ K )
!= ( zero_zero @ A ) )
=> ( ( ord_less_eq @ nat @ ( one_one @ nat ) @ K )
=> ( ( ord_less_eq @ nat @ K @ N2 )
=> ( eventually @ A
@ ^ [Z6: A] :
( ord_less_eq @ real @ B3
@ ( real_V7770717601297561774m_norm @ A
@ ( groups7311177749621191930dd_sum @ nat @ A
@ ^ [I5: nat] : ( times_times @ A @ ( C2 @ I5 ) @ ( power_power @ A @ Z6 @ I5 ) )
@ ( set_ord_atMost @ nat @ N2 ) ) ) )
@ ( at_infinity @ A ) ) ) ) ) ) ).
% polyfun_extremal
thf(fact_4498_field__has__derivative__at,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D6: A,X: A] :
( ( has_derivative @ A @ A @ F2 @ ( times_times @ A @ D6 ) @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) )
= ( filterlim @ A @ A
@ ^ [H: A] : ( divide_divide @ A @ ( minus_minus @ A @ ( F2 @ ( plus_plus @ A @ X @ H ) ) @ ( F2 @ X ) ) @ H )
@ ( topolo7230453075368039082e_nhds @ A @ D6 )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% field_has_derivative_at
thf(fact_4499_eventually__sequentially__Suc,axiom,
! [P2: nat > $o] :
( ( eventually @ nat
@ ^ [I5: nat] : ( P2 @ ( suc @ I5 ) )
@ ( at_top @ nat ) )
= ( eventually @ nat @ P2 @ ( at_top @ nat ) ) ) ).
% eventually_sequentially_Suc
thf(fact_4500_eventually__sequentially__seg,axiom,
! [P2: nat > $o,K: nat] :
( ( eventually @ nat
@ ^ [N: nat] : ( P2 @ ( plus_plus @ nat @ N @ K ) )
@ ( at_top @ nat ) )
= ( eventually @ nat @ P2 @ ( at_top @ nat ) ) ) ).
% eventually_sequentially_seg
thf(fact_4501_eventually__const,axiom,
! [A: $tType,F5: filter @ A,P2: $o] :
( ( F5
!= ( bot_bot @ ( filter @ A ) ) )
=> ( ( eventually @ A
@ ^ [X2: A] : P2
@ F5 )
= P2 ) ) ).
% eventually_const
thf(fact_4502_trivial__limit__def,axiom,
! [A: $tType,F5: filter @ A] :
( ( F5
= ( bot_bot @ ( filter @ A ) ) )
= ( eventually @ A
@ ^ [X2: A] : $false
@ F5 ) ) ).
% trivial_limit_def
thf(fact_4503_eventually__const__iff,axiom,
! [A: $tType,P2: $o,F5: filter @ A] :
( ( eventually @ A
@ ^ [X2: A] : P2
@ F5 )
= ( P2
| ( F5
= ( bot_bot @ ( filter @ A ) ) ) ) ) ).
% eventually_const_iff
thf(fact_4504_False__imp__not__eventually,axiom,
! [A: $tType,P2: A > $o,Net: filter @ A] :
( ! [X5: A] :
~ ( P2 @ X5 )
=> ( ( Net
!= ( bot_bot @ ( filter @ A ) ) )
=> ~ ( eventually @ A @ P2 @ Net ) ) ) ).
% False_imp_not_eventually
thf(fact_4505_eventually__happens_H,axiom,
! [A: $tType,F5: filter @ A,P2: A > $o] :
( ( F5
!= ( bot_bot @ ( filter @ A ) ) )
=> ( ( eventually @ A @ P2 @ F5 )
=> ? [X_12: A] : ( P2 @ X_12 ) ) ) ).
% eventually_happens'
thf(fact_4506_eventually__happens,axiom,
! [A: $tType,P2: A > $o,Net: filter @ A] :
( ( eventually @ A @ P2 @ Net )
=> ( ( Net
= ( bot_bot @ ( filter @ A ) ) )
| ? [X_12: A] : ( P2 @ X_12 ) ) ) ).
% eventually_happens
thf(fact_4507_eventually__bot,axiom,
! [A: $tType,P2: A > $o] : ( eventually @ A @ P2 @ ( bot_bot @ ( filter @ A ) ) ) ).
% eventually_bot
thf(fact_4508_has__derivative__scaleR,axiom,
! [C: $tType,D: $tType] :
( ( ( real_V822414075346904944vector @ D )
& ( real_V822414075346904944vector @ C ) )
=> ! [F2: D > real,F8: D > real,X: D,S: set @ D,G: D > C,G6: D > C] :
( ( has_derivative @ D @ real @ F2 @ F8 @ ( topolo174197925503356063within @ D @ X @ S ) )
=> ( ( has_derivative @ D @ C @ G @ G6 @ ( topolo174197925503356063within @ D @ X @ S ) )
=> ( has_derivative @ D @ C
@ ^ [X2: D] : ( real_V8093663219630862766scaleR @ C @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ^ [H: D] : ( plus_plus @ C @ ( real_V8093663219630862766scaleR @ C @ ( F2 @ X ) @ ( G6 @ H ) ) @ ( real_V8093663219630862766scaleR @ C @ ( F8 @ H ) @ ( G @ X ) ) )
@ ( topolo174197925503356063within @ D @ X @ S ) ) ) ) ) ).
% has_derivative_scaleR
thf(fact_4509_has__derivative__const,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [C2: B,F5: filter @ A] :
( has_derivative @ A @ B
@ ^ [X2: A] : C2
@ ^ [X2: A] : ( zero_zero @ B )
@ F5 ) ) ).
% has_derivative_const
thf(fact_4510_has__derivative__add,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,F8: A > B,F5: filter @ A,G: A > B,G6: A > B] :
( ( has_derivative @ A @ B @ F2 @ F8 @ F5 )
=> ( ( has_derivative @ A @ B @ G @ G6 @ F5 )
=> ( has_derivative @ A @ B
@ ^ [X2: A] : ( plus_plus @ B @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ^ [X2: A] : ( plus_plus @ B @ ( F8 @ X2 ) @ ( G6 @ X2 ) )
@ F5 ) ) ) ) ).
% has_derivative_add
thf(fact_4511_has__derivative__subset,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,F8: A > B,X: A,S: set @ A,T2: set @ A] :
( ( has_derivative @ A @ B @ F2 @ F8 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ord_less_eq @ ( set @ A ) @ T2 @ S )
=> ( has_derivative @ A @ B @ F2 @ F8 @ ( topolo174197925503356063within @ A @ X @ T2 ) ) ) ) ) ).
% has_derivative_subset
thf(fact_4512_eventually__at__top__linorder,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [P2: A > $o] :
( ( eventually @ A @ P2 @ ( at_top @ A ) )
= ( ? [N6: A] :
! [N: A] :
( ( ord_less_eq @ A @ N6 @ N )
=> ( P2 @ N ) ) ) ) ) ).
% eventually_at_top_linorder
thf(fact_4513_eventually__at__top__linorderI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [C2: A,P2: A > $o] :
( ! [X5: A] :
( ( ord_less_eq @ A @ C2 @ X5 )
=> ( P2 @ X5 ) )
=> ( eventually @ A @ P2 @ ( at_top @ A ) ) ) ) ).
% eventually_at_top_linorderI
thf(fact_4514_eventually__at__top__dense,axiom,
! [A: $tType] :
( ( ( linorder @ A )
& ( no_top @ A ) )
=> ! [P2: A > $o] :
( ( eventually @ A @ P2 @ ( at_top @ A ) )
= ( ? [N6: A] :
! [N: A] :
( ( ord_less @ A @ N6 @ N )
=> ( P2 @ N ) ) ) ) ) ).
% eventually_at_top_dense
thf(fact_4515_eventually__sequentially,axiom,
! [P2: nat > $o] :
( ( eventually @ nat @ P2 @ ( at_top @ nat ) )
= ( ? [N6: nat] :
! [N: nat] :
( ( ord_less_eq @ nat @ N6 @ N )
=> ( P2 @ N ) ) ) ) ).
% eventually_sequentially
thf(fact_4516_eventually__sequentiallyI,axiom,
! [C2: nat,P2: nat > $o] :
( ! [X5: nat] :
( ( ord_less_eq @ nat @ C2 @ X5 )
=> ( P2 @ X5 ) )
=> ( eventually @ nat @ P2 @ ( at_top @ nat ) ) ) ).
% eventually_sequentiallyI
thf(fact_4517_eventually__ge__at__top,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [C2: A] : ( eventually @ A @ ( ord_less_eq @ A @ C2 ) @ ( at_top @ A ) ) ) ).
% eventually_ge_at_top
thf(fact_4518_eventually__gt__at__top,axiom,
! [A: $tType] :
( ( ( linorder @ A )
& ( no_top @ A ) )
=> ! [C2: A] : ( eventually @ A @ ( ord_less @ A @ C2 ) @ ( at_top @ A ) ) ) ).
% eventually_gt_at_top
thf(fact_4519_le__sequentially,axiom,
! [F5: filter @ nat] :
( ( ord_less_eq @ ( filter @ nat ) @ F5 @ ( at_top @ nat ) )
= ( ! [N6: nat] : ( eventually @ nat @ ( ord_less_eq @ nat @ N6 ) @ F5 ) ) ) ).
% le_sequentially
thf(fact_4520_sequentially__offset,axiom,
! [P2: nat > $o,K: nat] :
( ( eventually @ nat @ P2 @ ( at_top @ nat ) )
=> ( eventually @ nat
@ ^ [I5: nat] : ( P2 @ ( plus_plus @ nat @ I5 @ K ) )
@ ( at_top @ nat ) ) ) ).
% sequentially_offset
thf(fact_4521_eventually__nhds__top,axiom,
! [A: $tType] :
( ( ( order_top @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [B2: A,P2: A > $o] :
( ( ord_less @ A @ B2 @ ( top_top @ A ) )
=> ( ( eventually @ A @ P2 @ ( topolo7230453075368039082e_nhds @ A @ ( top_top @ A ) ) )
= ( ? [B4: A] :
( ( ord_less @ A @ B4 @ ( top_top @ A ) )
& ! [Z6: A] :
( ( ord_less @ A @ B4 @ Z6 )
=> ( P2 @ Z6 ) ) ) ) ) ) ) ).
% eventually_nhds_top
thf(fact_4522_filterlim__at__top__at__top,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( linorder @ B ) )
=> ! [Q: A > $o,F2: A > B,P2: B > $o,G: B > A] :
( ! [X5: A,Y4: A] :
( ( Q @ X5 )
=> ( ( Q @ Y4 )
=> ( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ord_less_eq @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) ) ) )
=> ( ! [X5: B] :
( ( P2 @ X5 )
=> ( ( F2 @ ( G @ X5 ) )
= X5 ) )
=> ( ! [X5: B] :
( ( P2 @ X5 )
=> ( Q @ ( G @ X5 ) ) )
=> ( ( eventually @ A @ Q @ ( at_top @ A ) )
=> ( ( eventually @ B @ P2 @ ( at_top @ B ) )
=> ( filterlim @ A @ B @ F2 @ ( at_top @ B ) @ ( at_top @ A ) ) ) ) ) ) ) ) ).
% filterlim_at_top_at_top
thf(fact_4523_eventually__at__left__field,axiom,
! [A: $tType] :
( ( ( linordered_field @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [P2: A > $o,X: A] :
( ( eventually @ A @ P2 @ ( topolo174197925503356063within @ A @ X @ ( set_ord_lessThan @ A @ X ) ) )
= ( ? [B4: A] :
( ( ord_less @ A @ B4 @ X )
& ! [Y2: A] :
( ( ord_less @ A @ B4 @ Y2 )
=> ( ( ord_less @ A @ Y2 @ X )
=> ( P2 @ Y2 ) ) ) ) ) ) ) ).
% eventually_at_left_field
thf(fact_4524_eventually__at__left,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [Y: A,X: A,P2: A > $o] :
( ( ord_less @ A @ Y @ X )
=> ( ( eventually @ A @ P2 @ ( topolo174197925503356063within @ A @ X @ ( set_ord_lessThan @ A @ X ) ) )
= ( ? [B4: A] :
( ( ord_less @ A @ B4 @ X )
& ! [Y2: A] :
( ( ord_less @ A @ B4 @ Y2 )
=> ( ( ord_less @ A @ Y2 @ X )
=> ( P2 @ Y2 ) ) ) ) ) ) ) ) ).
% eventually_at_left
thf(fact_4525_has__derivative__zero__unique,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F5: A > B,X: A] :
( ( has_derivative @ A @ B
@ ^ [X2: A] : ( zero_zero @ B )
@ F5
@ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) )
=> ( F5
= ( ^ [H: A] : ( zero_zero @ B ) ) ) ) ) ).
% has_derivative_zero_unique
thf(fact_4526_has__derivative__mult,axiom,
! [A: $tType,D: $tType] :
( ( ( real_V822414075346904944vector @ D )
& ( real_V4412858255891104859lgebra @ A ) )
=> ! [F2: D > A,F8: D > A,X: D,S: set @ D,G: D > A,G6: D > A] :
( ( has_derivative @ D @ A @ F2 @ F8 @ ( topolo174197925503356063within @ D @ X @ S ) )
=> ( ( has_derivative @ D @ A @ G @ G6 @ ( topolo174197925503356063within @ D @ X @ S ) )
=> ( has_derivative @ D @ A
@ ^ [X2: D] : ( times_times @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ^ [H: D] : ( plus_plus @ A @ ( times_times @ A @ ( F2 @ X ) @ ( G6 @ H ) ) @ ( times_times @ A @ ( F8 @ H ) @ ( G @ X ) ) )
@ ( topolo174197925503356063within @ D @ X @ S ) ) ) ) ) ).
% has_derivative_mult
thf(fact_4527_has__derivative__in__compose2,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( ( real_V822414075346904944vector @ C )
& ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [T2: set @ A,G: A > B,G6: A > A > B,F2: C > A,S: set @ C,X: C,F8: C > A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ T2 )
=> ( has_derivative @ A @ B @ G @ ( G6 @ X5 ) @ ( topolo174197925503356063within @ A @ X5 @ T2 ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image2 @ C @ A @ F2 @ S ) @ T2 )
=> ( ( member2 @ C @ X @ S )
=> ( ( has_derivative @ C @ A @ F2 @ F8 @ ( topolo174197925503356063within @ C @ X @ S ) )
=> ( has_derivative @ C @ B
@ ^ [X2: C] : ( G @ ( F2 @ X2 ) )
@ ^ [Y2: C] : ( G6 @ ( F2 @ X ) @ ( F8 @ Y2 ) )
@ ( topolo174197925503356063within @ C @ X @ S ) ) ) ) ) ) ) ).
% has_derivative_in_compose2
thf(fact_4528_tendsto__sandwich,axiom,
! [A: $tType,B: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [F2: B > A,G: B > A,Net: filter @ B,H2: B > A,C2: A] :
( ( eventually @ B
@ ^ [N: B] : ( ord_less_eq @ A @ ( F2 @ N ) @ ( G @ N ) )
@ Net )
=> ( ( eventually @ B
@ ^ [N: B] : ( ord_less_eq @ A @ ( G @ N ) @ ( H2 @ N ) )
@ Net )
=> ( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ Net )
=> ( ( filterlim @ B @ A @ H2 @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ Net )
=> ( filterlim @ B @ A @ G @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ Net ) ) ) ) ) ) ).
% tendsto_sandwich
thf(fact_4529_order__tendstoD_I2_J,axiom,
! [A: $tType,B: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [F2: B > A,Y: A,F5: filter @ B,A3: A] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ Y ) @ F5 )
=> ( ( ord_less @ A @ Y @ A3 )
=> ( eventually @ B
@ ^ [X2: B] : ( ord_less @ A @ ( F2 @ X2 ) @ A3 )
@ F5 ) ) ) ) ).
% order_tendstoD(2)
thf(fact_4530_order__tendstoD_I1_J,axiom,
! [A: $tType,B: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [F2: B > A,Y: A,F5: filter @ B,A3: A] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ Y ) @ F5 )
=> ( ( ord_less @ A @ A3 @ Y )
=> ( eventually @ B
@ ^ [X2: B] : ( ord_less @ A @ A3 @ ( F2 @ X2 ) )
@ F5 ) ) ) ) ).
% order_tendstoD(1)
thf(fact_4531_order__tendstoI,axiom,
! [A: $tType,B: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [Y: A,F2: B > A,F5: filter @ B] :
( ! [A7: A] :
( ( ord_less @ A @ A7 @ Y )
=> ( eventually @ B
@ ^ [X2: B] : ( ord_less @ A @ A7 @ ( F2 @ X2 ) )
@ F5 ) )
=> ( ! [A7: A] :
( ( ord_less @ A @ Y @ A7 )
=> ( eventually @ B
@ ^ [X2: B] : ( ord_less @ A @ ( F2 @ X2 ) @ A7 )
@ F5 ) )
=> ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ Y ) @ F5 ) ) ) ) ).
% order_tendstoI
thf(fact_4532_order__tendsto__iff,axiom,
! [B: $tType,A: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [F2: B > A,X: A,F5: filter @ B] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ F5 )
= ( ! [L2: A] :
( ( ord_less @ A @ L2 @ X )
=> ( eventually @ B
@ ^ [X2: B] : ( ord_less @ A @ L2 @ ( F2 @ X2 ) )
@ F5 ) )
& ! [U2: A] :
( ( ord_less @ A @ X @ U2 )
=> ( eventually @ B
@ ^ [X2: B] : ( ord_less @ A @ ( F2 @ X2 ) @ U2 )
@ F5 ) ) ) ) ) ).
% order_tendsto_iff
thf(fact_4533_filterlim__at__top__mono,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,F5: filter @ B,G: B > A] :
( ( filterlim @ B @ A @ F2 @ ( at_top @ A ) @ F5 )
=> ( ( eventually @ B
@ ^ [X2: B] : ( ord_less_eq @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ F5 )
=> ( filterlim @ B @ A @ G @ ( at_top @ A ) @ F5 ) ) ) ) ).
% filterlim_at_top_mono
thf(fact_4534_filterlim__at__top__ge,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ B )
=> ! [F2: A > B,F5: filter @ A,C2: B] :
( ( filterlim @ A @ B @ F2 @ ( at_top @ B ) @ F5 )
= ( ! [Z9: B] :
( ( ord_less_eq @ B @ C2 @ Z9 )
=> ( eventually @ A
@ ^ [X2: A] : ( ord_less_eq @ B @ Z9 @ ( F2 @ X2 ) )
@ F5 ) ) ) ) ) ).
% filterlim_at_top_ge
thf(fact_4535_filterlim__at__top,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ B )
=> ! [F2: A > B,F5: filter @ A] :
( ( filterlim @ A @ B @ F2 @ ( at_top @ B ) @ F5 )
= ( ! [Z9: B] :
( eventually @ A
@ ^ [X2: A] : ( ord_less_eq @ B @ Z9 @ ( F2 @ X2 ) )
@ F5 ) ) ) ) ).
% filterlim_at_top
thf(fact_4536_filterlim__at__top__dense,axiom,
! [A: $tType,B: $tType] :
( ( unboun7993243217541854897norder @ B )
=> ! [F2: A > B,F5: filter @ A] :
( ( filterlim @ A @ B @ F2 @ ( at_top @ B ) @ F5 )
= ( ! [Z9: B] :
( eventually @ A
@ ^ [X2: A] : ( ord_less @ B @ Z9 @ ( F2 @ X2 ) )
@ F5 ) ) ) ) ).
% filterlim_at_top_dense
thf(fact_4537_eventually__Inf__base,axiom,
! [A: $tType,B3: set @ ( filter @ A ),P2: A > $o] :
( ( B3
!= ( bot_bot @ ( set @ ( filter @ A ) ) ) )
=> ( ! [F6: filter @ A] :
( ( member2 @ ( filter @ A ) @ F6 @ B3 )
=> ! [G5: filter @ A] :
( ( member2 @ ( filter @ A ) @ G5 @ B3 )
=> ? [X3: filter @ A] :
( ( member2 @ ( filter @ A ) @ X3 @ B3 )
& ( ord_less_eq @ ( filter @ A ) @ X3 @ ( inf_inf @ ( filter @ A ) @ F6 @ G5 ) ) ) ) )
=> ( ( eventually @ A @ P2 @ ( complete_Inf_Inf @ ( filter @ A ) @ B3 ) )
= ( ? [X2: filter @ A] :
( ( member2 @ ( filter @ A ) @ X2 @ B3 )
& ( eventually @ A @ P2 @ X2 ) ) ) ) ) ) ).
% eventually_Inf_base
thf(fact_4538_eventually__at__leftI,axiom,
! [A: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [A3: A,B2: A,P2: A > $o] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) )
=> ( P2 @ X5 ) )
=> ( ( ord_less @ A @ A3 @ B2 )
=> ( eventually @ A @ P2 @ ( topolo174197925503356063within @ A @ B2 @ ( set_ord_lessThan @ A @ B2 ) ) ) ) ) ) ).
% eventually_at_leftI
thf(fact_4539_eventually__at__to__0,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [P2: A > $o,A3: A] :
( ( eventually @ A @ P2 @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) )
= ( eventually @ A
@ ^ [X2: A] : ( P2 @ ( plus_plus @ A @ X2 @ A3 ) )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% eventually_at_to_0
thf(fact_4540_decreasing__tendsto,axiom,
! [A: $tType,B: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [L: A,F2: B > A,F5: filter @ B] :
( ( eventually @ B
@ ^ [N: B] : ( ord_less_eq @ A @ L @ ( F2 @ N ) )
@ F5 )
=> ( ! [X5: A] :
( ( ord_less @ A @ L @ X5 )
=> ( eventually @ B
@ ^ [N: B] : ( ord_less @ A @ ( F2 @ N ) @ X5 )
@ F5 ) )
=> ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ F5 ) ) ) ) ).
% decreasing_tendsto
thf(fact_4541_increasing__tendsto,axiom,
! [A: $tType,B: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [F2: B > A,L: A,F5: filter @ B] :
( ( eventually @ B
@ ^ [N: B] : ( ord_less_eq @ A @ ( F2 @ N ) @ L )
@ F5 )
=> ( ! [X5: A] :
( ( ord_less @ A @ X5 @ L )
=> ( eventually @ B
@ ^ [N: B] : ( ord_less @ A @ X5 @ ( F2 @ N ) )
@ F5 ) )
=> ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ F5 ) ) ) ) ).
% increasing_tendsto
thf(fact_4542_filterlim__at__top__gt,axiom,
! [A: $tType,B: $tType] :
( ( unboun7993243217541854897norder @ B )
=> ! [F2: A > B,F5: filter @ A,C2: B] :
( ( filterlim @ A @ B @ F2 @ ( at_top @ B ) @ F5 )
= ( ! [Z9: B] :
( ( ord_less @ B @ C2 @ Z9 )
=> ( eventually @ A
@ ^ [X2: A] : ( ord_less_eq @ B @ Z9 @ ( F2 @ X2 ) )
@ F5 ) ) ) ) ) ).
% filterlim_at_top_gt
thf(fact_4543_tendsto__upperbound,axiom,
! [B: $tType,A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [F2: B > A,X: A,F5: filter @ B,A3: A] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ F5 )
=> ( ( eventually @ B
@ ^ [I5: B] : ( ord_less_eq @ A @ ( F2 @ I5 ) @ A3 )
@ F5 )
=> ( ( F5
!= ( bot_bot @ ( filter @ B ) ) )
=> ( ord_less_eq @ A @ X @ A3 ) ) ) ) ) ).
% tendsto_upperbound
thf(fact_4544_tendsto__lowerbound,axiom,
! [B: $tType,A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [F2: B > A,X: A,F5: filter @ B,A3: A] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ F5 )
=> ( ( eventually @ B
@ ^ [I5: B] : ( ord_less_eq @ A @ A3 @ ( F2 @ I5 ) )
@ F5 )
=> ( ( F5
!= ( bot_bot @ ( filter @ B ) ) )
=> ( ord_less_eq @ A @ A3 @ X ) ) ) ) ) ).
% tendsto_lowerbound
thf(fact_4545_tendsto__le,axiom,
! [B: $tType,A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [F5: filter @ B,F2: B > A,X: A,G: B > A,Y: A] :
( ( F5
!= ( bot_bot @ ( filter @ B ) ) )
=> ( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ F5 )
=> ( ( filterlim @ B @ A @ G @ ( topolo7230453075368039082e_nhds @ A @ Y ) @ F5 )
=> ( ( eventually @ B
@ ^ [X2: B] : ( ord_less_eq @ A @ ( G @ X2 ) @ ( F2 @ X2 ) )
@ F5 )
=> ( ord_less_eq @ A @ Y @ X ) ) ) ) ) ) ).
% tendsto_le
thf(fact_4546_eventually__INF,axiom,
! [A: $tType,B: $tType,P2: A > $o,F5: B > ( filter @ A ),B3: set @ B] :
( ( eventually @ A @ P2 @ ( complete_Inf_Inf @ ( filter @ A ) @ ( image2 @ B @ ( filter @ A ) @ F5 @ B3 ) ) )
= ( ? [X8: set @ B] :
( ( ord_less_eq @ ( set @ B ) @ X8 @ B3 )
& ( finite_finite @ B @ X8 )
& ( eventually @ A @ P2 @ ( complete_Inf_Inf @ ( filter @ A ) @ ( image2 @ B @ ( filter @ A ) @ F5 @ X8 ) ) ) ) ) ) ).
% eventually_INF
thf(fact_4547_has__derivative__divide_H,axiom,
! [A: $tType,C: $tType] :
( ( ( real_V822414075346904944vector @ C )
& ( real_V3459762299906320749_field @ A ) )
=> ! [F2: C > A,F8: C > A,X: C,S3: set @ C,G: C > A,G6: C > A] :
( ( has_derivative @ C @ A @ F2 @ F8 @ ( topolo174197925503356063within @ C @ X @ S3 ) )
=> ( ( has_derivative @ C @ A @ G @ G6 @ ( topolo174197925503356063within @ C @ X @ S3 ) )
=> ( ( ( G @ X )
!= ( zero_zero @ A ) )
=> ( has_derivative @ C @ A
@ ^ [X2: C] : ( divide_divide @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ^ [H: C] : ( divide_divide @ A @ ( minus_minus @ A @ ( times_times @ A @ ( F8 @ H ) @ ( G @ X ) ) @ ( times_times @ A @ ( F2 @ X ) @ ( G6 @ H ) ) ) @ ( times_times @ A @ ( G @ X ) @ ( G @ X ) ) )
@ ( topolo174197925503356063within @ C @ X @ S3 ) ) ) ) ) ) ).
% has_derivative_divide'
thf(fact_4548_has__derivative__inverse,axiom,
! [A: $tType,C: $tType] :
( ( ( real_V822414075346904944vector @ C )
& ( real_V8999393235501362500lgebra @ A ) )
=> ! [F2: C > A,X: C,F8: C > A,S3: set @ C] :
( ( ( F2 @ X )
!= ( zero_zero @ A ) )
=> ( ( has_derivative @ C @ A @ F2 @ F8 @ ( topolo174197925503356063within @ C @ X @ S3 ) )
=> ( has_derivative @ C @ A
@ ^ [X2: C] : ( inverse_inverse @ A @ ( F2 @ X2 ) )
@ ^ [H: C] : ( uminus_uminus @ A @ ( times_times @ A @ ( times_times @ A @ ( inverse_inverse @ A @ ( F2 @ X ) ) @ ( F8 @ H ) ) @ ( inverse_inverse @ A @ ( F2 @ X ) ) ) )
@ ( topolo174197925503356063within @ C @ X @ S3 ) ) ) ) ) ).
% has_derivative_inverse
thf(fact_4549_has__derivative__inverse_H,axiom,
! [A: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [X: A,S3: set @ A] :
( ( X
!= ( zero_zero @ A ) )
=> ( has_derivative @ A @ A @ ( inverse_inverse @ A )
@ ^ [H: A] : ( uminus_uminus @ A @ ( times_times @ A @ ( times_times @ A @ ( inverse_inverse @ A @ X ) @ H ) @ ( inverse_inverse @ A @ X ) ) )
@ ( topolo174197925503356063within @ A @ X @ S3 ) ) ) ) ).
% has_derivative_inverse'
thf(fact_4550_tendsto__imp__filterlim__at__left,axiom,
! [B: $tType,A: $tType] :
( ( topolo2564578578187576103pology @ B )
=> ! [F2: A > B,L5: B,F5: filter @ A] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L5 ) @ F5 )
=> ( ( eventually @ A
@ ^ [X2: A] : ( ord_less @ B @ ( F2 @ X2 ) @ L5 )
@ F5 )
=> ( filterlim @ A @ B @ F2 @ ( topolo174197925503356063within @ B @ L5 @ ( set_ord_lessThan @ B @ L5 ) ) @ F5 ) ) ) ) ).
% tendsto_imp_filterlim_at_left
thf(fact_4551_filterlim__at__top__at__left,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo1944317154257567458pology @ A )
& ( linorder @ B ) )
=> ! [Q: A > $o,F2: A > B,P2: B > $o,G: B > A,A3: A] :
( ! [X5: A,Y4: A] :
( ( Q @ X5 )
=> ( ( Q @ Y4 )
=> ( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ord_less_eq @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) ) ) )
=> ( ! [X5: B] :
( ( P2 @ X5 )
=> ( ( F2 @ ( G @ X5 ) )
= X5 ) )
=> ( ! [X5: B] :
( ( P2 @ X5 )
=> ( Q @ ( G @ X5 ) ) )
=> ( ( eventually @ A @ Q @ ( topolo174197925503356063within @ A @ A3 @ ( set_ord_lessThan @ A @ A3 ) ) )
=> ( ! [B5: A] :
( ( Q @ B5 )
=> ( ord_less @ A @ B5 @ A3 ) )
=> ( ( eventually @ B @ P2 @ ( at_top @ B ) )
=> ( filterlim @ A @ B @ F2 @ ( at_top @ B ) @ ( topolo174197925503356063within @ A @ A3 @ ( set_ord_lessThan @ A @ A3 ) ) ) ) ) ) ) ) ) ) ).
% filterlim_at_top_at_left
thf(fact_4552_eventually__INF__base,axiom,
! [B: $tType,A: $tType,B3: set @ A,F5: A > ( filter @ B ),P2: B > $o] :
( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [A7: A] :
( ( member2 @ A @ A7 @ B3 )
=> ! [B5: A] :
( ( member2 @ A @ B5 @ B3 )
=> ? [X3: A] :
( ( member2 @ A @ X3 @ B3 )
& ( ord_less_eq @ ( filter @ B ) @ ( F5 @ X3 ) @ ( inf_inf @ ( filter @ B ) @ ( F5 @ A7 ) @ ( F5 @ B5 ) ) ) ) ) )
=> ( ( eventually @ B @ P2 @ ( complete_Inf_Inf @ ( filter @ B ) @ ( image2 @ A @ ( filter @ B ) @ F5 @ B3 ) ) )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ B3 )
& ( eventually @ B @ P2 @ ( F5 @ X2 ) ) ) ) ) ) ) ).
% eventually_INF_base
thf(fact_4553_tendsto__0__le,axiom,
! [B: $tType,C: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ C )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,F5: filter @ A,G: A > C,K5: real] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) ) @ F5 )
=> ( ( eventually @ A
@ ^ [X2: A] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ C @ ( G @ X2 ) ) @ ( times_times @ real @ ( real_V7770717601297561774m_norm @ B @ ( F2 @ X2 ) ) @ K5 ) )
@ F5 )
=> ( filterlim @ A @ C @ G @ ( topolo7230453075368039082e_nhds @ C @ ( zero_zero @ C ) ) @ F5 ) ) ) ) ).
% tendsto_0_le
thf(fact_4554_filterlim__at__withinI,axiom,
! [A: $tType,B: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [F2: B > A,C2: A,F5: filter @ B,A4: set @ A] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ C2 ) @ F5 )
=> ( ( eventually @ B
@ ^ [X2: B] : ( member2 @ A @ ( F2 @ X2 ) @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ C2 @ ( bot_bot @ ( set @ A ) ) ) ) )
@ F5 )
=> ( filterlim @ B @ A @ F2 @ ( topolo174197925503356063within @ A @ C2 @ A4 ) @ F5 ) ) ) ) ).
% filterlim_at_withinI
thf(fact_4555_has__derivative__divide,axiom,
! [A: $tType,C: $tType] :
( ( ( real_V822414075346904944vector @ C )
& ( real_V8999393235501362500lgebra @ A ) )
=> ! [F2: C > A,F8: C > A,X: C,S3: set @ C,G: C > A,G6: C > A] :
( ( has_derivative @ C @ A @ F2 @ F8 @ ( topolo174197925503356063within @ C @ X @ S3 ) )
=> ( ( has_derivative @ C @ A @ G @ G6 @ ( topolo174197925503356063within @ C @ X @ S3 ) )
=> ( ( ( G @ X )
!= ( zero_zero @ A ) )
=> ( has_derivative @ C @ A
@ ^ [X2: C] : ( divide_divide @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ^ [H: C] : ( plus_plus @ A @ ( times_times @ A @ ( uminus_uminus @ A @ ( F2 @ X ) ) @ ( times_times @ A @ ( times_times @ A @ ( inverse_inverse @ A @ ( G @ X ) ) @ ( G6 @ H ) ) @ ( inverse_inverse @ A @ ( G @ X ) ) ) ) @ ( divide_divide @ A @ ( F8 @ H ) @ ( G @ X ) ) )
@ ( topolo174197925503356063within @ C @ X @ S3 ) ) ) ) ) ) ).
% has_derivative_divide
thf(fact_4556_has__derivative__prod,axiom,
! [B: $tType,I7: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V3459762299906320749_field @ B ) )
=> ! [I6: set @ I7,F2: I7 > A > B,F8: I7 > A > B,X: A,S3: set @ A] :
( ! [I3: I7] :
( ( member2 @ I7 @ I3 @ I6 )
=> ( has_derivative @ A @ B @ ( F2 @ I3 ) @ ( F8 @ I3 ) @ ( topolo174197925503356063within @ A @ X @ S3 ) ) )
=> ( has_derivative @ A @ B
@ ^ [X2: A] :
( groups7121269368397514597t_prod @ I7 @ B
@ ^ [I5: I7] : ( F2 @ I5 @ X2 )
@ I6 )
@ ^ [Y2: A] :
( groups7311177749621191930dd_sum @ I7 @ B
@ ^ [I5: I7] :
( times_times @ B @ ( F8 @ I5 @ Y2 )
@ ( groups7121269368397514597t_prod @ I7 @ B
@ ^ [J3: I7] : ( F2 @ J3 @ X )
@ ( minus_minus @ ( set @ I7 ) @ I6 @ ( insert2 @ I7 @ I5 @ ( bot_bot @ ( set @ I7 ) ) ) ) ) )
@ I6 )
@ ( topolo174197925503356063within @ A @ X @ S3 ) ) ) ) ).
% has_derivative_prod
thf(fact_4557_has__derivative__at2,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,F8: A > B,X: A] :
( ( has_derivative @ A @ B @ F2 @ F8 @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) )
= ( ( real_V3181309239436604168linear @ A @ B @ F8 )
& ( filterlim @ A @ B
@ ^ [Y2: A] : ( real_V8093663219630862766scaleR @ B @ ( divide_divide @ real @ ( one_one @ real ) @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ Y2 @ X ) ) ) @ ( minus_minus @ B @ ( F2 @ Y2 ) @ ( plus_plus @ B @ ( F2 @ X ) @ ( F8 @ ( minus_minus @ A @ Y2 @ X ) ) ) ) )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ).
% has_derivative_at2
thf(fact_4558_has__derivative__at,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,D6: A > B,X: A] :
( ( has_derivative @ A @ B @ F2 @ D6 @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) )
= ( ( real_V3181309239436604168linear @ A @ B @ D6 )
& ( filterlim @ A @ real
@ ^ [H: A] : ( divide_divide @ real @ ( real_V7770717601297561774m_norm @ B @ ( minus_minus @ B @ ( minus_minus @ B @ ( F2 @ ( plus_plus @ A @ X @ H ) ) @ ( F2 @ X ) ) @ ( D6 @ H ) ) ) @ ( real_V7770717601297561774m_norm @ A @ H ) )
@ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ).
% has_derivative_at
thf(fact_4559_has__derivative__within,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,F8: A > B,X: A,S: set @ A] :
( ( has_derivative @ A @ B @ F2 @ F8 @ ( topolo174197925503356063within @ A @ X @ S ) )
= ( ( real_V3181309239436604168linear @ A @ B @ F8 )
& ( filterlim @ A @ B
@ ^ [Y2: A] : ( real_V8093663219630862766scaleR @ B @ ( divide_divide @ real @ ( one_one @ real ) @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ Y2 @ X ) ) ) @ ( minus_minus @ B @ ( F2 @ Y2 ) @ ( plus_plus @ B @ ( F2 @ X ) @ ( F8 @ ( minus_minus @ A @ Y2 @ X ) ) ) ) )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ).
% has_derivative_within
thf(fact_4560_summable__Cauchy_H,axiom,
! [A: $tType] :
( ( real_Vector_banach @ A )
=> ! [F2: nat > A,G: nat > real] :
( ( eventually @ nat
@ ^ [M2: nat] :
! [N: nat] :
( ( ord_less_eq @ nat @ M2 @ N )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or7035219750837199246ssThan @ nat @ M2 @ N ) ) ) @ ( G @ M2 ) ) )
@ ( at_top @ nat ) )
=> ( ( filterlim @ nat @ real @ G @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ ( at_top @ nat ) )
=> ( summable @ A @ F2 ) ) ) ) ).
% summable_Cauchy'
thf(fact_4561_bounded__linear__add,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,G: A > B] :
( ( real_V3181309239436604168linear @ A @ B @ F2 )
=> ( ( real_V3181309239436604168linear @ A @ B @ G )
=> ( real_V3181309239436604168linear @ A @ B
@ ^ [X2: A] : ( plus_plus @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ).
% bounded_linear_add
thf(fact_4562_bounded__linear__zero,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ( real_V3181309239436604168linear @ A @ B
@ ^ [X2: A] : ( zero_zero @ B ) ) ) ).
% bounded_linear_zero
thf(fact_4563_bounded__linear_Otendsto__zero,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,G: C > A,F5: filter @ C] :
( ( real_V3181309239436604168linear @ A @ B @ F2 )
=> ( ( filterlim @ C @ A @ G @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ F5 )
=> ( filterlim @ C @ B
@ ^ [X2: C] : ( F2 @ ( G @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ F5 ) ) ) ) ).
% bounded_linear.tendsto_zero
thf(fact_4564_eventually__all__ge__at__top,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [P2: A > $o] :
( ( eventually @ A @ P2 @ ( at_top @ A ) )
=> ( eventually @ A
@ ^ [X2: A] :
! [Y2: A] :
( ( ord_less_eq @ A @ X2 @ Y2 )
=> ( P2 @ Y2 ) )
@ ( at_top @ A ) ) ) ) ).
% eventually_all_ge_at_top
thf(fact_4565_has__derivative__within__singleton__iff,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,G: A > B,X: A] :
( ( has_derivative @ A @ B @ F2 @ G @ ( topolo174197925503356063within @ A @ X @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( real_V3181309239436604168linear @ A @ B @ G ) ) ) ).
% has_derivative_within_singleton_iff
thf(fact_4566_bounded__linear__intro,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,K5: real] :
( ! [X5: A,Y4: A] :
( ( F2 @ ( plus_plus @ A @ X5 @ Y4 ) )
= ( plus_plus @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ! [R3: real,X5: A] :
( ( F2 @ ( real_V8093663219630862766scaleR @ A @ R3 @ X5 ) )
= ( real_V8093663219630862766scaleR @ B @ R3 @ ( F2 @ X5 ) ) )
=> ( ! [X5: A] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ B @ ( F2 @ X5 ) ) @ ( times_times @ real @ ( real_V7770717601297561774m_norm @ A @ X5 ) @ K5 ) )
=> ( real_V3181309239436604168linear @ A @ B @ F2 ) ) ) ) ) ).
% bounded_linear_intro
thf(fact_4567_has__derivative__at__within,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,F8: A > B,X: A,S: set @ A] :
( ( has_derivative @ A @ B @ F2 @ F8 @ ( topolo174197925503356063within @ A @ X @ S ) )
= ( ( real_V3181309239436604168linear @ A @ B @ F8 )
& ( filterlim @ A @ B
@ ^ [Y2: A] : ( real_V8093663219630862766scaleR @ B @ ( inverse_inverse @ real @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ Y2 @ X ) ) ) @ ( minus_minus @ B @ ( minus_minus @ B @ ( F2 @ Y2 ) @ ( F2 @ X ) ) @ ( F8 @ ( minus_minus @ A @ Y2 @ X ) ) ) )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ).
% has_derivative_at_within
thf(fact_4568_has__derivativeI,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F8: A > B,X: A,F2: A > B,S: set @ A] :
( ( real_V3181309239436604168linear @ A @ B @ F8 )
=> ( ( filterlim @ A @ B
@ ^ [Y2: A] : ( real_V8093663219630862766scaleR @ B @ ( inverse_inverse @ real @ ( real_V7770717601297561774m_norm @ A @ ( minus_minus @ A @ Y2 @ X ) ) ) @ ( minus_minus @ B @ ( minus_minus @ B @ ( F2 @ Y2 ) @ ( F2 @ X ) ) @ ( F8 @ ( minus_minus @ A @ Y2 @ X ) ) ) )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( has_derivative @ A @ B @ F2 @ F8 @ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ).
% has_derivativeI
thf(fact_4569_has__derivative__iff__Ex,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,F8: A > B,X: A] :
( ( has_derivative @ A @ B @ F2 @ F8 @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) )
= ( ( real_V3181309239436604168linear @ A @ B @ F8 )
& ? [E4: A > B] :
( ! [H: A] :
( ( F2 @ ( plus_plus @ A @ X @ H ) )
= ( plus_plus @ B @ ( plus_plus @ B @ ( F2 @ X ) @ ( F8 @ H ) ) @ ( E4 @ H ) ) )
& ( filterlim @ A @ real
@ ^ [H: A] : ( divide_divide @ real @ ( real_V7770717601297561774m_norm @ B @ ( E4 @ H ) ) @ ( real_V7770717601297561774m_norm @ A @ H ) )
@ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ) ).
% has_derivative_iff_Ex
thf(fact_4570_summable__bounded__partials,axiom,
! [A: $tType] :
( ( ( real_V8037385150606011577_space @ A )
& ( real_V822414075346904944vector @ A ) )
=> ! [F2: nat > A,G: nat > real] :
( ( eventually @ nat
@ ^ [X02: nat] :
! [A5: nat] :
( ( ord_less_eq @ nat @ X02 @ A5 )
=> ! [B4: nat] :
( ( ord_less @ nat @ A5 @ B4 )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( groups7311177749621191930dd_sum @ nat @ A @ F2 @ ( set_or3652927894154168847AtMost @ nat @ A5 @ B4 ) ) ) @ ( G @ A5 ) ) ) )
@ ( at_top @ nat ) )
=> ( ( filterlim @ nat @ real @ G @ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) ) @ ( at_top @ nat ) )
=> ( summable @ A @ F2 ) ) ) ) ).
% summable_bounded_partials
thf(fact_4571_has__derivative__def,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ( ( has_derivative @ A @ B )
= ( ^ [F3: A > B,F9: A > B,F10: filter @ A] :
( ( real_V3181309239436604168linear @ A @ B @ F9 )
& ( filterlim @ A @ B
@ ^ [Y2: A] :
( real_V8093663219630862766scaleR @ B
@ ( inverse_inverse @ real
@ ( real_V7770717601297561774m_norm @ A
@ ( minus_minus @ A @ Y2
@ ( topolo3827282254853284352ce_Lim @ A @ A @ F10
@ ^ [X2: A] : X2 ) ) ) )
@ ( minus_minus @ B
@ ( minus_minus @ B @ ( F3 @ Y2 )
@ ( F3
@ ( topolo3827282254853284352ce_Lim @ A @ A @ F10
@ ^ [X2: A] : X2 ) ) )
@ ( F9
@ ( minus_minus @ A @ Y2
@ ( topolo3827282254853284352ce_Lim @ A @ A @ F10
@ ^ [X2: A] : X2 ) ) ) ) )
@ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) )
@ F10 ) ) ) ) ) ).
% has_derivative_def
thf(fact_4572_has__derivative__at__within__iff__Ex,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [X: A,S3: set @ A,F2: A > B,F8: A > B] :
( ( member2 @ A @ X @ S3 )
=> ( ( topolo1002775350975398744n_open @ A @ S3 )
=> ( ( has_derivative @ A @ B @ F2 @ F8 @ ( topolo174197925503356063within @ A @ X @ S3 ) )
= ( ( real_V3181309239436604168linear @ A @ B @ F8 )
& ? [E4: A > B] :
( ! [H: A] :
( ( member2 @ A @ ( plus_plus @ A @ X @ H ) @ S3 )
=> ( ( F2 @ ( plus_plus @ A @ X @ H ) )
= ( plus_plus @ B @ ( plus_plus @ B @ ( F2 @ X ) @ ( F8 @ H ) ) @ ( E4 @ H ) ) ) )
& ( filterlim @ A @ real
@ ^ [H: A] : ( divide_divide @ real @ ( real_V7770717601297561774m_norm @ B @ ( E4 @ H ) ) @ ( real_V7770717601297561774m_norm @ A @ H ) )
@ ( topolo7230453075368039082e_nhds @ real @ ( zero_zero @ real ) )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ) ) ) ).
% has_derivative_at_within_iff_Ex
thf(fact_4573_filterlim__pow__at__bot__even,axiom,
! [N2: nat,F2: real > real,F5: filter @ real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( filterlim @ real @ real @ F2 @ ( at_bot @ real ) @ F5 )
=> ( ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( filterlim @ real @ real
@ ^ [X2: real] : ( power_power @ real @ ( F2 @ X2 ) @ N2 )
@ ( at_top @ real )
@ F5 ) ) ) ) ).
% filterlim_pow_at_bot_even
thf(fact_4574_open__empty,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ( topolo1002775350975398744n_open @ A @ ( bot_bot @ ( set @ A ) ) ) ) ).
% open_empty
thf(fact_4575_greaterThanAtMost__iff,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [I: A,L: A,U: A] :
( ( member2 @ A @ I @ ( set_or3652927894154168847AtMost @ A @ L @ U ) )
= ( ( ord_less @ A @ L @ I )
& ( ord_less_eq @ A @ I @ U ) ) ) ) ).
% greaterThanAtMost_iff
thf(fact_4576_greaterThanAtMost__empty,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,K: A] :
( ( ord_less_eq @ A @ L @ K )
=> ( ( set_or3652927894154168847AtMost @ A @ K @ L )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% greaterThanAtMost_empty
thf(fact_4577_greaterThanAtMost__empty__iff2,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [K: A,L: A] :
( ( ( bot_bot @ ( set @ A ) )
= ( set_or3652927894154168847AtMost @ A @ K @ L ) )
= ( ~ ( ord_less @ A @ K @ L ) ) ) ) ).
% greaterThanAtMost_empty_iff2
thf(fact_4578_greaterThanAtMost__empty__iff,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [K: A,L: A] :
( ( ( set_or3652927894154168847AtMost @ A @ K @ L )
= ( bot_bot @ ( set @ A ) ) )
= ( ~ ( ord_less @ A @ K @ L ) ) ) ) ).
% greaterThanAtMost_empty_iff
thf(fact_4579_infinite__Ioc__iff,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A] :
( ( ~ ( finite_finite @ A @ ( set_or3652927894154168847AtMost @ A @ A3 @ B2 ) ) )
= ( ord_less @ A @ A3 @ B2 ) ) ) ).
% infinite_Ioc_iff
thf(fact_4580_image__add__greaterThanAtMost,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( image2 @ A @ A @ ( plus_plus @ A @ C2 ) @ ( set_or3652927894154168847AtMost @ A @ A3 @ B2 ) )
= ( set_or3652927894154168847AtMost @ A @ ( plus_plus @ A @ C2 @ A3 ) @ ( plus_plus @ A @ C2 @ B2 ) ) ) ) ).
% image_add_greaterThanAtMost
thf(fact_4581_Sup__greaterThanAtMost,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( ( complete_Sup_Sup @ A @ ( set_or3652927894154168847AtMost @ A @ X @ Y ) )
= Y ) ) ) ).
% Sup_greaterThanAtMost
thf(fact_4582_cSup__greaterThanAtMost,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [Y: A,X: A] :
( ( ord_less @ A @ Y @ X )
=> ( ( complete_Sup_Sup @ A @ ( set_or3652927894154168847AtMost @ A @ Y @ X ) )
= X ) ) ) ).
% cSup_greaterThanAtMost
thf(fact_4583_Inf__greaterThanAtMost,axiom,
! [A: $tType] :
( ( ( comple6319245703460814977attice @ A )
& ( dense_linorder @ A ) )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( ( complete_Inf_Inf @ A @ ( set_or3652927894154168847AtMost @ A @ X @ Y ) )
= X ) ) ) ).
% Inf_greaterThanAtMost
thf(fact_4584_cInf__greaterThanAtMost,axiom,
! [A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( dense_linorder @ A ) )
=> ! [Y: A,X: A] :
( ( ord_less @ A @ Y @ X )
=> ( ( complete_Inf_Inf @ A @ ( set_or3652927894154168847AtMost @ A @ Y @ X ) )
= Y ) ) ) ).
% cInf_greaterThanAtMost
thf(fact_4585_Ioc__inj,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ( set_or3652927894154168847AtMost @ A @ A3 @ B2 )
= ( set_or3652927894154168847AtMost @ A @ C2 @ D2 ) )
= ( ( ( ord_less_eq @ A @ B2 @ A3 )
& ( ord_less_eq @ A @ D2 @ C2 ) )
| ( ( A3 = C2 )
& ( B2 = D2 ) ) ) ) ) ).
% Ioc_inj
thf(fact_4586_open__left,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [S3: set @ A,X: A,Y: A] :
( ( topolo1002775350975398744n_open @ A @ S3 )
=> ( ( member2 @ A @ X @ S3 )
=> ( ( ord_less @ A @ Y @ X )
=> ? [B5: A] :
( ( ord_less @ A @ B5 @ X )
& ( ord_less_eq @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ B5 @ X ) @ S3 ) ) ) ) ) ) ).
% open_left
thf(fact_4587_openI,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S3: set @ A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ S3 )
=> ? [T9: set @ A] :
( ( topolo1002775350975398744n_open @ A @ T9 )
& ( member2 @ A @ X5 @ T9 )
& ( ord_less_eq @ ( set @ A ) @ T9 @ S3 ) ) )
=> ( topolo1002775350975398744n_open @ A @ S3 ) ) ) ).
% openI
thf(fact_4588_open__subopen,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ( ( topolo1002775350975398744n_open @ A )
= ( ^ [S8: set @ A] :
! [X2: A] :
( ( member2 @ A @ X2 @ S8 )
=> ? [T10: set @ A] :
( ( topolo1002775350975398744n_open @ A @ T10 )
& ( member2 @ A @ X2 @ T10 )
& ( ord_less_eq @ ( set @ A ) @ T10 @ S8 ) ) ) ) ) ) ).
% open_subopen
thf(fact_4589_first__countable__basis,axiom,
! [A: $tType] :
( ( topolo3112930676232923870pology @ A )
=> ! [X: A] :
? [A9: nat > ( set @ A )] :
( ! [I4: nat] :
( ( member2 @ A @ X @ ( A9 @ I4 ) )
& ( topolo1002775350975398744n_open @ A @ ( A9 @ I4 ) ) )
& ! [S9: set @ A] :
( ( ( topolo1002775350975398744n_open @ A @ S9 )
& ( member2 @ A @ X @ S9 ) )
=> ? [I3: nat] : ( ord_less_eq @ ( set @ A ) @ ( A9 @ I3 ) @ S9 ) ) ) ) ).
% first_countable_basis
thf(fact_4590_Sup__notin__open,axiom,
! [A: $tType] :
( ( topolo8458572112393995274pology @ A )
=> ! [A4: set @ A,X: A] :
( ( topolo1002775350975398744n_open @ A @ A4 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less @ A @ X5 @ X ) )
=> ~ ( member2 @ A @ ( complete_Sup_Sup @ A @ A4 ) @ A4 ) ) ) ) ).
% Sup_notin_open
thf(fact_4591_Inf__notin__open,axiom,
! [A: $tType] :
( ( topolo8458572112393995274pology @ A )
=> ! [A4: set @ A,X: A] :
( ( topolo1002775350975398744n_open @ A @ A4 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less @ A @ X @ X5 ) )
=> ~ ( member2 @ A @ ( complete_Inf_Inf @ A @ A4 ) @ A4 ) ) ) ) ).
% Inf_notin_open
thf(fact_4592_not__open__singleton,axiom,
! [A: $tType] :
( ( topolo8386298272705272623_space @ A )
=> ! [X: A] :
~ ( topolo1002775350975398744n_open @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% not_open_singleton
thf(fact_4593_separation__t2,axiom,
! [A: $tType] :
( ( topological_t2_space @ A )
=> ! [X: A,Y: A] :
( ( X != Y )
= ( ? [U5: set @ A,V6: set @ A] :
( ( topolo1002775350975398744n_open @ A @ U5 )
& ( topolo1002775350975398744n_open @ A @ V6 )
& ( member2 @ A @ X @ U5 )
& ( member2 @ A @ Y @ V6 )
& ( ( inf_inf @ ( set @ A ) @ U5 @ V6 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% separation_t2
thf(fact_4594_hausdorff,axiom,
! [A: $tType] :
( ( topological_t2_space @ A )
=> ! [X: A,Y: A] :
( ( X != Y )
=> ? [U6: set @ A,V7: set @ A] :
( ( topolo1002775350975398744n_open @ A @ U6 )
& ( topolo1002775350975398744n_open @ A @ V7 )
& ( member2 @ A @ X @ U6 )
& ( member2 @ A @ Y @ V7 )
& ( ( inf_inf @ ( set @ A ) @ U6 @ V7 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% hausdorff
thf(fact_4595_trivial__limit__at__bot__linorder,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( at_bot @ A )
!= ( bot_bot @ ( filter @ A ) ) ) ) ).
% trivial_limit_at_bot_linorder
thf(fact_4596_atLeastSucAtMost__greaterThanAtMost,axiom,
! [L: nat,U: nat] :
( ( set_or1337092689740270186AtMost @ nat @ ( suc @ L ) @ U )
= ( set_or3652927894154168847AtMost @ nat @ L @ U ) ) ).
% atLeastSucAtMost_greaterThanAtMost
thf(fact_4597_Ioc__subset__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ A3 @ B2 ) @ ( set_or3652927894154168847AtMost @ A @ C2 @ D2 ) )
= ( ( ord_less_eq @ A @ B2 @ A3 )
| ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less_eq @ A @ B2 @ D2 ) ) ) ) ) ).
% Ioc_subset_iff
thf(fact_4598_infinite__Ioc,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ~ ( finite_finite @ A @ ( set_or3652927894154168847AtMost @ A @ A3 @ B2 ) ) ) ) ).
% infinite_Ioc
thf(fact_4599_ivl__disj__int__two_I6_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,M: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ L @ M ) @ ( set_or3652927894154168847AtMost @ A @ M @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_two(6)
thf(fact_4600_at__within__open__subset,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [A3: A,S3: set @ A,T4: set @ A] :
( ( member2 @ A @ A3 @ S3 )
=> ( ( topolo1002775350975398744n_open @ A @ S3 )
=> ( ( ord_less_eq @ ( set @ A ) @ S3 @ T4 )
=> ( ( topolo174197925503356063within @ A @ A3 @ T4 )
= ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ) ).
% at_within_open_subset
thf(fact_4601_open__right,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [S3: set @ A,X: A,Y: A] :
( ( topolo1002775350975398744n_open @ A @ S3 )
=> ( ( member2 @ A @ X @ S3 )
=> ( ( ord_less @ A @ X @ Y )
=> ? [B5: A] :
( ( ord_less @ A @ X @ B5 )
& ( ord_less_eq @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ X @ B5 ) @ S3 ) ) ) ) ) ) ).
% open_right
thf(fact_4602_Ioc__disjoint,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ( inf_inf @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ A3 @ B2 ) @ ( set_or3652927894154168847AtMost @ A @ C2 @ D2 ) )
= ( bot_bot @ ( set @ A ) ) )
= ( ( ord_less_eq @ A @ B2 @ A3 )
| ( ord_less_eq @ A @ D2 @ C2 )
| ( ord_less_eq @ A @ B2 @ C2 )
| ( ord_less_eq @ A @ D2 @ A3 ) ) ) ) ).
% Ioc_disjoint
thf(fact_4603_eventually__at__bot__linorder,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [P2: A > $o] :
( ( eventually @ A @ P2 @ ( at_bot @ A ) )
= ( ? [N6: A] :
! [N: A] :
( ( ord_less_eq @ A @ N @ N6 )
=> ( P2 @ N ) ) ) ) ) ).
% eventually_at_bot_linorder
thf(fact_4604_eventually__at__bot__dense,axiom,
! [A: $tType] :
( ( ( linorder @ A )
& ( no_bot @ A ) )
=> ! [P2: A > $o] :
( ( eventually @ A @ P2 @ ( at_bot @ A ) )
= ( ? [N6: A] :
! [N: A] :
( ( ord_less @ A @ N @ N6 )
=> ( P2 @ N ) ) ) ) ) ).
% eventually_at_bot_dense
thf(fact_4605_ivl__disj__int__two_I8_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,M: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ L @ M ) @ ( set_or3652927894154168847AtMost @ A @ M @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_two(8)
thf(fact_4606_ivl__disj__int__one_I3_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_ord_atMost @ A @ L ) @ ( set_or3652927894154168847AtMost @ A @ L @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_one(3)
thf(fact_4607_ivl__disj__int__two_I2_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,M: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ L @ M ) @ ( set_or5935395276787703475ssThan @ A @ M @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_two(2)
thf(fact_4608_Lim__ident__at,axiom,
! [A: $tType] :
( ( topological_t2_space @ A )
=> ! [X: A,S: set @ A] :
( ( ( topolo174197925503356063within @ A @ X @ S )
!= ( bot_bot @ ( filter @ A ) ) )
=> ( ( topolo3827282254853284352ce_Lim @ A @ A @ ( topolo174197925503356063within @ A @ X @ S )
@ ^ [X2: A] : X2 )
= X ) ) ) ).
% Lim_ident_at
thf(fact_4609_countable__basis__at__decseq,axiom,
! [A: $tType] :
( ( topolo3112930676232923870pology @ A )
=> ! [X: A] :
~ ! [A9: nat > ( set @ A )] :
( ! [I4: nat] : ( topolo1002775350975398744n_open @ A @ ( A9 @ I4 ) )
=> ( ! [I4: nat] : ( member2 @ A @ X @ ( A9 @ I4 ) )
=> ~ ! [S9: set @ A] :
( ( topolo1002775350975398744n_open @ A @ S9 )
=> ( ( member2 @ A @ X @ S9 )
=> ( eventually @ nat
@ ^ [I5: nat] : ( ord_less_eq @ ( set @ A ) @ ( A9 @ I5 ) @ S9 )
@ ( at_top @ nat ) ) ) ) ) ) ) ).
% countable_basis_at_decseq
thf(fact_4610_eventually__le__at__bot,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [C2: A] :
( eventually @ A
@ ^ [X2: A] : ( ord_less_eq @ A @ X2 @ C2 )
@ ( at_bot @ A ) ) ) ).
% eventually_le_at_bot
thf(fact_4611_eventually__gt__at__bot,axiom,
! [A: $tType] :
( ( unboun7993243217541854897norder @ A )
=> ! [C2: A] :
( eventually @ A
@ ^ [X2: A] : ( ord_less @ A @ X2 @ C2 )
@ ( at_bot @ A ) ) ) ).
% eventually_gt_at_bot
thf(fact_4612_lim__explicit,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [F2: nat > A,F0: A] :
( ( filterlim @ nat @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ F0 ) @ ( at_top @ nat ) )
= ( ! [S8: set @ A] :
( ( topolo1002775350975398744n_open @ A @ S8 )
=> ( ( member2 @ A @ F0 @ S8 )
=> ? [N6: nat] :
! [N: nat] :
( ( ord_less_eq @ nat @ N6 @ N )
=> ( member2 @ A @ ( F2 @ N ) @ S8 ) ) ) ) ) ) ) ).
% lim_explicit
thf(fact_4613_sum_Ohead,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( plus_plus @ A @ ( G @ M ) @ ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or3652927894154168847AtMost @ nat @ M @ N2 ) ) ) ) ) ) ).
% sum.head
thf(fact_4614_prod_Ohead,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( times_times @ A @ ( G @ M ) @ ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or3652927894154168847AtMost @ nat @ M @ N2 ) ) ) ) ) ) ).
% prod.head
thf(fact_4615_greaterThanAtMost__subseteq__atLeastAtMost__iff,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ A3 @ B2 ) @ ( set_or1337092689740270186AtMost @ A @ C2 @ D2 ) )
= ( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less_eq @ A @ B2 @ D2 ) ) ) ) ) ).
% greaterThanAtMost_subseteq_atLeastAtMost_iff
thf(fact_4616_tendsto__Lim,axiom,
! [A: $tType,B: $tType] :
( ( topological_t2_space @ B )
=> ! [Net: filter @ A,F2: A > B,L: B] :
( ( Net
!= ( bot_bot @ ( filter @ A ) ) )
=> ( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L ) @ Net )
=> ( ( topolo3827282254853284352ce_Lim @ A @ B @ Net @ F2 )
= L ) ) ) ) ).
% tendsto_Lim
thf(fact_4617_greaterThanAtMost__subseteq__atLeastLessThan__iff,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ A3 @ B2 ) @ ( set_or7035219750837199246ssThan @ A @ C2 @ D2 ) )
= ( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less @ A @ B2 @ D2 ) ) ) ) ) ).
% greaterThanAtMost_subseteq_atLeastLessThan_iff
thf(fact_4618_greaterThanLessThan__subseteq__greaterThanAtMost__iff,axiom,
! [A: $tType] :
( ( dense_linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) @ ( set_or3652927894154168847AtMost @ A @ C2 @ D2 ) )
= ( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ C2 @ A3 )
& ( ord_less_eq @ A @ B2 @ D2 ) ) ) ) ) ).
% greaterThanLessThan_subseteq_greaterThanAtMost_iff
thf(fact_4619_greaterThanAtMost__eq__atLeastAtMost__diff,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( set_or3652927894154168847AtMost @ A )
= ( ^ [A5: A,B4: A] : ( minus_minus @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ A5 @ B4 ) @ ( insert2 @ A @ A5 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% greaterThanAtMost_eq_atLeastAtMost_diff
thf(fact_4620_at__within__nhd,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [X: A,S3: set @ A,T4: set @ A,U3: set @ A] :
( ( member2 @ A @ X @ S3 )
=> ( ( topolo1002775350975398744n_open @ A @ S3 )
=> ( ( ( minus_minus @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ T4 @ S3 ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( minus_minus @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ U3 @ S3 ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( ( topolo174197925503356063within @ A @ X @ T4 )
= ( topolo174197925503356063within @ A @ X @ U3 ) ) ) ) ) ) ).
% at_within_nhd
thf(fact_4621_at__eq__bot__iff,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [A3: A] :
( ( ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) )
= ( bot_bot @ ( filter @ A ) ) )
= ( topolo1002775350975398744n_open @ A @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% at_eq_bot_iff
thf(fact_4622_filterlim__at__bot__le,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ B )
=> ! [F2: A > B,F5: filter @ A,C2: B] :
( ( filterlim @ A @ B @ F2 @ ( at_bot @ B ) @ F5 )
= ( ! [Z9: B] :
( ( ord_less_eq @ B @ Z9 @ C2 )
=> ( eventually @ A
@ ^ [X2: A] : ( ord_less_eq @ B @ ( F2 @ X2 ) @ Z9 )
@ F5 ) ) ) ) ) ).
% filterlim_at_bot_le
thf(fact_4623_filterlim__at__bot,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ B )
=> ! [F2: A > B,F5: filter @ A] :
( ( filterlim @ A @ B @ F2 @ ( at_bot @ B ) @ F5 )
= ( ! [Z9: B] :
( eventually @ A
@ ^ [X2: A] : ( ord_less_eq @ B @ ( F2 @ X2 ) @ Z9 )
@ F5 ) ) ) ) ).
% filterlim_at_bot
thf(fact_4624_filterlim__at__bot__dense,axiom,
! [A: $tType,B: $tType] :
( ( ( dense_linorder @ B )
& ( no_bot @ B ) )
=> ! [F2: A > B,F5: filter @ A] :
( ( filterlim @ A @ B @ F2 @ ( at_bot @ B ) @ F5 )
= ( ! [Z9: B] :
( eventually @ A
@ ^ [X2: A] : ( ord_less @ B @ ( F2 @ X2 ) @ Z9 )
@ F5 ) ) ) ) ).
% filterlim_at_bot_dense
thf(fact_4625_filterlim__at__bot__lt,axiom,
! [A: $tType,B: $tType] :
( ( unboun7993243217541854897norder @ B )
=> ! [F2: A > B,F5: filter @ A,C2: B] :
( ( filterlim @ A @ B @ F2 @ ( at_bot @ B ) @ F5 )
= ( ! [Z9: B] :
( ( ord_less @ B @ Z9 @ C2 )
=> ( eventually @ A
@ ^ [X2: A] : ( ord_less_eq @ B @ ( F2 @ X2 ) @ Z9 )
@ F5 ) ) ) ) ) ).
% filterlim_at_bot_lt
thf(fact_4626_tendsto__offset__zero__iff,axiom,
! [C: $tType,D: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( topolo4958980785337419405_space @ D )
& ( zero @ C ) )
=> ! [A3: A,S3: set @ A,F2: A > D,L5: D] :
( ( nO_MATCH @ C @ A @ ( zero_zero @ C ) @ A3 )
=> ( ( member2 @ A @ A3 @ S3 )
=> ( ( topolo1002775350975398744n_open @ A @ S3 )
=> ( ( filterlim @ A @ D @ F2 @ ( topolo7230453075368039082e_nhds @ D @ L5 ) @ ( topolo174197925503356063within @ A @ A3 @ S3 ) )
= ( filterlim @ A @ D
@ ^ [H: A] : ( F2 @ ( plus_plus @ A @ A3 @ H ) )
@ ( topolo7230453075368039082e_nhds @ D @ L5 )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ) ) ) ).
% tendsto_offset_zero_iff
thf(fact_4627_nth__sorted__list__of__set__greaterThanAtMost,axiom,
! [N2: nat,J: nat,I: nat] :
( ( ord_less @ nat @ N2 @ ( minus_minus @ nat @ J @ I ) )
=> ( ( nth @ nat @ ( linord4507533701916653071of_set @ nat @ ( set_or3652927894154168847AtMost @ nat @ I @ J ) ) @ N2 )
= ( suc @ ( plus_plus @ nat @ I @ N2 ) ) ) ) ).
% nth_sorted_list_of_set_greaterThanAtMost
thf(fact_4628_filterlim__pow__at__bot__odd,axiom,
! [N2: nat,F2: real > real,F5: filter @ real] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( filterlim @ real @ real @ F2 @ ( at_bot @ real ) @ F5 )
=> ( ~ ( dvd_dvd @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 )
=> ( filterlim @ real @ real
@ ^ [X2: real] : ( power_power @ real @ ( F2 @ X2 ) @ N2 )
@ ( at_bot @ real )
@ F5 ) ) ) ) ).
% filterlim_pow_at_bot_odd
thf(fact_4629_eventually__filtercomap__at__topological,axiom,
! [A: $tType,B: $tType] :
( ( topolo4958980785337419405_space @ B )
=> ! [P2: A > $o,F2: A > B,A4: B,B3: set @ B] :
( ( eventually @ A @ P2 @ ( filtercomap @ A @ B @ F2 @ ( topolo174197925503356063within @ B @ A4 @ B3 ) ) )
= ( ? [S8: set @ B] :
( ( topolo1002775350975398744n_open @ B @ S8 )
& ( member2 @ B @ A4 @ S8 )
& ! [X2: A] :
( ( member2 @ B @ ( F2 @ X2 ) @ ( minus_minus @ ( set @ B ) @ ( inf_inf @ ( set @ B ) @ S8 @ B3 ) @ ( insert2 @ B @ A4 @ ( bot_bot @ ( set @ B ) ) ) ) )
=> ( P2 @ X2 ) ) ) ) ) ) ).
% eventually_filtercomap_at_topological
thf(fact_4630_at__within__eq,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ( ( topolo174197925503356063within @ A )
= ( ^ [X2: A,S7: set @ A] :
( complete_Inf_Inf @ ( filter @ A )
@ ( image2 @ ( set @ A ) @ ( filter @ A )
@ ^ [S8: set @ A] : ( principal @ A @ ( minus_minus @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ S8 @ S7 ) @ ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) ) )
@ ( collect @ ( set @ A )
@ ^ [S8: set @ A] :
( ( topolo1002775350975398744n_open @ A @ S8 )
& ( member2 @ A @ X2 @ S8 ) ) ) ) ) ) ) ) ).
% at_within_eq
thf(fact_4631_compactE__image,axiom,
! [A: $tType,B: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S3: set @ A,C5: set @ B,F2: B > ( set @ A )] :
( ( topolo2193935891317330818ompact @ A @ S3 )
=> ( ! [T6: B] :
( ( member2 @ B @ T6 @ C5 )
=> ( topolo1002775350975398744n_open @ A @ ( F2 @ T6 ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ S3 @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ F2 @ C5 ) ) )
=> ~ ! [C7: set @ B] :
( ( ord_less_eq @ ( set @ B ) @ C7 @ C5 )
=> ( ( finite_finite @ B @ C7 )
=> ~ ( ord_less_eq @ ( set @ A ) @ S3 @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ F2 @ C7 ) ) ) ) ) ) ) ) ) ).
% compactE_image
thf(fact_4632_compactE,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S3: set @ A,T11: set @ ( set @ A )] :
( ( topolo2193935891317330818ompact @ A @ S3 )
=> ( ( ord_less_eq @ ( set @ A ) @ S3 @ ( complete_Sup_Sup @ ( set @ A ) @ T11 ) )
=> ( ! [B8: set @ A] :
( ( member2 @ ( set @ A ) @ B8 @ T11 )
=> ( topolo1002775350975398744n_open @ A @ B8 ) )
=> ~ ! [T12: set @ ( set @ A )] :
( ( ord_less_eq @ ( set @ ( set @ A ) ) @ T12 @ T11 )
=> ( ( finite_finite @ ( set @ A ) @ T12 )
=> ~ ( ord_less_eq @ ( set @ A ) @ S3 @ ( complete_Sup_Sup @ ( set @ A ) @ T12 ) ) ) ) ) ) ) ) ).
% compactE
thf(fact_4633_filtercomap__bot,axiom,
! [B: $tType,A: $tType,F2: A > B] :
( ( filtercomap @ A @ B @ F2 @ ( bot_bot @ ( filter @ B ) ) )
= ( bot_bot @ ( filter @ A ) ) ) ).
% filtercomap_bot
thf(fact_4634_principal__le__iff,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( filter @ A ) @ ( principal @ A @ A4 ) @ ( principal @ A @ B3 ) )
= ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ).
% principal_le_iff
thf(fact_4635_compact__empty,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ( topolo2193935891317330818ompact @ A @ ( bot_bot @ ( set @ A ) ) ) ) ).
% compact_empty
thf(fact_4636_principal__eq__bot__iff,axiom,
! [A: $tType,X7: set @ A] :
( ( ( principal @ A @ X7 )
= ( bot_bot @ ( filter @ A ) ) )
= ( X7
= ( bot_bot @ ( set @ A ) ) ) ) ).
% principal_eq_bot_iff
thf(fact_4637_bot__eq__principal__empty,axiom,
! [A: $tType] :
( ( bot_bot @ ( filter @ A ) )
= ( principal @ A @ ( bot_bot @ ( set @ A ) ) ) ) ).
% bot_eq_principal_empty
thf(fact_4638_filtercomap__neq__bot,axiom,
! [A: $tType,B: $tType,F5: filter @ A,F2: B > A] :
( ! [P8: A > $o] :
( ( eventually @ A @ P8 @ F5 )
=> ? [X3: B] : ( P8 @ ( F2 @ X3 ) ) )
=> ( ( filtercomap @ B @ A @ F2 @ F5 )
!= ( bot_bot @ ( filter @ B ) ) ) ) ).
% filtercomap_neq_bot
thf(fact_4639_compact__attains__sup,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [S3: set @ A] :
( ( topolo2193935891317330818ompact @ A @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ S3 )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ S3 )
=> ( ord_less_eq @ A @ Xa @ X5 ) ) ) ) ) ) ).
% compact_attains_sup
thf(fact_4640_compact__attains__inf,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [S3: set @ A] :
( ( topolo2193935891317330818ompact @ A @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ S3 )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ S3 )
=> ( ord_less_eq @ A @ X5 @ Xa ) ) ) ) ) ) ).
% compact_attains_inf
thf(fact_4641_nhds__discrete,axiom,
! [A: $tType] :
( ( topolo8865339358273720382pology @ A )
=> ( ( topolo7230453075368039082e_nhds @ A )
= ( ^ [X2: A] : ( principal @ A @ ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% nhds_discrete
thf(fact_4642_eventually__filtercomap__at__top__linorder,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ A )
=> ! [P2: B > $o,F2: B > A] :
( ( eventually @ B @ P2 @ ( filtercomap @ B @ A @ F2 @ ( at_top @ A ) ) )
= ( ? [N6: A] :
! [X2: B] :
( ( ord_less_eq @ A @ N6 @ ( F2 @ X2 ) )
=> ( P2 @ X2 ) ) ) ) ) ).
% eventually_filtercomap_at_top_linorder
thf(fact_4643_eventually__filtercomap__at__top__dense,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( no_top @ A ) )
=> ! [P2: B > $o,F2: B > A] :
( ( eventually @ B @ P2 @ ( filtercomap @ B @ A @ F2 @ ( at_top @ A ) ) )
= ( ? [N6: A] :
! [X2: B] :
( ( ord_less @ A @ N6 @ ( F2 @ X2 ) )
=> ( P2 @ X2 ) ) ) ) ) ).
% eventually_filtercomap_at_top_dense
thf(fact_4644_filtercomap__neq__bot__surj,axiom,
! [A: $tType,B: $tType,F5: filter @ A,F2: B > A] :
( ( F5
!= ( bot_bot @ ( filter @ A ) ) )
=> ( ( ( image2 @ B @ A @ F2 @ ( top_top @ ( set @ B ) ) )
= ( top_top @ ( set @ A ) ) )
=> ( ( filtercomap @ B @ A @ F2 @ F5 )
!= ( bot_bot @ ( filter @ B ) ) ) ) ) ).
% filtercomap_neq_bot_surj
thf(fact_4645_eventually__filtercomap__at__bot__linorder,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ A )
=> ! [P2: B > $o,F2: B > A] :
( ( eventually @ B @ P2 @ ( filtercomap @ B @ A @ F2 @ ( at_bot @ A ) ) )
= ( ? [N6: A] :
! [X2: B] :
( ( ord_less_eq @ A @ ( F2 @ X2 ) @ N6 )
=> ( P2 @ X2 ) ) ) ) ) ).
% eventually_filtercomap_at_bot_linorder
thf(fact_4646_eventually__filtercomap__at__bot__dense,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( no_bot @ A ) )
=> ! [P2: B > $o,F2: B > A] :
( ( eventually @ B @ P2 @ ( filtercomap @ B @ A @ F2 @ ( at_bot @ A ) ) )
= ( ? [N6: A] :
! [X2: B] :
( ( ord_less @ A @ ( F2 @ X2 ) @ N6 )
=> ( P2 @ X2 ) ) ) ) ) ).
% eventually_filtercomap_at_bot_dense
thf(fact_4647_tendsto__principal__singleton,axiom,
! [A: $tType,B: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [F2: B > A,X: B] : ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ ( F2 @ X ) ) @ ( principal @ B @ ( insert2 @ B @ X @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ).
% tendsto_principal_singleton
thf(fact_4648_nhds__discrete__open,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [X: A] :
( ( topolo1002775350975398744n_open @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
=> ( ( topolo7230453075368039082e_nhds @ A @ X )
= ( principal @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% nhds_discrete_open
thf(fact_4649_filterlim__base__iff,axiom,
! [A: $tType,C: $tType,B: $tType,D: $tType,I6: set @ A,F5: A > ( set @ B ),F2: B > C,G7: D > ( set @ C ),J4: set @ D] :
( ( I6
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [I3: A] :
( ( member2 @ A @ I3 @ I6 )
=> ! [J2: A] :
( ( member2 @ A @ J2 @ I6 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( F5 @ I3 ) @ ( F5 @ J2 ) )
| ( ord_less_eq @ ( set @ B ) @ ( F5 @ J2 ) @ ( F5 @ I3 ) ) ) ) )
=> ( ( filterlim @ B @ C @ F2
@ ( complete_Inf_Inf @ ( filter @ C )
@ ( image2 @ D @ ( filter @ C )
@ ^ [J3: D] : ( principal @ C @ ( G7 @ J3 ) )
@ J4 ) )
@ ( complete_Inf_Inf @ ( filter @ B )
@ ( image2 @ A @ ( filter @ B )
@ ^ [I5: A] : ( principal @ B @ ( F5 @ I5 ) )
@ I6 ) ) )
= ( ! [X2: D] :
( ( member2 @ D @ X2 @ J4 )
=> ? [Y2: A] :
( ( member2 @ A @ Y2 @ I6 )
& ! [Z6: B] :
( ( member2 @ B @ Z6 @ ( F5 @ Y2 ) )
=> ( member2 @ C @ ( F2 @ Z6 ) @ ( G7 @ X2 ) ) ) ) ) ) ) ) ) ).
% filterlim_base_iff
thf(fact_4650_at__within__def,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ( ( topolo174197925503356063within @ A )
= ( ^ [A5: A,S7: set @ A] : ( inf_inf @ ( filter @ A ) @ ( topolo7230453075368039082e_nhds @ A @ A5 ) @ ( principal @ A @ ( minus_minus @ ( set @ A ) @ S7 @ ( insert2 @ A @ A5 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ).
% at_within_def
thf(fact_4651_at__left__eq,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [Y: A,X: A] :
( ( ord_less @ A @ Y @ X )
=> ( ( topolo174197925503356063within @ A @ X @ ( set_ord_lessThan @ A @ X ) )
= ( complete_Inf_Inf @ ( filter @ A )
@ ( image2 @ A @ ( filter @ A )
@ ^ [A5: A] : ( principal @ A @ ( set_or5935395276787703475ssThan @ A @ A5 @ X ) )
@ ( set_ord_lessThan @ A @ X ) ) ) ) ) ) ).
% at_left_eq
thf(fact_4652_compact__eq__Heine__Borel,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ( ( topolo2193935891317330818ompact @ A )
= ( ^ [S8: set @ A] :
! [C8: set @ ( set @ A )] :
( ( ! [X2: set @ A] :
( ( member2 @ ( set @ A ) @ X2 @ C8 )
=> ( topolo1002775350975398744n_open @ A @ X2 ) )
& ( ord_less_eq @ ( set @ A ) @ S8 @ ( complete_Sup_Sup @ ( set @ A ) @ C8 ) ) )
=> ? [D7: set @ ( set @ A )] :
( ( ord_less_eq @ ( set @ ( set @ A ) ) @ D7 @ C8 )
& ( finite_finite @ ( set @ A ) @ D7 )
& ( ord_less_eq @ ( set @ A ) @ S8 @ ( complete_Sup_Sup @ ( set @ A ) @ D7 ) ) ) ) ) ) ) ).
% compact_eq_Heine_Borel
thf(fact_4653_compactI,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S: set @ A] :
( ! [C6: set @ ( set @ A )] :
( ! [X3: set @ A] :
( ( member2 @ ( set @ A ) @ X3 @ C6 )
=> ( topolo1002775350975398744n_open @ A @ X3 ) )
=> ( ( ord_less_eq @ ( set @ A ) @ S @ ( complete_Sup_Sup @ ( set @ A ) @ C6 ) )
=> ? [C9: set @ ( set @ A )] :
( ( ord_less_eq @ ( set @ ( set @ A ) ) @ C9 @ C6 )
& ( finite_finite @ ( set @ A ) @ C9 )
& ( ord_less_eq @ ( set @ A ) @ S @ ( complete_Sup_Sup @ ( set @ A ) @ C9 ) ) ) ) )
=> ( topolo2193935891317330818ompact @ A @ S ) ) ) ).
% compactI
thf(fact_4654_at__within__order,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [X: A,S: set @ A] :
( ( ( top_top @ ( set @ A ) )
!= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
=> ( ( topolo174197925503356063within @ A @ X @ S )
= ( inf_inf @ ( filter @ A )
@ ( complete_Inf_Inf @ ( filter @ A )
@ ( image2 @ A @ ( filter @ A )
@ ^ [A5: A] : ( principal @ A @ ( minus_minus @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ ( set_ord_lessThan @ A @ A5 ) @ S ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
@ ( set_ord_greaterThan @ A @ X ) ) )
@ ( complete_Inf_Inf @ ( filter @ A )
@ ( image2 @ A @ ( filter @ A )
@ ^ [A5: A] : ( principal @ A @ ( minus_minus @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ ( set_ord_greaterThan @ A @ A5 ) @ S ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
@ ( set_ord_lessThan @ A @ X ) ) ) ) ) ) ) ).
% at_within_order
thf(fact_4655_tendsto__at__iff__sequentially,axiom,
! [C: $tType,A: $tType] :
( ( ( topolo3112930676232923870pology @ A )
& ( topolo4958980785337419405_space @ C ) )
=> ! [F2: A > C,A3: C,X: A,S: set @ A] :
( ( filterlim @ A @ C @ F2 @ ( topolo7230453075368039082e_nhds @ C @ A3 ) @ ( topolo174197925503356063within @ A @ X @ S ) )
= ( ! [X8: nat > A] :
( ! [I5: nat] : ( member2 @ A @ ( X8 @ I5 ) @ ( minus_minus @ ( set @ A ) @ S @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( ( filterlim @ nat @ A @ X8 @ ( topolo7230453075368039082e_nhds @ A @ X ) @ ( at_top @ nat ) )
=> ( filterlim @ nat @ C @ ( comp @ A @ C @ nat @ F2 @ X8 ) @ ( topolo7230453075368039082e_nhds @ C @ A3 ) @ ( at_top @ nat ) ) ) ) ) ) ) ).
% tendsto_at_iff_sequentially
thf(fact_4656_sequentially__imp__eventually__at__left,axiom,
! [A: $tType] :
( ( ( topolo3112930676232923870pology @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [B2: A,A3: A,P2: A > $o] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ! [F4: nat > A] :
( ! [N5: nat] : ( ord_less @ A @ B2 @ ( F4 @ N5 ) )
=> ( ! [N5: nat] : ( ord_less @ A @ ( F4 @ N5 ) @ A3 )
=> ( ( order_mono @ nat @ A @ F4 )
=> ( ( filterlim @ nat @ A @ F4 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ ( at_top @ nat ) )
=> ( eventually @ nat
@ ^ [N: nat] : ( P2 @ ( F4 @ N ) )
@ ( at_top @ nat ) ) ) ) ) )
=> ( eventually @ A @ P2 @ ( topolo174197925503356063within @ A @ A3 @ ( set_ord_lessThan @ A @ A3 ) ) ) ) ) ) ).
% sequentially_imp_eventually_at_left
thf(fact_4657_greaterThan__iff,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [I: A,K: A] :
( ( member2 @ A @ I @ ( set_ord_greaterThan @ A @ K ) )
= ( ord_less @ A @ K @ I ) ) ) ).
% greaterThan_iff
thf(fact_4658_greaterThan__subset__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_ord_greaterThan @ A @ X ) @ ( set_ord_greaterThan @ A @ Y ) )
= ( ord_less_eq @ A @ Y @ X ) ) ) ).
% greaterThan_subset_iff
thf(fact_4659_Sup__greaterThanAtLeast,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [X: A] :
( ( ord_less @ A @ X @ ( top_top @ A ) )
=> ( ( complete_Sup_Sup @ A @ ( set_ord_greaterThan @ A @ X ) )
= ( top_top @ A ) ) ) ) ).
% Sup_greaterThanAtLeast
thf(fact_4660_mono__def,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ( ( order_mono @ A @ B )
= ( ^ [F3: A > B] :
! [X2: A,Y2: A] :
( ( ord_less_eq @ A @ X2 @ Y2 )
=> ( ord_less_eq @ B @ ( F3 @ X2 ) @ ( F3 @ Y2 ) ) ) ) ) ) ).
% mono_def
thf(fact_4661_monoI,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ! [F2: A > B] :
( ! [X5: A,Y4: A] :
( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ord_less_eq @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( order_mono @ A @ B @ F2 ) ) ) ).
% monoI
thf(fact_4662_monoE,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ! [F2: A > B,X: A,Y: A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( ord_less_eq @ A @ X @ Y )
=> ( ord_less_eq @ B @ ( F2 @ X ) @ ( F2 @ Y ) ) ) ) ) ).
% monoE
thf(fact_4663_monoD,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ! [F2: A > B,X: A,Y: A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( ord_less_eq @ A @ X @ Y )
=> ( ord_less_eq @ B @ ( F2 @ X ) @ ( F2 @ Y ) ) ) ) ) ).
% monoD
thf(fact_4664_greaterThan__non__empty,axiom,
! [A: $tType] :
( ( no_top @ A )
=> ! [X: A] :
( ( set_ord_greaterThan @ A @ X )
!= ( bot_bot @ ( set @ A ) ) ) ) ).
% greaterThan_non_empty
thf(fact_4665_mono__funpow,axiom,
! [A: $tType] :
( ( ( lattice @ A )
& ( order_bot @ A ) )
=> ! [Q: A > A] :
( ( order_mono @ A @ A @ Q )
=> ( order_mono @ nat @ A
@ ^ [I5: nat] : ( compow @ ( A > A ) @ I5 @ Q @ ( bot_bot @ A ) ) ) ) ) ).
% mono_funpow
thf(fact_4666_greaterThan__def,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( set_ord_greaterThan @ A )
= ( ^ [L2: A] : ( collect @ A @ ( ord_less @ A @ L2 ) ) ) ) ) ).
% greaterThan_def
thf(fact_4667_mono__pow,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,N2: nat] :
( ( order_mono @ A @ A @ F2 )
=> ( order_mono @ A @ A @ ( compow @ ( A > A ) @ N2 @ F2 ) ) ) ) ).
% mono_pow
thf(fact_4668_comp__funpow,axiom,
! [B: $tType,A: $tType,N2: nat,F2: A > A] :
( ( compow @ ( ( B > A ) > B > A ) @ N2 @ ( comp @ A @ A @ B @ F2 ) )
= ( comp @ A @ A @ B @ ( compow @ ( A > A ) @ N2 @ F2 ) ) ) ).
% comp_funpow
thf(fact_4669_mono__Suc,axiom,
order_mono @ nat @ nat @ suc ).
% mono_Suc
thf(fact_4670_mono__add,axiom,
! [A: $tType] :
( ( ordere6658533253407199908up_add @ A )
=> ! [A3: A] : ( order_mono @ A @ A @ ( plus_plus @ A @ A3 ) ) ) ).
% mono_add
thf(fact_4671_mono__strict__invE,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( order @ B ) )
=> ! [F2: A > B,X: A,Y: A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( ord_less @ B @ ( F2 @ X ) @ ( F2 @ Y ) )
=> ( ord_less @ A @ X @ Y ) ) ) ) ).
% mono_strict_invE
thf(fact_4672_card_Ocomp__fun__commute__on,axiom,
( ( comp @ nat @ nat @ nat @ suc @ suc )
= ( comp @ nat @ nat @ nat @ suc @ suc ) ) ).
% card.comp_fun_commute_on
thf(fact_4673_max__of__mono,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( linorder @ B ) )
=> ! [F2: A > B,M: A,N2: A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( ord_max @ B @ ( F2 @ M ) @ ( F2 @ N2 ) )
= ( F2 @ ( ord_max @ A @ M @ N2 ) ) ) ) ) ).
% max_of_mono
thf(fact_4674_incseq__Suc__iff,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( order_mono @ nat @ A )
= ( ^ [F3: nat > A] :
! [N: nat] : ( ord_less_eq @ A @ ( F3 @ N ) @ ( F3 @ ( suc @ N ) ) ) ) ) ) ).
% incseq_Suc_iff
thf(fact_4675_incseq__SucI,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X7: nat > A] :
( ! [N3: nat] : ( ord_less_eq @ A @ ( X7 @ N3 ) @ ( X7 @ ( suc @ N3 ) ) )
=> ( order_mono @ nat @ A @ X7 ) ) ) ).
% incseq_SucI
thf(fact_4676_incseq__SucD,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A4: nat > A,I: nat] :
( ( order_mono @ nat @ A @ A4 )
=> ( ord_less_eq @ A @ ( A4 @ I ) @ ( A4 @ ( suc @ I ) ) ) ) ) ).
% incseq_SucD
thf(fact_4677_incseqD,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [F2: nat > A,I: nat,J: nat] :
( ( order_mono @ nat @ A @ F2 )
=> ( ( ord_less_eq @ nat @ I @ J )
=> ( ord_less_eq @ A @ ( F2 @ I ) @ ( F2 @ J ) ) ) ) ) ).
% incseqD
thf(fact_4678_incseq__def,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( order_mono @ nat @ A )
= ( ^ [X8: nat > A] :
! [M2: nat,N: nat] :
( ( ord_less_eq @ nat @ M2 @ N )
=> ( ord_less_eq @ A @ ( X8 @ M2 ) @ ( X8 @ N ) ) ) ) ) ) ).
% incseq_def
thf(fact_4679_mono__invE,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( order @ B ) )
=> ! [F2: A > B,X: A,Y: A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( ord_less @ B @ ( F2 @ X ) @ ( F2 @ Y ) )
=> ( ord_less_eq @ A @ X @ Y ) ) ) ) ).
% mono_invE
thf(fact_4680_mono__inf,axiom,
! [B: $tType,A: $tType] :
( ( ( semilattice_inf @ A )
& ( semilattice_inf @ B ) )
=> ! [F2: A > B,A4: A,B3: A] :
( ( order_mono @ A @ B @ F2 )
=> ( ord_less_eq @ B @ ( F2 @ ( inf_inf @ A @ A4 @ B3 ) ) @ ( inf_inf @ B @ ( F2 @ A4 ) @ ( F2 @ B3 ) ) ) ) ) ).
% mono_inf
thf(fact_4681_funpow__mono,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [F2: A > A,A4: A,B3: A,N2: nat] :
( ( order_mono @ A @ A @ F2 )
=> ( ( ord_less_eq @ A @ A4 @ B3 )
=> ( ord_less_eq @ A @ ( compow @ ( A > A ) @ N2 @ F2 @ A4 ) @ ( compow @ ( A > A ) @ N2 @ F2 @ B3 ) ) ) ) ) ).
% funpow_mono
thf(fact_4682_funpow__Suc__right,axiom,
! [A: $tType,N2: nat,F2: A > A] :
( ( compow @ ( A > A ) @ ( suc @ N2 ) @ F2 )
= ( comp @ A @ A @ A @ ( compow @ ( A > A ) @ N2 @ F2 ) @ F2 ) ) ).
% funpow_Suc_right
thf(fact_4683_funpow_Osimps_I2_J,axiom,
! [A: $tType,N2: nat,F2: A > A] :
( ( compow @ ( A > A ) @ ( suc @ N2 ) @ F2 )
= ( comp @ A @ A @ A @ F2 @ ( compow @ ( A > A ) @ N2 @ F2 ) ) ) ).
% funpow.simps(2)
thf(fact_4684_funpow__add,axiom,
! [A: $tType,M: nat,N2: nat,F2: A > A] :
( ( compow @ ( A > A ) @ ( plus_plus @ nat @ M @ N2 ) @ F2 )
= ( comp @ A @ A @ A @ ( compow @ ( A > A ) @ M @ F2 ) @ ( compow @ ( A > A ) @ N2 @ F2 ) ) ) ).
% funpow_add
thf(fact_4685_lessThan__Int__lessThan,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( inf_inf @ ( set @ A ) @ ( set_ord_greaterThan @ A @ A3 ) @ ( set_ord_greaterThan @ A @ B2 ) )
= ( set_ord_greaterThan @ A @ ( ord_max @ A @ A3 @ B2 ) ) ) ) ).
% lessThan_Int_lessThan
thf(fact_4686_trivial__limit__at__right__real,axiom,
! [A: $tType] :
( ( ( dense_order @ A )
& ( no_top @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [X: A] :
( ( topolo174197925503356063within @ A @ X @ ( set_ord_greaterThan @ A @ X ) )
!= ( bot_bot @ ( filter @ A ) ) ) ) ).
% trivial_limit_at_right_real
thf(fact_4687_cclfp__lowerbound,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [F2: A > A,A4: A] :
( ( order_mono @ A @ A @ F2 )
=> ( ( ord_less_eq @ A @ ( F2 @ A4 ) @ A4 )
=> ( ord_less_eq @ A @ ( order_532582986084564980_cclfp @ A @ F2 ) @ A4 ) ) ) ) ).
% cclfp_lowerbound
thf(fact_4688_mono__times__nat,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( order_mono @ nat @ nat @ ( times_times @ nat @ N2 ) ) ) ).
% mono_times_nat
thf(fact_4689_mono__mult,axiom,
! [A: $tType] :
( ( ordered_semiring @ A )
=> ! [A3: A] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( order_mono @ A @ A @ ( times_times @ A @ A3 ) ) ) ) ).
% mono_mult
thf(fact_4690_INT__greaterThan__UNIV,axiom,
( ( complete_Inf_Inf @ ( set @ nat ) @ ( image2 @ nat @ ( set @ nat ) @ ( set_ord_greaterThan @ nat ) @ ( top_top @ ( set @ nat ) ) ) )
= ( bot_bot @ ( set @ nat ) ) ) ).
% INT_greaterThan_UNIV
thf(fact_4691_mono__image__least,axiom,
! [A: $tType,B: $tType] :
( ( ( order @ B )
& ( order @ A ) )
=> ! [F2: A > B,M: A,N2: A,M6: B,N4: B] :
( ( order_mono @ A @ B @ F2 )
=> ( ( ( image2 @ A @ B @ F2 @ ( set_or7035219750837199246ssThan @ A @ M @ N2 ) )
= ( set_or7035219750837199246ssThan @ B @ M6 @ N4 ) )
=> ( ( ord_less @ A @ M @ N2 )
=> ( ( F2 @ M )
= M6 ) ) ) ) ) ).
% mono_image_least
thf(fact_4692_sum__comp__morphism,axiom,
! [A: $tType,B: $tType,C: $tType] :
( ( ( comm_monoid_add @ B )
& ( comm_monoid_add @ A ) )
=> ! [H2: B > A,G: C > B,A4: set @ C] :
( ( ( H2 @ ( zero_zero @ B ) )
= ( zero_zero @ A ) )
=> ( ! [X5: B,Y4: B] :
( ( H2 @ ( plus_plus @ B @ X5 @ Y4 ) )
= ( plus_plus @ A @ ( H2 @ X5 ) @ ( H2 @ Y4 ) ) )
=> ( ( groups7311177749621191930dd_sum @ C @ A @ ( comp @ B @ A @ C @ H2 @ G ) @ A4 )
= ( H2 @ ( groups7311177749621191930dd_sum @ C @ B @ G @ A4 ) ) ) ) ) ) ).
% sum_comp_morphism
thf(fact_4693_Kleene__iter__gpfp,axiom,
! [A: $tType] :
( ( order_top @ A )
=> ! [F2: A > A,P4: A,K: nat] :
( ( order_mono @ A @ A @ F2 )
=> ( ( ord_less_eq @ A @ P4 @ ( F2 @ P4 ) )
=> ( ord_less_eq @ A @ P4 @ ( compow @ ( A > A ) @ K @ F2 @ ( top_top @ A ) ) ) ) ) ) ).
% Kleene_iter_gpfp
thf(fact_4694_Kleene__iter__lpfp,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ! [F2: A > A,P4: A,K: nat] :
( ( order_mono @ A @ A @ F2 )
=> ( ( ord_less_eq @ A @ ( F2 @ P4 ) @ P4 )
=> ( ord_less_eq @ A @ ( compow @ ( A > A ) @ K @ F2 @ ( bot_bot @ A ) ) @ P4 ) ) ) ) ).
% Kleene_iter_lpfp
thf(fact_4695_funpow__mono2,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [F2: A > A,I: nat,J: nat,X: A,Y: A] :
( ( order_mono @ A @ A @ F2 )
=> ( ( ord_less_eq @ nat @ I @ J )
=> ( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_less_eq @ A @ X @ ( F2 @ X ) )
=> ( ord_less_eq @ A @ ( compow @ ( A > A ) @ I @ F2 @ X ) @ ( compow @ ( A > A ) @ J @ F2 @ Y ) ) ) ) ) ) ) ).
% funpow_mono2
thf(fact_4696_sum_OatLeast__Suc__atMost__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ ( comp @ nat @ A @ nat @ G @ suc ) @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% sum.atLeast_Suc_atMost_Suc_shift
thf(fact_4697_sum_OatLeast__Suc__lessThan__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ ( comp @ nat @ A @ nat @ G @ suc ) @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ).
% sum.atLeast_Suc_lessThan_Suc_shift
thf(fact_4698_sum_OatLeastAtMost__shift__bounds,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,K: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( plus_plus @ nat @ M @ K ) @ ( plus_plus @ nat @ N2 @ K ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ ( comp @ nat @ A @ nat @ G @ ( plus_plus @ nat @ K ) ) @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% sum.atLeastAtMost_shift_bounds
thf(fact_4699_sum_OatLeastLessThan__shift__bounds,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,K: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( plus_plus @ nat @ M @ K ) @ ( plus_plus @ nat @ N2 @ K ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ ( comp @ nat @ A @ nat @ G @ ( plus_plus @ nat @ K ) ) @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ).
% sum.atLeastLessThan_shift_bounds
thf(fact_4700_prod_OatLeast__Suc__atMost__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7121269368397514597t_prod @ nat @ A @ ( comp @ nat @ A @ nat @ G @ suc ) @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% prod.atLeast_Suc_atMost_Suc_shift
thf(fact_4701_prod_OatLeast__Suc__lessThan__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7121269368397514597t_prod @ nat @ A @ ( comp @ nat @ A @ nat @ G @ suc ) @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ).
% prod.atLeast_Suc_lessThan_Suc_shift
thf(fact_4702_prod_OatLeastAtMost__shift__bounds,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,K: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( plus_plus @ nat @ M @ K ) @ ( plus_plus @ nat @ N2 @ K ) ) )
= ( groups7121269368397514597t_prod @ nat @ A @ ( comp @ nat @ A @ nat @ G @ ( plus_plus @ nat @ K ) ) @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% prod.atLeastAtMost_shift_bounds
thf(fact_4703_prod_OatLeastLessThan__shift__bounds,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,K: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( plus_plus @ nat @ M @ K ) @ ( plus_plus @ nat @ N2 @ K ) ) )
= ( groups7121269368397514597t_prod @ nat @ A @ ( comp @ nat @ A @ nat @ G @ ( plus_plus @ nat @ K ) ) @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ).
% prod.atLeastLessThan_shift_bounds
thf(fact_4704_eventually__at__right__field,axiom,
! [A: $tType] :
( ( ( linordered_field @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [P2: A > $o,X: A] :
( ( eventually @ A @ P2 @ ( topolo174197925503356063within @ A @ X @ ( set_ord_greaterThan @ A @ X ) ) )
= ( ? [B4: A] :
( ( ord_less @ A @ X @ B4 )
& ! [Y2: A] :
( ( ord_less @ A @ X @ Y2 )
=> ( ( ord_less @ A @ Y2 @ B4 )
=> ( P2 @ Y2 ) ) ) ) ) ) ) ).
% eventually_at_right_field
thf(fact_4705_eventually__at__right,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [X: A,Y: A,P2: A > $o] :
( ( ord_less @ A @ X @ Y )
=> ( ( eventually @ A @ P2 @ ( topolo174197925503356063within @ A @ X @ ( set_ord_greaterThan @ A @ X ) ) )
= ( ? [B4: A] :
( ( ord_less @ A @ X @ B4 )
& ! [Y2: A] :
( ( ord_less @ A @ X @ Y2 )
=> ( ( ord_less @ A @ Y2 @ B4 )
=> ( P2 @ Y2 ) ) ) ) ) ) ) ) ).
% eventually_at_right
thf(fact_4706_at__within__Icc__at__right,axiom,
! [A: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( topolo174197925503356063within @ A @ A3 @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
= ( topolo174197925503356063within @ A @ A3 @ ( set_ord_greaterThan @ A @ A3 ) ) ) ) ) ).
% at_within_Icc_at_right
thf(fact_4707_bit__drop__bit__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [N2: nat,A3: A] :
( ( bit_se5641148757651400278ts_bit @ A @ ( bit_se4197421643247451524op_bit @ A @ N2 @ A3 ) )
= ( comp @ nat @ $o @ nat @ ( bit_se5641148757651400278ts_bit @ A @ A3 ) @ ( plus_plus @ nat @ N2 ) ) ) ) ).
% bit_drop_bit_eq
thf(fact_4708_ivl__disj__int__one_I7_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ L @ U ) @ ( set_ord_greaterThan @ A @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_one(7)
thf(fact_4709_mono__SUP,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( ( comple6319245703460814977attice @ A )
& ( comple6319245703460814977attice @ B ) )
=> ! [F2: A > B,A4: C > A,I6: set @ C] :
( ( order_mono @ A @ B @ F2 )
=> ( ord_less_eq @ B
@ ( complete_Sup_Sup @ B
@ ( image2 @ C @ B
@ ^ [X2: C] : ( F2 @ ( A4 @ X2 ) )
@ I6 ) )
@ ( F2 @ ( complete_Sup_Sup @ A @ ( image2 @ C @ A @ A4 @ I6 ) ) ) ) ) ) ).
% mono_SUP
thf(fact_4710_mono__Sup,axiom,
! [B: $tType,A: $tType] :
( ( ( comple6319245703460814977attice @ A )
& ( comple6319245703460814977attice @ B ) )
=> ! [F2: A > B,A4: set @ A] :
( ( order_mono @ A @ B @ F2 )
=> ( ord_less_eq @ B @ ( complete_Sup_Sup @ B @ ( image2 @ A @ B @ F2 @ A4 ) ) @ ( F2 @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ).
% mono_Sup
thf(fact_4711_mono__INF,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( ( comple6319245703460814977attice @ A )
& ( comple6319245703460814977attice @ B ) )
=> ! [F2: A > B,A4: C > A,I6: set @ C] :
( ( order_mono @ A @ B @ F2 )
=> ( ord_less_eq @ B @ ( F2 @ ( complete_Inf_Inf @ A @ ( image2 @ C @ A @ A4 @ I6 ) ) )
@ ( complete_Inf_Inf @ B
@ ( image2 @ C @ B
@ ^ [X2: C] : ( F2 @ ( A4 @ X2 ) )
@ I6 ) ) ) ) ) ).
% mono_INF
thf(fact_4712_mono__Inf,axiom,
! [B: $tType,A: $tType] :
( ( ( comple6319245703460814977attice @ A )
& ( comple6319245703460814977attice @ B ) )
=> ! [F2: A > B,A4: set @ A] :
( ( order_mono @ A @ B @ F2 )
=> ( ord_less_eq @ B @ ( F2 @ ( complete_Inf_Inf @ A @ A4 ) ) @ ( complete_Inf_Inf @ B @ ( image2 @ A @ B @ F2 @ A4 ) ) ) ) ) ).
% mono_Inf
thf(fact_4713_trivial__limit__at__right__top,axiom,
! [A: $tType] :
( ( ( order_top @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ( ( topolo174197925503356063within @ A @ ( top_top @ A ) @ ( set_ord_greaterThan @ A @ ( top_top @ A ) ) )
= ( bot_bot @ ( filter @ A ) ) ) ) ).
% trivial_limit_at_right_top
thf(fact_4714_ivl__disj__int__one_I5_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ L @ U ) @ ( set_ord_greaterThan @ A @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_one(5)
thf(fact_4715_eventually__at__right__less,axiom,
! [A: $tType] :
( ( ( no_top @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [X: A] : ( eventually @ A @ ( ord_less @ A @ X ) @ ( topolo174197925503356063within @ A @ X @ ( set_ord_greaterThan @ A @ X ) ) ) ) ).
% eventually_at_right_less
thf(fact_4716_incseq__le,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [X7: nat > A,L5: A,N2: nat] :
( ( order_mono @ nat @ A @ X7 )
=> ( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ L5 ) @ ( at_top @ nat ) )
=> ( ord_less_eq @ A @ ( X7 @ N2 ) @ L5 ) ) ) ) ).
% incseq_le
thf(fact_4717_sum_Oreindex__nontrivial,axiom,
! [C: $tType,A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,H2: B > C,G: C > A] :
( ( finite_finite @ B @ A4 )
=> ( ! [X5: B,Y4: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ( member2 @ B @ Y4 @ A4 )
=> ( ( X5 != Y4 )
=> ( ( ( H2 @ X5 )
= ( H2 @ Y4 ) )
=> ( ( G @ ( H2 @ X5 ) )
= ( zero_zero @ A ) ) ) ) ) )
=> ( ( groups7311177749621191930dd_sum @ C @ A @ G @ ( image2 @ B @ C @ H2 @ A4 ) )
= ( groups7311177749621191930dd_sum @ B @ A @ ( comp @ C @ A @ B @ G @ H2 ) @ A4 ) ) ) ) ) ).
% sum.reindex_nontrivial
thf(fact_4718_funpow__increasing,axiom,
! [A: $tType] :
( ( ( lattice @ A )
& ( order_top @ A ) )
=> ! [M: nat,N2: nat,F2: A > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( order_mono @ A @ A @ F2 )
=> ( ord_less_eq @ A @ ( compow @ ( A > A ) @ N2 @ F2 @ ( top_top @ A ) ) @ ( compow @ ( A > A ) @ M @ F2 @ ( top_top @ A ) ) ) ) ) ) ).
% funpow_increasing
thf(fact_4719_funpow__decreasing,axiom,
! [A: $tType] :
( ( ( lattice @ A )
& ( order_bot @ A ) )
=> ! [M: nat,N2: nat,F2: A > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( order_mono @ A @ A @ F2 )
=> ( ord_less_eq @ A @ ( compow @ ( A > A ) @ M @ F2 @ ( bot_bot @ A ) ) @ ( compow @ ( A > A ) @ N2 @ F2 @ ( bot_bot @ A ) ) ) ) ) ) ).
% funpow_decreasing
thf(fact_4720_DERIV__at__within__shift__lemma,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,Y: A,Z: A,X: A,S3: set @ A] :
( ( has_field_derivative @ A @ F2 @ Y @ ( topolo174197925503356063within @ A @ ( plus_plus @ A @ Z @ X ) @ ( image2 @ A @ A @ ( plus_plus @ A @ Z ) @ S3 ) ) )
=> ( has_field_derivative @ A @ ( comp @ A @ A @ A @ F2 @ ( plus_plus @ A @ Z ) ) @ Y @ ( topolo174197925503356063within @ A @ X @ S3 ) ) ) ) ).
% DERIV_at_within_shift_lemma
thf(fact_4721_less__separate,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ? [A7: A,B5: A] :
( ( member2 @ A @ X @ ( set_ord_lessThan @ A @ A7 ) )
& ( member2 @ A @ Y @ ( set_ord_greaterThan @ A @ B5 ) )
& ( ( inf_inf @ ( set @ A ) @ ( set_ord_lessThan @ A @ A7 ) @ ( set_ord_greaterThan @ A @ B5 ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% less_separate
thf(fact_4722_eventually__at__rightI,axiom,
! [A: $tType] :
( ( topolo2564578578187576103pology @ A )
=> ! [A3: A,B2: A,P2: A > $o] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) )
=> ( P2 @ X5 ) )
=> ( ( ord_less @ A @ A3 @ B2 )
=> ( eventually @ A @ P2 @ ( topolo174197925503356063within @ A @ A3 @ ( set_ord_greaterThan @ A @ A3 ) ) ) ) ) ) ).
% eventually_at_rightI
thf(fact_4723_greaterThan__0,axiom,
( ( set_ord_greaterThan @ nat @ ( zero_zero @ nat ) )
= ( image2 @ nat @ nat @ suc @ ( top_top @ ( set @ nat ) ) ) ) ).
% greaterThan_0
thf(fact_4724_sum__image__le,axiom,
! [A: $tType,B: $tType,C: $tType] :
( ( ordere6911136660526730532id_add @ B )
=> ! [I6: set @ C,G: A > B,F2: C > A] :
( ( finite_finite @ C @ I6 )
=> ( ! [I3: C] :
( ( member2 @ C @ I3 @ I6 )
=> ( ord_less_eq @ B @ ( zero_zero @ B ) @ ( G @ ( F2 @ I3 ) ) ) )
=> ( ord_less_eq @ B @ ( groups7311177749621191930dd_sum @ A @ B @ G @ ( image2 @ C @ A @ F2 @ I6 ) ) @ ( groups7311177749621191930dd_sum @ C @ B @ ( comp @ A @ B @ C @ G @ F2 ) @ I6 ) ) ) ) ) ).
% sum_image_le
thf(fact_4725_filterlim__shift__iff,axiom,
! [B: $tType,A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: A > B,D2: A,F5: filter @ B,A3: A] :
( ( filterlim @ A @ B @ ( comp @ A @ B @ A @ F2 @ ( plus_plus @ A @ D2 ) ) @ F5 @ ( topolo174197925503356063within @ A @ ( minus_minus @ A @ A3 @ D2 ) @ ( top_top @ ( set @ A ) ) ) )
= ( filterlim @ A @ B @ F2 @ F5 @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% filterlim_shift_iff
thf(fact_4726_filterlim__shift,axiom,
! [B: $tType,A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: A > B,F5: filter @ B,A3: A,D2: A] :
( ( filterlim @ A @ B @ F2 @ F5 @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) )
=> ( filterlim @ A @ B @ ( comp @ A @ B @ A @ F2 @ ( plus_plus @ A @ D2 ) ) @ F5 @ ( topolo174197925503356063within @ A @ ( minus_minus @ A @ A3 @ D2 ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% filterlim_shift
thf(fact_4727_sum_OatLeast0__atMost__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( G @ ( zero_zero @ nat ) ) @ ( groups7311177749621191930dd_sum @ nat @ A @ ( comp @ nat @ A @ nat @ G @ suc ) @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ) ).
% sum.atLeast0_atMost_Suc_shift
thf(fact_4728_sum_OatLeast0__lessThan__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) ) )
= ( plus_plus @ A @ ( G @ ( zero_zero @ nat ) ) @ ( groups7311177749621191930dd_sum @ nat @ A @ ( comp @ nat @ A @ nat @ G @ suc ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ) ).
% sum.atLeast0_lessThan_Suc_shift
thf(fact_4729_prod_OatLeast0__atMost__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( G @ ( zero_zero @ nat ) ) @ ( groups7121269368397514597t_prod @ nat @ A @ ( comp @ nat @ A @ nat @ G @ suc ) @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ) ).
% prod.atLeast0_atMost_Suc_shift
thf(fact_4730_prod_OatLeast0__lessThan__Suc__shift,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( suc @ N2 ) ) )
= ( times_times @ A @ ( G @ ( zero_zero @ nat ) ) @ ( groups7121269368397514597t_prod @ nat @ A @ ( comp @ nat @ A @ nat @ G @ suc ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ) ).
% prod.atLeast0_lessThan_Suc_shift
thf(fact_4731_sum_OatLeastLessThan__shift__0,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ ( comp @ nat @ A @ nat @ G @ ( plus_plus @ nat @ M ) ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ) ).
% sum.atLeastLessThan_shift_0
thf(fact_4732_prod_OatLeastLessThan__shift__0,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) )
= ( groups7121269368397514597t_prod @ nat @ A @ ( comp @ nat @ A @ nat @ G @ ( plus_plus @ nat @ M ) ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ) ).
% prod.atLeastLessThan_shift_0
thf(fact_4733_greaterThan__Suc,axiom,
! [K: nat] :
( ( set_ord_greaterThan @ nat @ ( suc @ K ) )
= ( minus_minus @ ( set @ nat ) @ ( set_ord_greaterThan @ nat @ K ) @ ( insert2 @ nat @ ( suc @ K ) @ ( bot_bot @ ( set @ nat ) ) ) ) ) ).
% greaterThan_Suc
thf(fact_4734_sum_OatLeast__atMost__pred__shift,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ( comp @ nat @ A @ nat @ G
@ ^ [N: nat] : ( minus_minus @ nat @ N @ ( suc @ ( zero_zero @ nat ) ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% sum.atLeast_atMost_pred_shift
thf(fact_4735_sum_OatLeast__lessThan__pred__shift,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7311177749621191930dd_sum @ nat @ A
@ ( comp @ nat @ A @ nat @ G
@ ^ [N: nat] : ( minus_minus @ nat @ N @ ( suc @ ( zero_zero @ nat ) ) ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ).
% sum.atLeast_lessThan_pred_shift
thf(fact_4736_prod_OatLeast__atMost__pred__shift,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A
@ ( comp @ nat @ A @ nat @ G
@ ^ [N: nat] : ( minus_minus @ nat @ N @ ( suc @ ( zero_zero @ nat ) ) ) )
@ ( set_or1337092689740270186AtMost @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) ) ) ) ).
% prod.atLeast_atMost_pred_shift
thf(fact_4737_prod_OatLeast__lessThan__pred__shift,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: nat > A,M: nat,N2: nat] :
( ( groups7121269368397514597t_prod @ nat @ A
@ ( comp @ nat @ A @ nat @ G
@ ^ [N: nat] : ( minus_minus @ nat @ N @ ( suc @ ( zero_zero @ nat ) ) ) )
@ ( set_or7035219750837199246ssThan @ nat @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ).
% prod.atLeast_lessThan_pred_shift
thf(fact_4738_filterlim__times__pos,axiom,
! [A: $tType,B: $tType] :
( ( ( linordered_field @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [F2: B > A,P4: A,F12: filter @ B,C2: A,L: A] :
( ( filterlim @ B @ A @ F2 @ ( topolo174197925503356063within @ A @ P4 @ ( set_ord_greaterThan @ A @ P4 ) ) @ F12 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( L
= ( times_times @ A @ C2 @ P4 ) )
=> ( filterlim @ B @ A
@ ^ [X2: B] : ( times_times @ A @ C2 @ ( F2 @ X2 ) )
@ ( topolo174197925503356063within @ A @ L @ ( set_ord_greaterThan @ A @ L ) )
@ F12 ) ) ) ) ) ).
% filterlim_times_pos
thf(fact_4739_tendsto__imp__filterlim__at__right,axiom,
! [B: $tType,A: $tType] :
( ( topolo2564578578187576103pology @ B )
=> ! [F2: A > B,L5: B,F5: filter @ A] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L5 ) @ F5 )
=> ( ( eventually @ A
@ ^ [X2: A] : ( ord_less @ B @ L5 @ ( F2 @ X2 ) )
@ F5 )
=> ( filterlim @ A @ B @ F2 @ ( topolo174197925503356063within @ B @ L5 @ ( set_ord_greaterThan @ B @ L5 ) ) @ F5 ) ) ) ) ).
% tendsto_imp_filterlim_at_right
thf(fact_4740_mono__ge2__power__minus__self,axiom,
! [K: nat] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ K )
=> ( order_mono @ nat @ nat
@ ^ [M2: nat] : ( minus_minus @ nat @ ( power_power @ nat @ K @ M2 ) @ M2 ) ) ) ).
% mono_ge2_power_minus_self
thf(fact_4741_sum_OatLeastAtMost__shift__0,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7311177749621191930dd_sum @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( groups7311177749621191930dd_sum @ nat @ A @ ( comp @ nat @ A @ nat @ G @ ( plus_plus @ nat @ M ) ) @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ) ) ).
% sum.atLeastAtMost_shift_0
thf(fact_4742_prod_OatLeastAtMost__shift__0,axiom,
! [A: $tType] :
( ( comm_monoid_mult @ A )
=> ! [M: nat,N2: nat,G: nat > A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups7121269368397514597t_prod @ nat @ A @ G @ ( set_or1337092689740270186AtMost @ nat @ M @ N2 ) )
= ( groups7121269368397514597t_prod @ nat @ A @ ( comp @ nat @ A @ nat @ G @ ( plus_plus @ nat @ M ) ) @ ( set_or1337092689740270186AtMost @ nat @ ( zero_zero @ nat ) @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ) ) ).
% prod.atLeastAtMost_shift_0
thf(fact_4743_filterlim__at__bot__at__right,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo1944317154257567458pology @ A )
& ( linorder @ B ) )
=> ! [Q: A > $o,F2: A > B,P2: B > $o,G: B > A,A3: A] :
( ! [X5: A,Y4: A] :
( ( Q @ X5 )
=> ( ( Q @ Y4 )
=> ( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ord_less_eq @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) ) ) )
=> ( ! [X5: B] :
( ( P2 @ X5 )
=> ( ( F2 @ ( G @ X5 ) )
= X5 ) )
=> ( ! [X5: B] :
( ( P2 @ X5 )
=> ( Q @ ( G @ X5 ) ) )
=> ( ( eventually @ A @ Q @ ( topolo174197925503356063within @ A @ A3 @ ( set_ord_greaterThan @ A @ A3 ) ) )
=> ( ! [B5: A] :
( ( Q @ B5 )
=> ( ord_less @ A @ A3 @ B5 ) )
=> ( ( eventually @ B @ P2 @ ( at_bot @ B ) )
=> ( filterlim @ A @ B @ F2 @ ( at_bot @ B ) @ ( topolo174197925503356063within @ A @ A3 @ ( set_ord_greaterThan @ A @ A3 ) ) ) ) ) ) ) ) ) ) ).
% filterlim_at_bot_at_right
thf(fact_4744_finite__mono__remains__stable__implies__strict__prefix,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [F2: nat > A] :
( ( finite_finite @ A @ ( image2 @ nat @ A @ F2 @ ( top_top @ ( set @ nat ) ) ) )
=> ( ( order_mono @ nat @ A @ F2 )
=> ( ! [N3: nat] :
( ( ( F2 @ N3 )
= ( F2 @ ( suc @ N3 ) ) )
=> ( ( F2 @ ( suc @ N3 ) )
= ( F2 @ ( suc @ ( suc @ N3 ) ) ) ) )
=> ? [N9: nat] :
( ! [N5: nat] :
( ( ord_less_eq @ nat @ N5 @ N9 )
=> ! [M4: nat] :
( ( ord_less_eq @ nat @ M4 @ N9 )
=> ( ( ord_less @ nat @ M4 @ N5 )
=> ( ord_less @ A @ ( F2 @ M4 ) @ ( F2 @ N5 ) ) ) ) )
& ! [N5: nat] :
( ( ord_less_eq @ nat @ N9 @ N5 )
=> ( ( F2 @ N9 )
= ( F2 @ N5 ) ) ) ) ) ) ) ) ).
% finite_mono_remains_stable_implies_strict_prefix
thf(fact_4745_tendsto__at__left__sequentially,axiom,
! [A: $tType,B: $tType] :
( ( ( topolo3112930676232923870pology @ B )
& ( topolo1944317154257567458pology @ B )
& ( topolo4958980785337419405_space @ A ) )
=> ! [B2: B,A3: B,X7: B > A,L5: A] :
( ( ord_less @ B @ B2 @ A3 )
=> ( ! [S6: nat > B] :
( ! [N5: nat] : ( ord_less @ B @ ( S6 @ N5 ) @ A3 )
=> ( ! [N5: nat] : ( ord_less @ B @ B2 @ ( S6 @ N5 ) )
=> ( ( order_mono @ nat @ B @ S6 )
=> ( ( filterlim @ nat @ B @ S6 @ ( topolo7230453075368039082e_nhds @ B @ A3 ) @ ( at_top @ nat ) )
=> ( filterlim @ nat @ A
@ ^ [N: nat] : ( X7 @ ( S6 @ N ) )
@ ( topolo7230453075368039082e_nhds @ A @ L5 )
@ ( at_top @ nat ) ) ) ) ) )
=> ( filterlim @ B @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ L5 ) @ ( topolo174197925503356063within @ B @ A3 @ ( set_ord_lessThan @ B @ A3 ) ) ) ) ) ) ).
% tendsto_at_left_sequentially
thf(fact_4746_lim__at__infinity__0,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,L: A] :
( ( filterlim @ A @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ ( at_infinity @ A ) )
= ( filterlim @ A @ A @ ( comp @ A @ A @ A @ F2 @ ( inverse_inverse @ A ) ) @ ( topolo7230453075368039082e_nhds @ A @ L ) @ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% lim_at_infinity_0
thf(fact_4747_at__right__eq,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [X: A,Y: A] :
( ( ord_less @ A @ X @ Y )
=> ( ( topolo174197925503356063within @ A @ X @ ( set_ord_greaterThan @ A @ X ) )
= ( complete_Inf_Inf @ ( filter @ A )
@ ( image2 @ A @ ( filter @ A )
@ ^ [A5: A] : ( principal @ A @ ( set_or5935395276787703475ssThan @ A @ X @ A5 ) )
@ ( set_ord_greaterThan @ A @ X ) ) ) ) ) ) ).
% at_right_eq
thf(fact_4748_interval__cases,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [S3: set @ A] :
( ! [A7: A,B5: A,X5: A] :
( ( member2 @ A @ A7 @ S3 )
=> ( ( member2 @ A @ B5 @ S3 )
=> ( ( ord_less_eq @ A @ A7 @ X5 )
=> ( ( ord_less_eq @ A @ X5 @ B5 )
=> ( member2 @ A @ X5 @ S3 ) ) ) ) )
=> ? [A7: A,B5: A] :
( ( S3
= ( bot_bot @ ( set @ A ) ) )
| ( S3
= ( top_top @ ( set @ A ) ) )
| ( S3
= ( set_ord_lessThan @ A @ B5 ) )
| ( S3
= ( set_ord_atMost @ A @ B5 ) )
| ( S3
= ( set_ord_greaterThan @ A @ A7 ) )
| ( S3
= ( set_ord_atLeast @ A @ A7 ) )
| ( S3
= ( set_or5935395276787703475ssThan @ A @ A7 @ B5 ) )
| ( S3
= ( set_or3652927894154168847AtMost @ A @ A7 @ B5 ) )
| ( S3
= ( set_or7035219750837199246ssThan @ A @ A7 @ B5 ) )
| ( S3
= ( set_or1337092689740270186AtMost @ A @ A7 @ B5 ) ) ) ) ) ).
% interval_cases
thf(fact_4749_sequentially__imp__eventually__at__right,axiom,
! [A: $tType] :
( ( ( topolo3112930676232923870pology @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [A3: A,B2: A,P2: A > $o] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ! [F4: nat > A] :
( ! [N5: nat] : ( ord_less @ A @ A3 @ ( F4 @ N5 ) )
=> ( ! [N5: nat] : ( ord_less @ A @ ( F4 @ N5 ) @ B2 )
=> ( ( order_antimono @ nat @ A @ F4 )
=> ( ( filterlim @ nat @ A @ F4 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ ( at_top @ nat ) )
=> ( eventually @ nat
@ ^ [N: nat] : ( P2 @ ( F4 @ N ) )
@ ( at_top @ nat ) ) ) ) ) )
=> ( eventually @ A @ P2 @ ( topolo174197925503356063within @ A @ A3 @ ( set_ord_greaterThan @ A @ A3 ) ) ) ) ) ) ).
% sequentially_imp_eventually_at_right
thf(fact_4750_map__filter__on__comp,axiom,
! [A: $tType,C: $tType,B: $tType,G: B > A,Y6: set @ B,X7: set @ A,F5: filter @ B,F2: A > C] :
( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ G @ Y6 ) @ X7 )
=> ( ( eventually @ B
@ ^ [X2: B] : ( member2 @ B @ X2 @ Y6 )
@ F5 )
=> ( ( map_filter_on @ A @ C @ X7 @ F2 @ ( map_filter_on @ B @ A @ Y6 @ G @ F5 ) )
= ( map_filter_on @ B @ C @ Y6 @ ( comp @ A @ C @ B @ F2 @ G ) @ F5 ) ) ) ) ).
% map_filter_on_comp
thf(fact_4751_atLeast__0,axiom,
( ( set_ord_atLeast @ nat @ ( zero_zero @ nat ) )
= ( top_top @ ( set @ nat ) ) ) ).
% atLeast_0
thf(fact_4752_atLeast__iff,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [I: A,K: A] :
( ( member2 @ A @ I @ ( set_ord_atLeast @ A @ K ) )
= ( ord_less_eq @ A @ K @ I ) ) ) ).
% atLeast_iff
thf(fact_4753_atLeast__empty__triv,axiom,
! [A: $tType] :
( ( set_ord_atLeast @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) )
= ( top_top @ ( set @ ( set @ A ) ) ) ) ).
% atLeast_empty_triv
thf(fact_4754_atLeast__subset__iff,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_ord_atLeast @ A @ X ) @ ( set_ord_atLeast @ A @ Y ) )
= ( ord_less_eq @ A @ Y @ X ) ) ) ).
% atLeast_subset_iff
thf(fact_4755_image__add__atLeast,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [K: A,I: A] :
( ( image2 @ A @ A @ ( plus_plus @ A @ K ) @ ( set_ord_atLeast @ A @ I ) )
= ( set_ord_atLeast @ A @ ( plus_plus @ A @ K @ I ) ) ) ) ).
% image_add_atLeast
thf(fact_4756_Icc__subset__Ici__iff,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [L: A,H2: A,L3: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ L @ H2 ) @ ( set_ord_atLeast @ A @ L3 ) )
= ( ~ ( ord_less_eq @ A @ L @ H2 )
| ( ord_less_eq @ A @ L3 @ L ) ) ) ) ).
% Icc_subset_Ici_iff
thf(fact_4757_Int__atLeastAtMostL2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ ( set_ord_atLeast @ A @ C2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( ord_max @ A @ A3 @ C2 ) @ B2 ) ) ) ).
% Int_atLeastAtMostL2
thf(fact_4758_Int__atLeastAtMostR2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,C2: A,D2: A] :
( ( inf_inf @ ( set @ A ) @ ( set_ord_atLeast @ A @ A3 ) @ ( set_or1337092689740270186AtMost @ A @ C2 @ D2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( ord_max @ A @ A3 @ C2 ) @ D2 ) ) ) ).
% Int_atLeastAtMostR2
thf(fact_4759_empty__natural,axiom,
! [C: $tType,B: $tType,D: $tType,A: $tType,F2: A > C,G: D > B] :
( ( comp @ C @ ( set @ B ) @ A
@ ^ [Uu3: C] : ( bot_bot @ ( set @ B ) )
@ F2 )
= ( comp @ ( set @ D ) @ ( set @ B ) @ A @ ( image2 @ D @ B @ G )
@ ^ [Uu3: A] : ( bot_bot @ ( set @ D ) ) ) ) ).
% empty_natural
thf(fact_4760_sorted__list__of__set_Ofold__insort__key_Ocomp__fun__commute__on,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Y: A,X: A] :
( ( comp @ ( list @ A ) @ ( list @ A ) @ ( list @ A )
@ ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ Y )
@ ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ X ) )
= ( comp @ ( list @ A ) @ ( list @ A ) @ ( list @ A )
@ ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ X )
@ ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ Y ) ) ) ) ).
% sorted_list_of_set.fold_insort_key.comp_fun_commute_on
thf(fact_4761_atLeast__Suc__greaterThan,axiom,
! [K: nat] :
( ( set_ord_atLeast @ nat @ ( suc @ K ) )
= ( set_ord_greaterThan @ nat @ K ) ) ).
% atLeast_Suc_greaterThan
thf(fact_4762_snd__diag__snd,axiom,
! [B: $tType,A: $tType] :
( ( comp @ ( product_prod @ B @ B ) @ B @ ( product_prod @ A @ B ) @ ( product_snd @ B @ B )
@ ( comp @ B @ ( product_prod @ B @ B ) @ ( product_prod @ A @ B )
@ ^ [X2: B] : ( product_Pair @ B @ B @ X2 @ X2 )
@ ( product_snd @ A @ B ) ) )
= ( product_snd @ A @ B ) ) ).
% snd_diag_snd
thf(fact_4763_fst__diag__fst,axiom,
! [B: $tType,A: $tType] :
( ( comp @ ( product_prod @ A @ A ) @ A @ ( product_prod @ A @ B ) @ ( product_fst @ A @ A )
@ ( comp @ A @ ( product_prod @ A @ A ) @ ( product_prod @ A @ B )
@ ^ [X2: A] : ( product_Pair @ A @ A @ X2 @ X2 )
@ ( product_fst @ A @ B ) ) )
= ( product_fst @ A @ B ) ) ).
% fst_diag_fst
thf(fact_4764_fst__diag__snd,axiom,
! [B: $tType,A: $tType] :
( ( comp @ ( product_prod @ B @ B ) @ B @ ( product_prod @ A @ B ) @ ( product_fst @ B @ B )
@ ( comp @ B @ ( product_prod @ B @ B ) @ ( product_prod @ A @ B )
@ ^ [X2: B] : ( product_Pair @ B @ B @ X2 @ X2 )
@ ( product_snd @ A @ B ) ) )
= ( product_snd @ A @ B ) ) ).
% fst_diag_snd
thf(fact_4765_snd__diag__fst,axiom,
! [B: $tType,A: $tType] :
( ( comp @ ( product_prod @ A @ A ) @ A @ ( product_prod @ A @ B ) @ ( product_snd @ A @ A )
@ ( comp @ A @ ( product_prod @ A @ A ) @ ( product_prod @ A @ B )
@ ^ [X2: A] : ( product_Pair @ A @ A @ X2 @ X2 )
@ ( product_fst @ A @ B ) ) )
= ( product_fst @ A @ B ) ) ).
% snd_diag_fst
thf(fact_4766_not__empty__eq__Ici__eq__empty,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [L: A] :
( ( bot_bot @ ( set @ A ) )
!= ( set_ord_atLeast @ A @ L ) ) ) ).
% not_empty_eq_Ici_eq_empty
thf(fact_4767_atLeast__def,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( set_ord_atLeast @ A )
= ( ^ [L2: A] : ( collect @ A @ ( ord_less_eq @ A @ L2 ) ) ) ) ) ).
% atLeast_def
thf(fact_4768_mono__Int,axiom,
! [B: $tType,A: $tType,F2: ( set @ A ) > ( set @ B ),A4: set @ A,B3: set @ A] :
( ( order_mono @ ( set @ A ) @ ( set @ B ) @ F2 )
=> ( ord_less_eq @ ( set @ B ) @ ( F2 @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) @ ( inf_inf @ ( set @ B ) @ ( F2 @ A4 ) @ ( F2 @ B3 ) ) ) ) ).
% mono_Int
thf(fact_4769_antimonoD,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ! [F2: A > B,X: A,Y: A] :
( ( order_antimono @ A @ B @ F2 )
=> ( ( ord_less_eq @ A @ X @ Y )
=> ( ord_less_eq @ B @ ( F2 @ Y ) @ ( F2 @ X ) ) ) ) ) ).
% antimonoD
thf(fact_4770_antimonoE,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ! [F2: A > B,X: A,Y: A] :
( ( order_antimono @ A @ B @ F2 )
=> ( ( ord_less_eq @ A @ X @ Y )
=> ( ord_less_eq @ B @ ( F2 @ Y ) @ ( F2 @ X ) ) ) ) ) ).
% antimonoE
thf(fact_4771_antimonoI,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ! [F2: A > B] :
( ! [X5: A,Y4: A] :
( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ord_less_eq @ B @ ( F2 @ Y4 ) @ ( F2 @ X5 ) ) )
=> ( order_antimono @ A @ B @ F2 ) ) ) ).
% antimonoI
thf(fact_4772_antimono__def,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ( ( order_antimono @ A @ B )
= ( ^ [F3: A > B] :
! [X2: A,Y2: A] :
( ( ord_less_eq @ A @ X2 @ Y2 )
=> ( ord_less_eq @ B @ ( F3 @ Y2 ) @ ( F3 @ X2 ) ) ) ) ) ) ).
% antimono_def
thf(fact_4773_atLeast__eq__UNIV__iff,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ! [X: A] :
( ( ( set_ord_atLeast @ A @ X )
= ( top_top @ ( set @ A ) ) )
= ( X
= ( bot_bot @ A ) ) ) ) ).
% atLeast_eq_UNIV_iff
thf(fact_4774_not__UNIV__le__Ici,axiom,
! [A: $tType] :
( ( no_bot @ A )
=> ! [L: A] :
~ ( ord_less_eq @ ( set @ A ) @ ( top_top @ ( set @ A ) ) @ ( set_ord_atLeast @ A @ L ) ) ) ).
% not_UNIV_le_Ici
thf(fact_4775_not__Ici__le__Icc,axiom,
! [A: $tType] :
( ( no_top @ A )
=> ! [L: A,L3: A,H3: A] :
~ ( ord_less_eq @ ( set @ A ) @ ( set_ord_atLeast @ A @ L ) @ ( set_or1337092689740270186AtMost @ A @ L3 @ H3 ) ) ) ).
% not_Ici_le_Icc
thf(fact_4776_not__Ici__le__Iic,axiom,
! [A: $tType] :
( ( no_top @ A )
=> ! [L: A,H3: A] :
~ ( ord_less_eq @ ( set @ A ) @ ( set_ord_atLeast @ A @ L ) @ ( set_ord_atMost @ A @ H3 ) ) ) ).
% not_Ici_le_Iic
thf(fact_4777_not__Iic__le__Ici,axiom,
! [A: $tType] :
( ( no_bot @ A )
=> ! [H2: A,L3: A] :
~ ( ord_less_eq @ ( set @ A ) @ ( set_ord_atMost @ A @ H2 ) @ ( set_ord_atLeast @ A @ L3 ) ) ) ).
% not_Iic_le_Ici
thf(fact_4778_Ioi__le__Ico,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A3: A] : ( ord_less_eq @ ( set @ A ) @ ( set_ord_greaterThan @ A @ A3 ) @ ( set_ord_atLeast @ A @ A3 ) ) ) ).
% Ioi_le_Ico
thf(fact_4779_decseq__Suc__iff,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( order_antimono @ nat @ A )
= ( ^ [F3: nat > A] :
! [N: nat] : ( ord_less_eq @ A @ ( F3 @ ( suc @ N ) ) @ ( F3 @ N ) ) ) ) ) ).
% decseq_Suc_iff
thf(fact_4780_decseq__SucI,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [X7: nat > A] :
( ! [N3: nat] : ( ord_less_eq @ A @ ( X7 @ ( suc @ N3 ) ) @ ( X7 @ N3 ) )
=> ( order_antimono @ nat @ A @ X7 ) ) ) ).
% decseq_SucI
thf(fact_4781_decseq__SucD,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [A4: nat > A,I: nat] :
( ( order_antimono @ nat @ A @ A4 )
=> ( ord_less_eq @ A @ ( A4 @ ( suc @ I ) ) @ ( A4 @ I ) ) ) ) ).
% decseq_SucD
thf(fact_4782_decseqD,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [F2: nat > A,I: nat,J: nat] :
( ( order_antimono @ nat @ A @ F2 )
=> ( ( ord_less_eq @ nat @ I @ J )
=> ( ord_less_eq @ A @ ( F2 @ J ) @ ( F2 @ I ) ) ) ) ) ).
% decseqD
thf(fact_4783_decseq__def,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( order_antimono @ nat @ A )
= ( ^ [X8: nat > A] :
! [M2: nat,N: nat] :
( ( ord_less_eq @ nat @ M2 @ N )
=> ( ord_less_eq @ A @ ( X8 @ N ) @ ( X8 @ M2 ) ) ) ) ) ) ).
% decseq_def
thf(fact_4784_fst__diag__id,axiom,
! [A: $tType,Z: A] :
( ( comp @ ( product_prod @ A @ A ) @ A @ A @ ( product_fst @ A @ A )
@ ^ [X2: A] : ( product_Pair @ A @ A @ X2 @ X2 )
@ Z )
= ( id @ A @ Z ) ) ).
% fst_diag_id
thf(fact_4785_snd__diag__id,axiom,
! [A: $tType,Z: A] :
( ( comp @ ( product_prod @ A @ A ) @ A @ A @ ( product_snd @ A @ A )
@ ^ [X2: A] : ( product_Pair @ A @ A @ X2 @ X2 )
@ Z )
= ( id @ A @ Z ) ) ).
% snd_diag_id
thf(fact_4786_Ici__subset__Ioi__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ ( set @ A ) @ ( set_ord_atLeast @ A @ A3 ) @ ( set_ord_greaterThan @ A @ B2 ) )
= ( ord_less @ A @ B2 @ A3 ) ) ) ).
% Ici_subset_Ioi_iff
thf(fact_4787_ivl__disj__int__one_I8_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ L @ U ) @ ( set_ord_atLeast @ A @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_one(8)
thf(fact_4788_ivl__disj__int__one_I6_J,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [L: A,U: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ L @ U ) @ ( set_ord_atLeast @ A @ U ) )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% ivl_disj_int_one(6)
thf(fact_4789_antimono__funpow,axiom,
! [A: $tType] :
( ( ( lattice @ A )
& ( order_top @ A ) )
=> ! [Q: A > A] :
( ( order_mono @ A @ A @ Q )
=> ( order_antimono @ nat @ A
@ ^ [I5: nat] : ( compow @ ( A > A ) @ I5 @ Q @ ( top_top @ A ) ) ) ) ) ).
% antimono_funpow
thf(fact_4790_snd__fst__flip,axiom,
! [A: $tType,B: $tType] :
( ( product_snd @ B @ A )
= ( comp @ ( product_prod @ A @ B ) @ A @ ( product_prod @ B @ A ) @ ( product_fst @ A @ B )
@ ( product_case_prod @ B @ A @ ( product_prod @ A @ B )
@ ^ [X2: B,Y2: A] : ( product_Pair @ A @ B @ Y2 @ X2 ) ) ) ) ).
% snd_fst_flip
thf(fact_4791_fst__snd__flip,axiom,
! [B: $tType,A: $tType] :
( ( product_fst @ A @ B )
= ( comp @ ( product_prod @ B @ A ) @ A @ ( product_prod @ A @ B ) @ ( product_snd @ B @ A )
@ ( product_case_prod @ A @ B @ ( product_prod @ B @ A )
@ ^ [X2: A,Y2: B] : ( product_Pair @ B @ A @ Y2 @ X2 ) ) ) ) ).
% fst_snd_flip
thf(fact_4792_atMost__Int__atLeast,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [N2: A] :
( ( inf_inf @ ( set @ A ) @ ( set_ord_atMost @ A @ N2 ) @ ( set_ord_atLeast @ A @ N2 ) )
= ( insert2 @ A @ N2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% atMost_Int_atLeast
thf(fact_4793_prod_OUnion__disjoint,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [C5: set @ ( set @ B ),G: B > A] :
( ! [X5: set @ B] :
( ( member2 @ ( set @ B ) @ X5 @ C5 )
=> ( finite_finite @ B @ X5 ) )
=> ( ! [X5: set @ B] :
( ( member2 @ ( set @ B ) @ X5 @ C5 )
=> ! [Xa4: set @ B] :
( ( member2 @ ( set @ B ) @ Xa4 @ C5 )
=> ( ( X5 != Xa4 )
=> ( ( inf_inf @ ( set @ B ) @ X5 @ Xa4 )
= ( bot_bot @ ( set @ B ) ) ) ) ) )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ ( complete_Sup_Sup @ ( set @ B ) @ C5 ) )
= ( comp @ ( ( set @ B ) > A ) @ ( ( set @ ( set @ B ) ) > A ) @ ( B > A ) @ ( groups7121269368397514597t_prod @ ( set @ B ) @ A ) @ ( groups7121269368397514597t_prod @ B @ A ) @ G @ C5 ) ) ) ) ) ).
% prod.Union_disjoint
thf(fact_4794_decseq__ge,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [X7: nat > A,L5: A,N2: nat] :
( ( order_antimono @ nat @ A @ X7 )
=> ( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ L5 ) @ ( at_top @ nat ) )
=> ( ord_less_eq @ A @ L5 @ ( X7 @ N2 ) ) ) ) ) ).
% decseq_ge
thf(fact_4795_sum_OUnion__comp,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [B3: set @ ( set @ B ),G: B > A] :
( ! [X5: set @ B] :
( ( member2 @ ( set @ B ) @ X5 @ B3 )
=> ( finite_finite @ B @ X5 ) )
=> ( ! [A14: set @ B] :
( ( member2 @ ( set @ B ) @ A14 @ B3 )
=> ! [A25: set @ B] :
( ( member2 @ ( set @ B ) @ A25 @ B3 )
=> ( ( A14 != A25 )
=> ! [X5: B] :
( ( member2 @ B @ X5 @ A14 )
=> ( ( member2 @ B @ X5 @ A25 )
=> ( ( G @ X5 )
= ( zero_zero @ A ) ) ) ) ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( complete_Sup_Sup @ ( set @ B ) @ B3 ) )
= ( comp @ ( ( set @ B ) > A ) @ ( ( set @ ( set @ B ) ) > A ) @ ( B > A ) @ ( groups7311177749621191930dd_sum @ ( set @ B ) @ A ) @ ( groups7311177749621191930dd_sum @ B @ A ) @ G @ B3 ) ) ) ) ) ).
% sum.Union_comp
thf(fact_4796_atLeast__Suc,axiom,
! [K: nat] :
( ( set_ord_atLeast @ nat @ ( suc @ K ) )
= ( minus_minus @ ( set @ nat ) @ ( set_ord_atLeast @ nat @ K ) @ ( insert2 @ nat @ K @ ( bot_bot @ ( set @ nat ) ) ) ) ) ).
% atLeast_Suc
thf(fact_4797_sum_OUnion__disjoint,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [C5: set @ ( set @ B ),G: B > A] :
( ! [X5: set @ B] :
( ( member2 @ ( set @ B ) @ X5 @ C5 )
=> ( finite_finite @ B @ X5 ) )
=> ( ! [X5: set @ B] :
( ( member2 @ ( set @ B ) @ X5 @ C5 )
=> ! [Xa4: set @ B] :
( ( member2 @ ( set @ B ) @ Xa4 @ C5 )
=> ( ( X5 != Xa4 )
=> ( ( inf_inf @ ( set @ B ) @ X5 @ Xa4 )
= ( bot_bot @ ( set @ B ) ) ) ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( complete_Sup_Sup @ ( set @ B ) @ C5 ) )
= ( comp @ ( ( set @ B ) > A ) @ ( ( set @ ( set @ B ) ) > A ) @ ( B > A ) @ ( groups7311177749621191930dd_sum @ ( set @ B ) @ A ) @ ( groups7311177749621191930dd_sum @ B @ A ) @ G @ C5 ) ) ) ) ) ).
% sum.Union_disjoint
thf(fact_4798_tendsto__at__right__sequentially,axiom,
! [C: $tType,B: $tType] :
( ( ( topolo3112930676232923870pology @ B )
& ( topolo1944317154257567458pology @ B )
& ( topolo4958980785337419405_space @ C ) )
=> ! [A3: B,B2: B,X7: B > C,L5: C] :
( ( ord_less @ B @ A3 @ B2 )
=> ( ! [S6: nat > B] :
( ! [N5: nat] : ( ord_less @ B @ A3 @ ( S6 @ N5 ) )
=> ( ! [N5: nat] : ( ord_less @ B @ ( S6 @ N5 ) @ B2 )
=> ( ( order_antimono @ nat @ B @ S6 )
=> ( ( filterlim @ nat @ B @ S6 @ ( topolo7230453075368039082e_nhds @ B @ A3 ) @ ( at_top @ nat ) )
=> ( filterlim @ nat @ C
@ ^ [N: nat] : ( X7 @ ( S6 @ N ) )
@ ( topolo7230453075368039082e_nhds @ C @ L5 )
@ ( at_top @ nat ) ) ) ) ) )
=> ( filterlim @ B @ C @ X7 @ ( topolo7230453075368039082e_nhds @ C @ L5 ) @ ( topolo174197925503356063within @ B @ A3 @ ( set_ord_greaterThan @ B @ A3 ) ) ) ) ) ) ).
% tendsto_at_right_sequentially
thf(fact_4799_remdups__adj__altdef,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( remdups_adj @ A @ Xs )
= Ys )
= ( ? [F3: nat > nat] :
( ( order_mono @ nat @ nat @ F3 )
& ( ( image2 @ nat @ nat @ F3 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( size_size @ ( list @ A ) @ Xs ) ) )
= ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( size_size @ ( list @ A ) @ Ys ) ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ A @ Xs @ I5 )
= ( nth @ A @ Ys @ ( F3 @ I5 ) ) ) )
& ! [I5: nat] :
( ( ord_less @ nat @ ( plus_plus @ nat @ I5 @ ( one_one @ nat ) ) @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ( nth @ A @ Xs @ I5 )
= ( nth @ A @ Xs @ ( plus_plus @ nat @ I5 @ ( one_one @ nat ) ) ) )
= ( ( F3 @ I5 )
= ( F3 @ ( plus_plus @ nat @ I5 @ ( one_one @ nat ) ) ) ) ) ) ) ) ) ).
% remdups_adj_altdef
thf(fact_4800_Gcd__eq__Max,axiom,
! [M7: set @ nat] :
( ( finite_finite @ nat @ M7 )
=> ( ( M7
!= ( bot_bot @ ( set @ nat ) ) )
=> ( ~ ( member2 @ nat @ ( zero_zero @ nat ) @ M7 )
=> ( ( gcd_Gcd @ nat @ M7 )
= ( lattic643756798349783984er_Max @ nat
@ ( complete_Inf_Inf @ ( set @ nat )
@ ( image2 @ nat @ ( set @ nat )
@ ^ [M2: nat] :
( collect @ nat
@ ^ [D5: nat] : ( dvd_dvd @ nat @ D5 @ M2 ) )
@ M7 ) ) ) ) ) ) ) ).
% Gcd_eq_Max
thf(fact_4801_LIMSEQ__iff__nz,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ! [X7: nat > A,L5: A] :
( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ L5 ) @ ( at_top @ nat ) )
= ( ! [R4: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ R4 )
=> ? [No: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ No )
& ! [N: nat] :
( ( ord_less_eq @ nat @ No @ N )
=> ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ ( X7 @ N ) @ L5 ) @ R4 ) ) ) ) ) ) ) ).
% LIMSEQ_iff_nz
thf(fact_4802_dist__add__cancel2,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( real_V557655796197034286t_dist @ A @ ( plus_plus @ A @ B2 @ A3 ) @ ( plus_plus @ A @ C2 @ A3 ) )
= ( real_V557655796197034286t_dist @ A @ B2 @ C2 ) ) ) ).
% dist_add_cancel2
thf(fact_4803_dist__add__cancel,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( real_V557655796197034286t_dist @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( plus_plus @ A @ A3 @ C2 ) )
= ( real_V557655796197034286t_dist @ A @ B2 @ C2 ) ) ) ).
% dist_add_cancel
thf(fact_4804_remdups__adj__Nil__iff,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( remdups_adj @ A @ Xs )
= ( nil @ A ) )
= ( Xs
= ( nil @ A ) ) ) ).
% remdups_adj_Nil_iff
thf(fact_4805_remdups__adj__set,axiom,
! [A: $tType,Xs: list @ A] :
( ( set2 @ A @ ( remdups_adj @ A @ Xs ) )
= ( set2 @ A @ Xs ) ) ).
% remdups_adj_set
thf(fact_4806_dist__0__norm,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [X: A] :
( ( real_V557655796197034286t_dist @ A @ ( zero_zero @ A ) @ X )
= ( real_V7770717601297561774m_norm @ A @ X ) ) ) ).
% dist_0_norm
thf(fact_4807_Max__singleton,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A] :
( ( lattic643756798349783984er_Max @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= X ) ) ).
% Max_singleton
thf(fact_4808_Max__divisors__self__nat,axiom,
! [N2: nat] :
( ( N2
!= ( zero_zero @ nat ) )
=> ( ( lattic643756798349783984er_Max @ nat
@ ( collect @ nat
@ ^ [D5: nat] : ( dvd_dvd @ nat @ D5 @ N2 ) ) )
= N2 ) ) ).
% Max_divisors_self_nat
thf(fact_4809_Max_Obounded__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ A @ ( lattic643756798349783984er_Max @ A @ A4 ) @ X )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ X2 @ X ) ) ) ) ) ) ) ).
% Max.bounded_iff
thf(fact_4810_Max__less__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less @ A @ ( lattic643756798349783984er_Max @ A @ A4 ) @ X )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less @ A @ X2 @ X ) ) ) ) ) ) ) ).
% Max_less_iff
thf(fact_4811_Max__const,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ B,C2: A] :
( ( finite_finite @ B @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( lattic643756798349783984er_Max @ A
@ ( image2 @ B @ A
@ ^ [Uu3: B] : C2
@ A4 ) )
= C2 ) ) ) ) ).
% Max_const
thf(fact_4812_Max__insert,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798349783984er_Max @ A @ ( insert2 @ A @ X @ A4 ) )
= ( ord_max @ A @ X @ ( lattic643756798349783984er_Max @ A @ A4 ) ) ) ) ) ) ).
% Max_insert
thf(fact_4813_remdups__adj__distinct,axiom,
! [A: $tType,Xs: list @ A] :
( ( distinct @ A @ Xs )
=> ( ( remdups_adj @ A @ Xs )
= Xs ) ) ).
% remdups_adj_distinct
thf(fact_4814_remdups__adj_Osimps_I1_J,axiom,
! [A: $tType] :
( ( remdups_adj @ A @ ( nil @ A ) )
= ( nil @ A ) ) ).
% remdups_adj.simps(1)
thf(fact_4815_norm__conv__dist,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ( ( real_V7770717601297561774m_norm @ A )
= ( ^ [X2: A] : ( real_V557655796197034286t_dist @ A @ X2 @ ( zero_zero @ A ) ) ) ) ) ).
% norm_conv_dist
thf(fact_4816_Max__ge,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ A @ X @ ( lattic643756798349783984er_Max @ A @ A4 ) ) ) ) ) ).
% Max_ge
thf(fact_4817_Max__eqI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ! [Y4: A] :
( ( member2 @ A @ Y4 @ A4 )
=> ( ord_less_eq @ A @ Y4 @ X ) )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( lattic643756798349783984er_Max @ A @ A4 )
= X ) ) ) ) ) ).
% Max_eqI
thf(fact_4818_Max__eq__if,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ A @ B3 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ? [Xa: A] :
( ( member2 @ A @ Xa @ B3 )
& ( ord_less_eq @ A @ X5 @ Xa ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ B3 )
=> ? [Xa: A] :
( ( member2 @ A @ Xa @ A4 )
& ( ord_less_eq @ A @ X5 @ Xa ) ) )
=> ( ( lattic643756798349783984er_Max @ A @ A4 )
= ( lattic643756798349783984er_Max @ A @ B3 ) ) ) ) ) ) ) ).
% Max_eq_if
thf(fact_4819_Max_OcoboundedI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,A3: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( ord_less_eq @ A @ A3 @ ( lattic643756798349783984er_Max @ A @ A4 ) ) ) ) ) ).
% Max.coboundedI
thf(fact_4820_Max__in,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ A @ ( lattic643756798349783984er_Max @ A @ A4 ) @ A4 ) ) ) ) ).
% Max_in
thf(fact_4821_remdups__adj__length,axiom,
! [A: $tType,Xs: list @ A] : ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ ( remdups_adj @ A @ Xs ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ).
% remdups_adj_length
thf(fact_4822_Max_Oin__idem,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( ord_max @ A @ X @ ( lattic643756798349783984er_Max @ A @ A4 ) )
= ( lattic643756798349783984er_Max @ A @ A4 ) ) ) ) ) ).
% Max.in_idem
thf(fact_4823_Max__eq__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,M: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ( lattic643756798349783984er_Max @ A @ A4 )
= M )
= ( ( member2 @ A @ M @ A4 )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ X2 @ M ) ) ) ) ) ) ) ).
% Max_eq_iff
thf(fact_4824_Max__ge__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ A @ X @ ( lattic643756798349783984er_Max @ A @ A4 ) )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( ord_less_eq @ A @ X @ X2 ) ) ) ) ) ) ) ).
% Max_ge_iff
thf(fact_4825_eq__Max__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,M: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( M
= ( lattic643756798349783984er_Max @ A @ A4 ) )
= ( ( member2 @ A @ M @ A4 )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ X2 @ M ) ) ) ) ) ) ) ).
% eq_Max_iff
thf(fact_4826_Max_OboundedE,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ A @ ( lattic643756798349783984er_Max @ A @ A4 ) @ X )
=> ! [A15: A] :
( ( member2 @ A @ A15 @ A4 )
=> ( ord_less_eq @ A @ A15 @ X ) ) ) ) ) ) ).
% Max.boundedE
thf(fact_4827_Max_OboundedI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [A7: A] :
( ( member2 @ A @ A7 @ A4 )
=> ( ord_less_eq @ A @ A7 @ X ) )
=> ( ord_less_eq @ A @ ( lattic643756798349783984er_Max @ A @ A4 ) @ X ) ) ) ) ) ).
% Max.boundedI
thf(fact_4828_Max__gr__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less @ A @ X @ ( lattic643756798349783984er_Max @ A @ A4 ) )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( ord_less @ A @ X @ X2 ) ) ) ) ) ) ) ).
% Max_gr_iff
thf(fact_4829_Max__insert2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,A3: A] :
( ( finite_finite @ A @ A4 )
=> ( ! [B5: A] :
( ( member2 @ A @ B5 @ A4 )
=> ( ord_less_eq @ A @ B5 @ A3 ) )
=> ( ( lattic643756798349783984er_Max @ A @ ( insert2 @ A @ A3 @ A4 ) )
= A3 ) ) ) ) ).
% Max_insert2
thf(fact_4830_cSup__eq__Max,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [X7: set @ A] :
( ( finite_finite @ A @ X7 )
=> ( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Sup_Sup @ A @ X7 )
= ( lattic643756798349783984er_Max @ A @ X7 ) ) ) ) ) ).
% cSup_eq_Max
thf(fact_4831_Max__Sup,axiom,
! [A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798349783984er_Max @ A @ A4 )
= ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ).
% Max_Sup
thf(fact_4832_metric__CauchyI,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ! [X7: nat > A] :
( ! [E: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E )
=> ? [M10: nat] :
! [M3: nat] :
( ( ord_less_eq @ nat @ M10 @ M3 )
=> ! [N3: nat] :
( ( ord_less_eq @ nat @ M10 @ N3 )
=> ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ ( X7 @ M3 ) @ ( X7 @ N3 ) ) @ E ) ) ) )
=> ( topolo3814608138187158403Cauchy @ A @ X7 ) ) ) ).
% metric_CauchyI
thf(fact_4833_metric__CauchyD,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ! [X7: nat > A,E3: real] :
( ( topolo3814608138187158403Cauchy @ A @ X7 )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ E3 )
=> ? [M8: nat] :
! [M4: nat] :
( ( ord_less_eq @ nat @ M8 @ M4 )
=> ! [N5: nat] :
( ( ord_less_eq @ nat @ M8 @ N5 )
=> ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ ( X7 @ M4 ) @ ( X7 @ N5 ) ) @ E3 ) ) ) ) ) ) ).
% metric_CauchyD
thf(fact_4834_Cauchy__altdef2,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ( ( topolo3814608138187158403Cauchy @ A )
= ( ^ [S7: nat > A] :
! [E4: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E4 )
=> ? [N6: nat] :
! [N: nat] :
( ( ord_less_eq @ nat @ N6 @ N )
=> ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ ( S7 @ N ) @ ( S7 @ N6 ) ) @ E4 ) ) ) ) ) ) ).
% Cauchy_altdef2
thf(fact_4835_Cauchy__def,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ( ( topolo3814608138187158403Cauchy @ A )
= ( ^ [X8: nat > A] :
! [E4: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E4 )
=> ? [M9: nat] :
! [M2: nat] :
( ( ord_less_eq @ nat @ M9 @ M2 )
=> ! [N: nat] :
( ( ord_less_eq @ nat @ M9 @ N )
=> ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ ( X8 @ M2 ) @ ( X8 @ N ) ) @ E4 ) ) ) ) ) ) ) ).
% Cauchy_def
thf(fact_4836_Max_Osubset__imp,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ord_less_eq @ A @ ( lattic643756798349783984er_Max @ A @ A4 ) @ ( lattic643756798349783984er_Max @ A @ B3 ) ) ) ) ) ) ).
% Max.subset_imp
thf(fact_4837_Max__mono,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [M7: set @ A,N7: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ M7 @ N7 )
=> ( ( M7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ N7 )
=> ( ord_less_eq @ A @ ( lattic643756798349783984er_Max @ A @ M7 ) @ ( lattic643756798349783984er_Max @ A @ N7 ) ) ) ) ) ) ).
% Max_mono
thf(fact_4838_remdups__adj__adjacent,axiom,
! [A: $tType,I: nat,Xs: list @ A] :
( ( ord_less @ nat @ ( suc @ I ) @ ( size_size @ ( list @ A ) @ ( remdups_adj @ A @ Xs ) ) )
=> ( ( nth @ A @ ( remdups_adj @ A @ Xs ) @ I )
!= ( nth @ A @ ( remdups_adj @ A @ Xs ) @ ( suc @ I ) ) ) ) ).
% remdups_adj_adjacent
thf(fact_4839_hom__Max__commute,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [H2: A > A,N7: set @ A] :
( ! [X5: A,Y4: A] :
( ( H2 @ ( ord_max @ A @ X5 @ Y4 ) )
= ( ord_max @ A @ ( H2 @ X5 ) @ ( H2 @ Y4 ) ) )
=> ( ( finite_finite @ A @ N7 )
=> ( ( N7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( H2 @ ( lattic643756798349783984er_Max @ A @ N7 ) )
= ( lattic643756798349783984er_Max @ A @ ( image2 @ A @ A @ H2 @ N7 ) ) ) ) ) ) ) ).
% hom_Max_commute
thf(fact_4840_Max_Osubset,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( ord_max @ A @ ( lattic643756798349783984er_Max @ A @ B3 ) @ ( lattic643756798349783984er_Max @ A @ A4 ) )
= ( lattic643756798349783984er_Max @ A @ A4 ) ) ) ) ) ) ).
% Max.subset
thf(fact_4841_Max_Oinsert__not__elem,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ~ ( member2 @ A @ X @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798349783984er_Max @ A @ ( insert2 @ A @ X @ A4 ) )
= ( ord_max @ A @ X @ ( lattic643756798349783984er_Max @ A @ A4 ) ) ) ) ) ) ) ).
% Max.insert_not_elem
thf(fact_4842_Max_Oclosed,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A,Y4: A] : ( member2 @ A @ ( ord_max @ A @ X5 @ Y4 ) @ ( insert2 @ A @ X5 @ ( insert2 @ A @ Y4 @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( member2 @ A @ ( lattic643756798349783984er_Max @ A @ A4 ) @ A4 ) ) ) ) ) ).
% Max.closed
thf(fact_4843_mono__Max__commute,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( linorder @ B ) )
=> ! [F2: A > B,A4: set @ A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( F2 @ ( lattic643756798349783984er_Max @ A @ A4 ) )
= ( lattic643756798349783984er_Max @ B @ ( image2 @ A @ B @ F2 @ A4 ) ) ) ) ) ) ) ).
% mono_Max_commute
thf(fact_4844_card__le__Suc__Max,axiom,
! [S3: set @ nat] :
( ( finite_finite @ nat @ S3 )
=> ( ord_less_eq @ nat @ ( finite_card @ nat @ S3 ) @ ( suc @ ( lattic643756798349783984er_Max @ nat @ S3 ) ) ) ) ).
% card_le_Suc_Max
thf(fact_4845_Sup__nat__def,axiom,
( ( complete_Sup_Sup @ nat )
= ( ^ [X8: set @ nat] :
( if @ nat
@ ( X8
= ( bot_bot @ ( set @ nat ) ) )
@ ( zero_zero @ nat )
@ ( lattic643756798349783984er_Max @ nat @ X8 ) ) ) ) ).
% Sup_nat_def
thf(fact_4846_divide__nat__def,axiom,
( ( divide_divide @ nat )
= ( ^ [M2: nat,N: nat] :
( if @ nat
@ ( N
= ( zero_zero @ nat ) )
@ ( zero_zero @ nat )
@ ( lattic643756798349783984er_Max @ nat
@ ( collect @ nat
@ ^ [K2: nat] : ( ord_less_eq @ nat @ ( times_times @ nat @ K2 @ N ) @ M2 ) ) ) ) ) ) ).
% divide_nat_def
thf(fact_4847_Max__add__commute,axiom,
! [B: $tType,A: $tType] :
( ( linord4140545234300271783up_add @ A )
=> ! [S3: set @ B,F2: B > A,K: A] :
( ( finite_finite @ B @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( lattic643756798349783984er_Max @ A
@ ( image2 @ B @ A
@ ^ [X2: B] : ( plus_plus @ A @ ( F2 @ X2 ) @ K )
@ S3 ) )
= ( plus_plus @ A @ ( lattic643756798349783984er_Max @ A @ ( image2 @ B @ A @ F2 @ S3 ) ) @ K ) ) ) ) ) ).
% Max_add_commute
thf(fact_4848_CauchyI_H,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ! [X7: nat > A] :
( ! [E: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E )
=> ? [M10: nat] :
! [M3: nat] :
( ( ord_less_eq @ nat @ M10 @ M3 )
=> ! [N3: nat] :
( ( ord_less @ nat @ M3 @ N3 )
=> ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ ( X7 @ M3 ) @ ( X7 @ N3 ) ) @ E ) ) ) )
=> ( topolo3814608138187158403Cauchy @ A @ X7 ) ) ) ).
% CauchyI'
thf(fact_4849_Cauchy__altdef,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ( ( topolo3814608138187158403Cauchy @ A )
= ( ^ [F3: nat > A] :
! [E4: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E4 )
=> ? [M9: nat] :
! [M2: nat] :
( ( ord_less_eq @ nat @ M9 @ M2 )
=> ! [N: nat] :
( ( ord_less @ nat @ M2 @ N )
=> ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ ( F3 @ M2 ) @ ( F3 @ N ) ) @ E4 ) ) ) ) ) ) ) ).
% Cauchy_altdef
thf(fact_4850_remdups__adj__length__ge1,axiom,
! [A: $tType,Xs: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ord_less_eq @ nat @ ( suc @ ( zero_zero @ nat ) ) @ ( size_size @ ( list @ A ) @ ( remdups_adj @ A @ Xs ) ) ) ) ).
% remdups_adj_length_ge1
thf(fact_4851_Max_Oinsert__remove,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798349783984er_Max @ A @ ( insert2 @ A @ X @ A4 ) )
= X ) )
& ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798349783984er_Max @ A @ ( insert2 @ A @ X @ A4 ) )
= ( ord_max @ A @ X @ ( lattic643756798349783984er_Max @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ).
% Max.insert_remove
thf(fact_4852_Max_Oremove,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798349783984er_Max @ A @ A4 )
= X ) )
& ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798349783984er_Max @ A @ A4 )
= ( ord_max @ A @ X @ ( lattic643756798349783984er_Max @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ) ).
% Max.remove
thf(fact_4853_metric__LIMSEQ__D,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ! [X7: nat > A,L5: A,R2: real] :
( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ L5 ) @ ( at_top @ nat ) )
=> ( ( ord_less @ real @ ( zero_zero @ real ) @ R2 )
=> ? [No3: nat] :
! [N5: nat] :
( ( ord_less_eq @ nat @ No3 @ N5 )
=> ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ ( X7 @ N5 ) @ L5 ) @ R2 ) ) ) ) ) ).
% metric_LIMSEQ_D
thf(fact_4854_metric__LIMSEQ__I,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ! [X7: nat > A,L5: A] :
( ! [R3: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ R3 )
=> ? [No2: nat] :
! [N3: nat] :
( ( ord_less_eq @ nat @ No2 @ N3 )
=> ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ ( X7 @ N3 ) @ L5 ) @ R3 ) ) )
=> ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ L5 ) @ ( at_top @ nat ) ) ) ) ).
% metric_LIMSEQ_I
thf(fact_4855_lim__sequentially,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ! [X7: nat > A,L5: A] :
( ( filterlim @ nat @ A @ X7 @ ( topolo7230453075368039082e_nhds @ A @ L5 ) @ ( at_top @ nat ) )
= ( ! [R4: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ R4 )
=> ? [No: nat] :
! [N: nat] :
( ( ord_less_eq @ nat @ No @ N )
=> ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ ( X7 @ N ) @ L5 ) @ R4 ) ) ) ) ) ) ).
% lim_sequentially
thf(fact_4856_metric__Cauchy__iff2,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ( ( topolo3814608138187158403Cauchy @ A )
= ( ^ [X8: nat > A] :
! [J3: nat] :
? [M9: nat] :
! [M2: nat] :
( ( ord_less_eq @ nat @ M9 @ M2 )
=> ! [N: nat] :
( ( ord_less_eq @ nat @ M9 @ N )
=> ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ ( X8 @ M2 ) @ ( X8 @ N ) ) @ ( inverse_inverse @ real @ ( semiring_1_of_nat @ real @ ( suc @ J3 ) ) ) ) ) ) ) ) ) ).
% metric_Cauchy_iff2
thf(fact_4857_sum__le__card__Max,axiom,
! [A: $tType,A4: set @ A,F2: A > nat] :
( ( finite_finite @ A @ A4 )
=> ( ord_less_eq @ nat @ ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ A4 ) @ ( times_times @ nat @ ( finite_card @ A @ A4 ) @ ( lattic643756798349783984er_Max @ nat @ ( image2 @ A @ nat @ F2 @ A4 ) ) ) ) ) ).
% sum_le_card_Max
thf(fact_4858_totally__bounded__metric,axiom,
! [A: $tType] :
( ( real_V7819770556892013058_space @ A )
=> ( ( topolo6688025880775521714ounded @ A )
= ( ^ [S8: set @ A] :
! [E4: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E4 )
=> ? [K2: set @ A] :
( ( finite_finite @ A @ K2 )
& ( ord_less_eq @ ( set @ A ) @ S8
@ ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ A @ ( set @ A )
@ ^ [X2: A] :
( collect @ A
@ ^ [Y2: A] : ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ X2 @ Y2 ) @ E4 ) )
@ K2 ) ) ) ) ) ) ) ) ).
% totally_bounded_metric
thf(fact_4859_dual__Min,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( lattices_Min @ A
@ ^ [X2: A,Y2: A] : ( ord_less_eq @ A @ Y2 @ X2 ) )
= ( lattic643756798349783984er_Max @ A ) ) ) ).
% dual_Min
thf(fact_4860_range__abs__Nats,axiom,
( ( image2 @ int @ int @ ( abs_abs @ int ) @ ( top_top @ ( set @ int ) ) )
= ( semiring_1_Nats @ int ) ) ).
% range_abs_Nats
thf(fact_4861_totally__bounded__empty,axiom,
! [A: $tType] :
( ( topolo7287701948861334536_space @ A )
=> ( topolo6688025880775521714ounded @ A @ ( bot_bot @ ( set @ A ) ) ) ) ).
% totally_bounded_empty
thf(fact_4862_Nats__1,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( member2 @ A @ ( one_one @ A ) @ ( semiring_1_Nats @ A ) ) ) ).
% Nats_1
thf(fact_4863_Nats__add,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [A3: A,B2: A] :
( ( member2 @ A @ A3 @ ( semiring_1_Nats @ A ) )
=> ( ( member2 @ A @ B2 @ ( semiring_1_Nats @ A ) )
=> ( member2 @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( semiring_1_Nats @ A ) ) ) ) ) ).
% Nats_add
thf(fact_4864_Nats__0,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( member2 @ A @ ( zero_zero @ A ) @ ( semiring_1_Nats @ A ) ) ) ).
% Nats_0
thf(fact_4865_linorder_OMin_Ocong,axiom,
! [A: $tType] :
( ( lattices_Min @ A )
= ( lattices_Min @ A ) ) ).
% linorder.Min.cong
thf(fact_4866_Nats__mult,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [A3: A,B2: A] :
( ( member2 @ A @ A3 @ ( semiring_1_Nats @ A ) )
=> ( ( member2 @ A @ B2 @ ( semiring_1_Nats @ A ) )
=> ( member2 @ A @ ( times_times @ A @ A3 @ B2 ) @ ( semiring_1_Nats @ A ) ) ) ) ) ).
% Nats_mult
thf(fact_4867_Nats__numeral,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [W2: num] : ( member2 @ A @ ( numeral_numeral @ A @ W2 ) @ ( semiring_1_Nats @ A ) ) ) ).
% Nats_numeral
thf(fact_4868_Nats__cases,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [X: A] :
( ( member2 @ A @ X @ ( semiring_1_Nats @ A ) )
=> ~ ! [N3: nat] :
( X
!= ( semiring_1_of_nat @ A @ N3 ) ) ) ) ).
% Nats_cases
thf(fact_4869_Nats__induct,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [X: A,P2: A > $o] :
( ( member2 @ A @ X @ ( semiring_1_Nats @ A ) )
=> ( ! [N3: nat] : ( P2 @ ( semiring_1_of_nat @ A @ N3 ) )
=> ( P2 @ X ) ) ) ) ).
% Nats_induct
thf(fact_4870_of__nat__in__Nats,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [N2: nat] : ( member2 @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( semiring_1_Nats @ A ) ) ) ).
% of_nat_in_Nats
thf(fact_4871_totally__bounded__subset,axiom,
! [A: $tType] :
( ( topolo7287701948861334536_space @ A )
=> ! [S3: set @ A,T4: set @ A] :
( ( topolo6688025880775521714ounded @ A @ S3 )
=> ( ( ord_less_eq @ ( set @ A ) @ T4 @ S3 )
=> ( topolo6688025880775521714ounded @ A @ T4 ) ) ) ) ).
% totally_bounded_subset
thf(fact_4872_Nats__diff,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A,B2: A] :
( ( member2 @ A @ A3 @ ( semiring_1_Nats @ A ) )
=> ( ( member2 @ A @ B2 @ ( semiring_1_Nats @ A ) )
=> ( ( ord_less_eq @ A @ B2 @ A3 )
=> ( member2 @ A @ ( minus_minus @ A @ A3 @ B2 ) @ ( semiring_1_Nats @ A ) ) ) ) ) ) ).
% Nats_diff
thf(fact_4873_Nats__def,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( semiring_1_Nats @ A )
= ( image2 @ nat @ A @ ( semiring_1_of_nat @ A ) @ ( top_top @ ( set @ nat ) ) ) ) ) ).
% Nats_def
thf(fact_4874_compact__imp__fip__image,axiom,
! [B: $tType,A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S: set @ A,I6: set @ B,F2: B > ( set @ A )] :
( ( topolo2193935891317330818ompact @ A @ S )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ I6 )
=> ( topolo7761053866217962861closed @ A @ ( F2 @ I3 ) ) )
=> ( ! [I9: set @ B] :
( ( finite_finite @ B @ I9 )
=> ( ( ord_less_eq @ ( set @ B ) @ I9 @ I6 )
=> ( ( inf_inf @ ( set @ A ) @ S @ ( complete_Inf_Inf @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ F2 @ I9 ) ) )
!= ( bot_bot @ ( set @ A ) ) ) ) )
=> ( ( inf_inf @ ( set @ A ) @ S @ ( complete_Inf_Inf @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ F2 @ I6 ) ) )
!= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% compact_imp_fip_image
thf(fact_4875_inj__sgn__power,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( inj_on @ real @ real
@ ^ [Y2: real] : ( times_times @ real @ ( sgn_sgn @ real @ Y2 ) @ ( power_power @ real @ ( abs_abs @ real @ Y2 ) @ N2 ) )
@ ( top_top @ ( set @ real ) ) ) ) ).
% inj_sgn_power
thf(fact_4876_continuous__on__IccI,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo1944317154257567458pology @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [F2: A > B,A3: A,B2: A] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( F2 @ A3 ) ) @ ( topolo174197925503356063within @ A @ A3 @ ( set_ord_greaterThan @ A @ A3 ) ) )
=> ( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( F2 @ B2 ) ) @ ( topolo174197925503356063within @ A @ B2 @ ( set_ord_lessThan @ A @ B2 ) ) )
=> ( ! [X5: A] :
( ( ord_less @ A @ A3 @ X5 )
=> ( ( ord_less @ A @ X5 @ B2 )
=> ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( F2 @ X5 ) ) @ ( topolo174197925503356063within @ A @ X5 @ ( top_top @ ( set @ A ) ) ) ) ) )
=> ( ( ord_less @ A @ A3 @ B2 )
=> ( topolo81223032696312382ous_on @ A @ B @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ F2 ) ) ) ) ) ) ).
% continuous_on_IccI
thf(fact_4877_inj__on__empty,axiom,
! [B: $tType,A: $tType,F2: A > B] : ( inj_on @ A @ B @ F2 @ ( bot_bot @ ( set @ A ) ) ) ).
% inj_on_empty
thf(fact_4878_closed__empty,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ( topolo7761053866217962861closed @ A @ ( bot_bot @ ( set @ A ) ) ) ) ).
% closed_empty
thf(fact_4879_closed__singleton,axiom,
! [A: $tType] :
( ( topological_t1_space @ A )
=> ! [A3: A] : ( topolo7761053866217962861closed @ A @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% closed_singleton
thf(fact_4880_inj__mult__left,axiom,
! [A: $tType] :
( ( idom @ A )
=> ! [A3: A] :
( ( inj_on @ A @ A @ ( times_times @ A @ A3 ) @ ( top_top @ ( set @ A ) ) )
= ( A3
!= ( zero_zero @ A ) ) ) ) ).
% inj_mult_left
thf(fact_4881_inj__divide__right,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [A3: A] :
( ( inj_on @ A @ A
@ ^ [B4: A] : ( divide_divide @ A @ B4 @ A3 )
@ ( top_top @ ( set @ A ) ) )
= ( A3
!= ( zero_zero @ A ) ) ) ) ).
% inj_divide_right
thf(fact_4882_inj__on__insert,axiom,
! [B: $tType,A: $tType,F2: A > B,A3: A,A4: set @ A] :
( ( inj_on @ A @ B @ F2 @ ( insert2 @ A @ A3 @ A4 ) )
= ( ( inj_on @ A @ B @ F2 @ A4 )
& ~ ( member2 @ B @ ( F2 @ A3 ) @ ( image2 @ A @ B @ F2 @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% inj_on_insert
thf(fact_4883_closed__Collect__le,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( topolo1944317154257567458pology @ B ) )
=> ! [F2: A > B,G: A > B] :
( ( topolo81223032696312382ous_on @ A @ B @ ( top_top @ ( set @ A ) ) @ F2 )
=> ( ( topolo81223032696312382ous_on @ A @ B @ ( top_top @ ( set @ A ) ) @ G )
=> ( topolo7761053866217962861closed @ A
@ ( collect @ A
@ ^ [X2: A] : ( ord_less_eq @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ) ).
% closed_Collect_le
thf(fact_4884_inj__on__subset,axiom,
! [B: $tType,A: $tType,F2: A > B,A4: set @ A,B3: set @ A] :
( ( inj_on @ A @ B @ F2 @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( inj_on @ A @ B @ F2 @ B3 ) ) ) ).
% inj_on_subset
thf(fact_4885_subset__inj__on,axiom,
! [B: $tType,A: $tType,F2: A > B,B3: set @ A,A4: set @ A] :
( ( inj_on @ A @ B @ F2 @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( inj_on @ A @ B @ F2 @ A4 ) ) ) ).
% subset_inj_on
thf(fact_4886_continuous__on__subset,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [S: set @ A,F2: A > B,T2: set @ A] :
( ( topolo81223032696312382ous_on @ A @ B @ S @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ T2 @ S )
=> ( topolo81223032696312382ous_on @ A @ B @ T2 @ F2 ) ) ) ) ).
% continuous_on_subset
thf(fact_4887_continuous__on__empty,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [F2: A > B] : ( topolo81223032696312382ous_on @ A @ B @ ( bot_bot @ ( set @ A ) ) @ F2 ) ) ).
% continuous_on_empty
thf(fact_4888_inj__on__add_H,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A )
=> ! [A3: A,A4: set @ A] :
( inj_on @ A @ A
@ ^ [B4: A] : ( plus_plus @ A @ B4 @ A3 )
@ A4 ) ) ).
% inj_on_add'
thf(fact_4889_continuous__on__max,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( topolo1944317154257567458pology @ B ) )
=> ! [A4: set @ A,F2: A > B,G: A > B] :
( ( topolo81223032696312382ous_on @ A @ B @ A4 @ F2 )
=> ( ( topolo81223032696312382ous_on @ A @ B @ A4 @ G )
=> ( topolo81223032696312382ous_on @ A @ B @ A4
@ ^ [X2: A] : ( ord_max @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ).
% continuous_on_max
thf(fact_4890_continuous__on__add,axiom,
! [B: $tType,D: $tType] :
( ( ( topolo4958980785337419405_space @ D )
& ( topolo6943815403480290642id_add @ B ) )
=> ! [S: set @ D,F2: D > B,G: D > B] :
( ( topolo81223032696312382ous_on @ D @ B @ S @ F2 )
=> ( ( topolo81223032696312382ous_on @ D @ B @ S @ G )
=> ( topolo81223032696312382ous_on @ D @ B @ S
@ ^ [X2: D] : ( plus_plus @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ).
% continuous_on_add
thf(fact_4891_inj__on__add,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A )
=> ! [A3: A,A4: set @ A] : ( inj_on @ A @ A @ ( plus_plus @ A @ A3 ) @ A4 ) ) ).
% inj_on_add
thf(fact_4892_sorted__list__of__set_Oinj__on,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( inj_on @ A @ A
@ ^ [X2: A] : X2
@ ( top_top @ ( set @ A ) ) ) ) ).
% sorted_list_of_set.inj_on
thf(fact_4893_continuous__on__Pair,axiom,
! [C: $tType,B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( topolo4958980785337419405_space @ B )
& ( topolo4958980785337419405_space @ C ) )
=> ! [S: set @ A,F2: A > B,G: A > C] :
( ( topolo81223032696312382ous_on @ A @ B @ S @ F2 )
=> ( ( topolo81223032696312382ous_on @ A @ C @ S @ G )
=> ( topolo81223032696312382ous_on @ A @ ( product_prod @ B @ C ) @ S
@ ^ [X2: A] : ( product_Pair @ B @ C @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ).
% continuous_on_Pair
thf(fact_4894_continuous__inj__imp__mono,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo8458572112393995274pology @ A )
& ( topolo1944317154257567458pology @ B ) )
=> ! [A3: A,X: A,B2: A,F2: A > B] :
( ( ord_less @ A @ A3 @ X )
=> ( ( ord_less @ A @ X @ B2 )
=> ( ( topolo81223032696312382ous_on @ A @ B @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ F2 )
=> ( ( inj_on @ A @ B @ F2 @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) )
=> ( ( ( ord_less @ B @ ( F2 @ A3 ) @ ( F2 @ X ) )
& ( ord_less @ B @ ( F2 @ X ) @ ( F2 @ B2 ) ) )
| ( ( ord_less @ B @ ( F2 @ B2 ) @ ( F2 @ X ) )
& ( ord_less @ B @ ( F2 @ X ) @ ( F2 @ A3 ) ) ) ) ) ) ) ) ) ).
% continuous_inj_imp_mono
thf(fact_4895_IVT2_H,axiom,
! [A: $tType,B: $tType] :
( ( ( topolo1944317154257567458pology @ B )
& ( topolo8458572112393995274pology @ A ) )
=> ! [F2: A > B,B2: A,Y: B,A3: A] :
( ( ord_less_eq @ B @ ( F2 @ B2 ) @ Y )
=> ( ( ord_less_eq @ B @ Y @ ( F2 @ A3 ) )
=> ( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( topolo81223032696312382ous_on @ A @ B @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ F2 )
=> ? [X5: A] :
( ( ord_less_eq @ A @ A3 @ X5 )
& ( ord_less_eq @ A @ X5 @ B2 )
& ( ( F2 @ X5 )
= Y ) ) ) ) ) ) ) ).
% IVT2'
thf(fact_4896_IVT_H,axiom,
! [A: $tType,B: $tType] :
( ( ( topolo1944317154257567458pology @ B )
& ( topolo8458572112393995274pology @ A ) )
=> ! [F2: A > B,A3: A,Y: B,B2: A] :
( ( ord_less_eq @ B @ ( F2 @ A3 ) @ Y )
=> ( ( ord_less_eq @ B @ Y @ ( F2 @ B2 ) )
=> ( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( topolo81223032696312382ous_on @ A @ B @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ F2 )
=> ? [X5: A] :
( ( ord_less_eq @ A @ A3 @ X5 )
& ( ord_less_eq @ A @ X5 @ B2 )
& ( ( F2 @ X5 )
= Y ) ) ) ) ) ) ) ).
% IVT'
thf(fact_4897_linorder__inj__onI,axiom,
! [B: $tType,A: $tType] :
( ( order @ A )
=> ! [A4: set @ A,F2: A > B] :
( ! [X5: A,Y4: A] :
( ( ord_less @ A @ X5 @ Y4 )
=> ( ( member2 @ A @ X5 @ A4 )
=> ( ( member2 @ A @ Y4 @ A4 )
=> ( ( F2 @ X5 )
!= ( F2 @ Y4 ) ) ) ) )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ( member2 @ A @ Y4 @ A4 )
=> ( ( ord_less_eq @ A @ X5 @ Y4 )
| ( ord_less_eq @ A @ Y4 @ X5 ) ) ) )
=> ( inj_on @ A @ B @ F2 @ A4 ) ) ) ) ).
% linorder_inj_onI
thf(fact_4898_continuous__on__sing,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [X: A,F2: A > B] : ( topolo81223032696312382ous_on @ A @ B @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) @ F2 ) ) ).
% continuous_on_sing
thf(fact_4899_inj__on__mult,axiom,
! [A: $tType] :
( ( semidom_divide @ A )
=> ! [A3: A,A4: set @ A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( inj_on @ A @ A @ ( times_times @ A @ A3 ) @ A4 ) ) ) ).
% inj_on_mult
thf(fact_4900_linorder__injI,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ A )
=> ! [F2: A > B] :
( ! [X5: A,Y4: A] :
( ( ord_less @ A @ X5 @ Y4 )
=> ( ( F2 @ X5 )
!= ( F2 @ Y4 ) ) )
=> ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) ) ) ) ).
% linorder_injI
thf(fact_4901_inj__add__left,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A )
=> ! [A3: A] : ( inj_on @ A @ A @ ( plus_plus @ A @ A3 ) @ ( top_top @ ( set @ A ) ) ) ) ).
% inj_add_left
thf(fact_4902_subset__image__inj,axiom,
! [A: $tType,B: $tType,S3: set @ A,F2: B > A,T4: set @ B] :
( ( ord_less_eq @ ( set @ A ) @ S3 @ ( image2 @ B @ A @ F2 @ T4 ) )
= ( ? [U5: set @ B] :
( ( ord_less_eq @ ( set @ B ) @ U5 @ T4 )
& ( inj_on @ B @ A @ F2 @ U5 )
& ( S3
= ( image2 @ B @ A @ F2 @ U5 ) ) ) ) ) ).
% subset_image_inj
thf(fact_4903_inj__on__image__eq__iff,axiom,
! [B: $tType,A: $tType,F2: A > B,C5: set @ A,A4: set @ A,B3: set @ A] :
( ( inj_on @ A @ B @ F2 @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ C5 )
=> ( ( ( image2 @ A @ B @ F2 @ A4 )
= ( image2 @ A @ B @ F2 @ B3 ) )
= ( A4 = B3 ) ) ) ) ) ).
% inj_on_image_eq_iff
thf(fact_4904_inj__on__image__mem__iff,axiom,
! [B: $tType,A: $tType,F2: A > B,B3: set @ A,A3: A,A4: set @ A] :
( ( inj_on @ A @ B @ F2 @ B3 )
=> ( ( member2 @ A @ A3 @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( member2 @ B @ ( F2 @ A3 ) @ ( image2 @ A @ B @ F2 @ A4 ) )
= ( member2 @ A @ A3 @ A4 ) ) ) ) ) ).
% inj_on_image_mem_iff
thf(fact_4905_inj__fn,axiom,
! [A: $tType,F2: A > A,N2: nat] :
( ( inj_on @ A @ A @ F2 @ ( top_top @ ( set @ A ) ) )
=> ( inj_on @ A @ A @ ( compow @ ( A > A ) @ N2 @ F2 ) @ ( top_top @ ( set @ A ) ) ) ) ).
% inj_fn
thf(fact_4906_continuous__on__divide,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( real_V3459762299906320749_field @ B ) )
=> ! [S: set @ A,F2: A > B,G: A > B] :
( ( topolo81223032696312382ous_on @ A @ B @ S @ F2 )
=> ( ( topolo81223032696312382ous_on @ A @ B @ S @ G )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ S )
=> ( ( G @ X5 )
!= ( zero_zero @ B ) ) )
=> ( topolo81223032696312382ous_on @ A @ B @ S
@ ^ [X2: A] : ( divide_divide @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ) ).
% continuous_on_divide
thf(fact_4907_continuous__on__compose2,axiom,
! [A: $tType,B: $tType,C: $tType] :
( ( ( topolo4958980785337419405_space @ C )
& ( topolo4958980785337419405_space @ B )
& ( topolo4958980785337419405_space @ A ) )
=> ! [T2: set @ A,G: A > B,S: set @ C,F2: C > A] :
( ( topolo81223032696312382ous_on @ A @ B @ T2 @ G )
=> ( ( topolo81223032696312382ous_on @ C @ A @ S @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image2 @ C @ A @ F2 @ S ) @ T2 )
=> ( topolo81223032696312382ous_on @ C @ B @ S
@ ^ [X2: C] : ( G @ ( F2 @ X2 ) ) ) ) ) ) ) ).
% continuous_on_compose2
thf(fact_4908_inj__on__Inter,axiom,
! [B: $tType,A: $tType,S3: set @ ( set @ A ),F2: A > B] :
( ( S3
!= ( bot_bot @ ( set @ ( set @ A ) ) ) )
=> ( ! [A9: set @ A] :
( ( member2 @ ( set @ A ) @ A9 @ S3 )
=> ( inj_on @ A @ B @ F2 @ A9 ) )
=> ( inj_on @ A @ B @ F2 @ ( complete_Inf_Inf @ ( set @ A ) @ S3 ) ) ) ) ).
% inj_on_Inter
thf(fact_4909_continuous__on__inverse,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( real_V8999393235501362500lgebra @ B ) )
=> ! [S: set @ A,F2: A > B] :
( ( topolo81223032696312382ous_on @ A @ B @ S @ F2 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ S )
=> ( ( F2 @ X5 )
!= ( zero_zero @ B ) ) )
=> ( topolo81223032696312382ous_on @ A @ B @ S
@ ^ [X2: A] : ( inverse_inverse @ B @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_on_inverse
thf(fact_4910_continuous__on__sgn,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [S: set @ A,F2: A > B] :
( ( topolo81223032696312382ous_on @ A @ B @ S @ F2 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ S )
=> ( ( F2 @ X5 )
!= ( zero_zero @ B ) ) )
=> ( topolo81223032696312382ous_on @ A @ B @ S
@ ^ [X2: A] : ( sgn_sgn @ B @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_on_sgn
thf(fact_4911_continuous__onI__mono,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo1944317154257567458pology @ A )
& ( dense_order @ B )
& ( topolo1944317154257567458pology @ B ) )
=> ! [F2: A > B,A4: set @ A] :
( ( topolo1002775350975398744n_open @ B @ ( image2 @ A @ B @ F2 @ A4 ) )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ( member2 @ A @ Y4 @ A4 )
=> ( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ord_less_eq @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) ) ) )
=> ( topolo81223032696312382ous_on @ A @ B @ A4 @ F2 ) ) ) ) ).
% continuous_onI_mono
thf(fact_4912_inj__image__subset__iff,axiom,
! [B: $tType,A: $tType,F2: A > B,A4: set @ A,B3: set @ A] :
( ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ ( image2 @ A @ B @ F2 @ B3 ) )
= ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ) ).
% inj_image_subset_iff
thf(fact_4913_inj__on__iff__surj,axiom,
! [A: $tType,B: $tType,A4: set @ A,A16: set @ B] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ? [F3: A > B] :
( ( inj_on @ A @ B @ F3 @ A4 )
& ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F3 @ A4 ) @ A16 ) ) )
= ( ? [G2: B > A] :
( ( image2 @ B @ A @ G2 @ A16 )
= A4 ) ) ) ) ).
% inj_on_iff_surj
thf(fact_4914_endo__inj__surj,axiom,
! [A: $tType,A4: set @ A,F2: A > A] :
( ( finite_finite @ A @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image2 @ A @ A @ F2 @ A4 ) @ A4 )
=> ( ( inj_on @ A @ A @ F2 @ A4 )
=> ( ( image2 @ A @ A @ F2 @ A4 )
= A4 ) ) ) ) ).
% endo_inj_surj
thf(fact_4915_inj__on__finite,axiom,
! [B: $tType,A: $tType,F2: A > B,A4: set @ A,B3: set @ B] :
( ( inj_on @ A @ B @ F2 @ A4 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ B3 )
=> ( ( finite_finite @ B @ B3 )
=> ( finite_finite @ A @ A4 ) ) ) ) ).
% inj_on_finite
thf(fact_4916_finite__surj__inj,axiom,
! [A: $tType,A4: set @ A,F2: A > A] :
( ( finite_finite @ A @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( image2 @ A @ A @ F2 @ A4 ) )
=> ( inj_on @ A @ A @ F2 @ A4 ) ) ) ).
% finite_surj_inj
thf(fact_4917_inj__on__image__Int,axiom,
! [B: $tType,A: $tType,F2: A > B,C5: set @ A,A4: set @ A,B3: set @ A] :
( ( inj_on @ A @ B @ F2 @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ C5 )
=> ( ( image2 @ A @ B @ F2 @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) )
= ( inf_inf @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ ( image2 @ A @ B @ F2 @ B3 ) ) ) ) ) ) ).
% inj_on_image_Int
thf(fact_4918_inj__on__image__set__diff,axiom,
! [B: $tType,A: $tType,F2: A > B,C5: set @ A,A4: set @ A,B3: set @ A] :
( ( inj_on @ A @ B @ F2 @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ C5 )
=> ( ( image2 @ A @ B @ F2 @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) )
= ( minus_minus @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ ( image2 @ A @ B @ F2 @ B3 ) ) ) ) ) ) ).
% inj_on_image_set_diff
thf(fact_4919_pigeonhole,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B] :
( ( ord_less @ nat @ ( finite_card @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( finite_card @ B @ A4 ) )
=> ~ ( inj_on @ B @ A @ F2 @ A4 ) ) ).
% pigeonhole
thf(fact_4920_continuous__attains__sup,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( topolo1944317154257567458pology @ B ) )
=> ! [S: set @ A,F2: A > B] :
( ( topolo2193935891317330818ompact @ A @ S )
=> ( ( S
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( topolo81223032696312382ous_on @ A @ B @ S @ F2 )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ S )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ S )
=> ( ord_less_eq @ B @ ( F2 @ Xa ) @ ( F2 @ X5 ) ) ) ) ) ) ) ) ).
% continuous_attains_sup
thf(fact_4921_continuous__attains__inf,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( topolo1944317154257567458pology @ B ) )
=> ! [S: set @ A,F2: A > B] :
( ( topolo2193935891317330818ompact @ A @ S )
=> ( ( S
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( topolo81223032696312382ous_on @ A @ B @ S @ F2 )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ S )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ S )
=> ( ord_less_eq @ B @ ( F2 @ X5 ) @ ( F2 @ Xa ) ) ) ) ) ) ) ) ).
% continuous_attains_inf
thf(fact_4922_the__inv__into__into,axiom,
! [B: $tType,A: $tType,F2: A > B,A4: set @ A,X: B,B3: set @ A] :
( ( inj_on @ A @ B @ F2 @ A4 )
=> ( ( member2 @ B @ X @ ( image2 @ A @ B @ F2 @ A4 ) )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( member2 @ A @ ( the_inv_into @ A @ B @ A4 @ F2 @ X ) @ B3 ) ) ) ) ).
% the_inv_into_into
thf(fact_4923_open__Collect__less,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( topolo1944317154257567458pology @ B ) )
=> ! [F2: A > B,G: A > B] :
( ( topolo81223032696312382ous_on @ A @ B @ ( top_top @ ( set @ A ) ) @ F2 )
=> ( ( topolo81223032696312382ous_on @ A @ B @ ( top_top @ ( set @ A ) ) @ G )
=> ( topolo1002775350975398744n_open @ A
@ ( collect @ A
@ ^ [X2: A] : ( ord_less @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ) ).
% open_Collect_less
thf(fact_4924_continuous__on__tan,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [S: set @ A,F2: A > A] :
( ( topolo81223032696312382ous_on @ A @ A @ S @ F2 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ S )
=> ( ( cos @ A @ ( F2 @ X5 ) )
!= ( zero_zero @ A ) ) )
=> ( topolo81223032696312382ous_on @ A @ A @ S
@ ^ [X2: A] : ( tan @ A @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_on_tan
thf(fact_4925_inj__on__UNION__chain,axiom,
! [C: $tType,B: $tType,A: $tType,I6: set @ A,A4: A > ( set @ B ),F2: B > C] :
( ! [I3: A,J2: A] :
( ( member2 @ A @ I3 @ I6 )
=> ( ( member2 @ A @ J2 @ I6 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( A4 @ I3 ) @ ( A4 @ J2 ) )
| ( ord_less_eq @ ( set @ B ) @ ( A4 @ J2 ) @ ( A4 @ I3 ) ) ) ) )
=> ( ! [I3: A] :
( ( member2 @ A @ I3 @ I6 )
=> ( inj_on @ B @ C @ F2 @ ( A4 @ I3 ) ) )
=> ( inj_on @ B @ C @ F2 @ ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ A4 @ I6 ) ) ) ) ) ).
% inj_on_UNION_chain
thf(fact_4926_inj__on__INTER,axiom,
! [C: $tType,B: $tType,A: $tType,I6: set @ A,F2: B > C,A4: A > ( set @ B )] :
( ( I6
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [I3: A] :
( ( member2 @ A @ I3 @ I6 )
=> ( inj_on @ B @ C @ F2 @ ( A4 @ I3 ) ) )
=> ( inj_on @ B @ C @ F2 @ ( complete_Inf_Inf @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ A4 @ I6 ) ) ) ) ) ).
% inj_on_INTER
thf(fact_4927_continuous__on__cot,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [S: set @ A,F2: A > A] :
( ( topolo81223032696312382ous_on @ A @ A @ S @ F2 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ S )
=> ( ( sin @ A @ ( F2 @ X5 ) )
!= ( zero_zero @ A ) ) )
=> ( topolo81223032696312382ous_on @ A @ A @ S
@ ^ [X2: A] : ( cot @ A @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_on_cot
thf(fact_4928_continuous__on__tanh,axiom,
! [A: $tType,C: $tType] :
( ( ( topolo4958980785337419405_space @ C )
& ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [A4: set @ C,F2: C > A] :
( ( topolo81223032696312382ous_on @ C @ A @ A4 @ F2 )
=> ( ! [X5: C] :
( ( member2 @ C @ X5 @ A4 )
=> ( ( cosh @ A @ ( F2 @ X5 ) )
!= ( zero_zero @ A ) ) )
=> ( topolo81223032696312382ous_on @ C @ A @ A4
@ ^ [X2: C] : ( tanh @ A @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_on_tanh
thf(fact_4929_card__bij__eq,axiom,
! [A: $tType,B: $tType,F2: A > B,A4: set @ A,B3: set @ B,G: B > A] :
( ( inj_on @ A @ B @ F2 @ A4 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ B3 )
=> ( ( inj_on @ B @ A @ G @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ G @ B3 ) @ A4 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ( finite_card @ A @ A4 )
= ( finite_card @ B @ B3 ) ) ) ) ) ) ) ) ).
% card_bij_eq
thf(fact_4930_surjective__iff__injective__gen,axiom,
! [B: $tType,A: $tType,S3: set @ A,T4: set @ B,F2: A > B] :
( ( finite_finite @ A @ S3 )
=> ( ( finite_finite @ B @ T4 )
=> ( ( ( finite_card @ A @ S3 )
= ( finite_card @ B @ T4 ) )
=> ( ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ S3 ) @ T4 )
=> ( ( ! [X2: B] :
( ( member2 @ B @ X2 @ T4 )
=> ? [Y2: A] :
( ( member2 @ A @ Y2 @ S3 )
& ( ( F2 @ Y2 )
= X2 ) ) ) )
= ( inj_on @ A @ B @ F2 @ S3 ) ) ) ) ) ) ).
% surjective_iff_injective_gen
thf(fact_4931_inj__image__Compl__subset,axiom,
! [B: $tType,A: $tType,F2: A > B,A4: set @ A] :
( ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
=> ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ ( uminus_uminus @ ( set @ A ) @ A4 ) ) @ ( uminus_uminus @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) ) ) ) ).
% inj_image_Compl_subset
thf(fact_4932_t4__space,axiom,
! [A: $tType] :
( ( topological_t4_space @ A )
=> ! [S3: set @ A,T4: set @ A] :
( ( topolo7761053866217962861closed @ A @ S3 )
=> ( ( topolo7761053866217962861closed @ A @ T4 )
=> ( ( ( inf_inf @ ( set @ A ) @ S3 @ T4 )
= ( bot_bot @ ( set @ A ) ) )
=> ? [U6: set @ A,V7: set @ A] :
( ( topolo1002775350975398744n_open @ A @ U6 )
& ( topolo1002775350975398744n_open @ A @ V7 )
& ( ord_less_eq @ ( set @ A ) @ S3 @ U6 )
& ( ord_less_eq @ ( set @ A ) @ T4 @ V7 )
& ( ( inf_inf @ ( set @ A ) @ U6 @ V7 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% t4_space
thf(fact_4933_t3__space,axiom,
! [A: $tType] :
( ( topological_t3_space @ A )
=> ! [S3: set @ A,Y: A] :
( ( topolo7761053866217962861closed @ A @ S3 )
=> ( ~ ( member2 @ A @ Y @ S3 )
=> ? [U6: set @ A,V7: set @ A] :
( ( topolo1002775350975398744n_open @ A @ U6 )
& ( topolo1002775350975398744n_open @ A @ V7 )
& ( member2 @ A @ Y @ U6 )
& ( ord_less_eq @ ( set @ A ) @ S3 @ V7 )
& ( ( inf_inf @ ( set @ A ) @ U6 @ V7 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% t3_space
thf(fact_4934_image__INT,axiom,
! [B: $tType,A: $tType,C: $tType,F2: A > B,C5: set @ A,A4: set @ C,B3: C > ( set @ A ),J: C] :
( ( inj_on @ A @ B @ F2 @ C5 )
=> ( ! [X5: C] :
( ( member2 @ C @ X5 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ ( B3 @ X5 ) @ C5 ) )
=> ( ( member2 @ C @ J @ A4 )
=> ( ( image2 @ A @ B @ F2 @ ( complete_Inf_Inf @ ( set @ A ) @ ( image2 @ C @ ( set @ A ) @ B3 @ A4 ) ) )
= ( complete_Inf_Inf @ ( set @ B )
@ ( image2 @ C @ ( set @ B )
@ ^ [X2: C] : ( image2 @ A @ B @ F2 @ ( B3 @ X2 ) )
@ A4 ) ) ) ) ) ) ).
% image_INT
thf(fact_4935_nhds__closed,axiom,
! [A: $tType] :
( ( topological_t3_space @ A )
=> ! [X: A,A4: set @ A] :
( ( member2 @ A @ X @ A4 )
=> ( ( topolo1002775350975398744n_open @ A @ A4 )
=> ? [A17: set @ A] :
( ( member2 @ A @ X @ A17 )
& ( topolo7761053866217962861closed @ A @ A17 )
& ( ord_less_eq @ ( set @ A ) @ A17 @ A4 )
& ( eventually @ A
@ ^ [Y2: A] : ( member2 @ A @ Y2 @ A17 )
@ ( topolo7230453075368039082e_nhds @ A @ X ) ) ) ) ) ) ).
% nhds_closed
thf(fact_4936_Lim__in__closed__set,axiom,
! [B: $tType,A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S3: set @ A,F2: B > A,F5: filter @ B,L: A] :
( ( topolo7761053866217962861closed @ A @ S3 )
=> ( ( eventually @ B
@ ^ [X2: B] : ( member2 @ A @ ( F2 @ X2 ) @ S3 )
@ F5 )
=> ( ( F5
!= ( bot_bot @ ( filter @ B ) ) )
=> ( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L ) @ F5 )
=> ( member2 @ A @ L @ S3 ) ) ) ) ) ) ).
% Lim_in_closed_set
thf(fact_4937_DERIV__atLeastAtMost__imp__continuous__on,axiom,
! [A: $tType] :
( ( ( ord @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [A3: A,B2: A,F2: A > A] :
( ! [X5: A] :
( ( ord_less_eq @ A @ A3 @ X5 )
=> ( ( ord_less_eq @ A @ X5 @ B2 )
=> ? [Y3: A] : ( has_field_derivative @ A @ F2 @ Y3 @ ( topolo174197925503356063within @ A @ X5 @ ( top_top @ ( set @ A ) ) ) ) ) )
=> ( topolo81223032696312382ous_on @ A @ A @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ F2 ) ) ) ).
% DERIV_atLeastAtMost_imp_continuous_on
thf(fact_4938_card__le__inj,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ( ord_less_eq @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ B @ B3 ) )
=> ? [F4: A > B] :
( ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F4 @ A4 ) @ B3 )
& ( inj_on @ A @ B @ F4 @ A4 ) ) ) ) ) ).
% card_le_inj
thf(fact_4939_card__inj__on__le,axiom,
! [A: $tType,B: $tType,F2: A > B,A4: set @ A,B3: set @ B] :
( ( inj_on @ A @ B @ F2 @ A4 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ B3 )
=> ( ( finite_finite @ B @ B3 )
=> ( ord_less_eq @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ B @ B3 ) ) ) ) ) ).
% card_inj_on_le
thf(fact_4940_inj__on__iff__card__le,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ( ? [F3: A > B] :
( ( inj_on @ A @ B @ F3 @ A4 )
& ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F3 @ A4 ) @ B3 ) ) )
= ( ord_less_eq @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ B @ B3 ) ) ) ) ) ).
% inj_on_iff_card_le
thf(fact_4941_continuous__on__Icc__at__leftD,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo1944317154257567458pology @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [A3: A,B2: A,F2: A > B] :
( ( topolo81223032696312382ous_on @ A @ B @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ F2 )
=> ( ( ord_less @ A @ A3 @ B2 )
=> ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( F2 @ B2 ) ) @ ( topolo174197925503356063within @ A @ B2 @ ( set_ord_lessThan @ A @ B2 ) ) ) ) ) ) ).
% continuous_on_Icc_at_leftD
thf(fact_4942_continuous__on__Icc__at__rightD,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo1944317154257567458pology @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [A3: A,B2: A,F2: A > B] :
( ( topolo81223032696312382ous_on @ A @ B @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ F2 )
=> ( ( ord_less @ A @ A3 @ B2 )
=> ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( F2 @ A3 ) ) @ ( topolo174197925503356063within @ A @ A3 @ ( set_ord_greaterThan @ A @ A3 ) ) ) ) ) ) ).
% continuous_on_Icc_at_rightD
thf(fact_4943_compact__fip,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ( ( topolo2193935891317330818ompact @ A )
= ( ^ [U5: set @ A] :
! [A6: set @ ( set @ A )] :
( ! [X2: set @ A] :
( ( member2 @ ( set @ A ) @ X2 @ A6 )
=> ( topolo7761053866217962861closed @ A @ X2 ) )
=> ( ! [B6: set @ ( set @ A )] :
( ( ord_less_eq @ ( set @ ( set @ A ) ) @ B6 @ A6 )
=> ( ( finite_finite @ ( set @ A ) @ B6 )
=> ( ( inf_inf @ ( set @ A ) @ U5 @ ( complete_Inf_Inf @ ( set @ A ) @ B6 ) )
!= ( bot_bot @ ( set @ A ) ) ) ) )
=> ( ( inf_inf @ ( set @ A ) @ U5 @ ( complete_Inf_Inf @ ( set @ A ) @ A6 ) )
!= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% compact_fip
thf(fact_4944_compact__imp__fip,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S3: set @ A,F5: set @ ( set @ A )] :
( ( topolo2193935891317330818ompact @ A @ S3 )
=> ( ! [T6: set @ A] :
( ( member2 @ ( set @ A ) @ T6 @ F5 )
=> ( topolo7761053866217962861closed @ A @ T6 ) )
=> ( ! [F11: set @ ( set @ A )] :
( ( finite_finite @ ( set @ A ) @ F11 )
=> ( ( ord_less_eq @ ( set @ ( set @ A ) ) @ F11 @ F5 )
=> ( ( inf_inf @ ( set @ A ) @ S3 @ ( complete_Inf_Inf @ ( set @ A ) @ F11 ) )
!= ( bot_bot @ ( set @ A ) ) ) ) )
=> ( ( inf_inf @ ( set @ A ) @ S3 @ ( complete_Inf_Inf @ ( set @ A ) @ F5 ) )
!= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% compact_imp_fip
thf(fact_4945_all__subset__image__inj,axiom,
! [A: $tType,B: $tType,F2: B > A,S3: set @ B,P2: ( set @ A ) > $o] :
( ( ! [T10: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ T10 @ ( image2 @ B @ A @ F2 @ S3 ) )
=> ( P2 @ T10 ) ) )
= ( ! [T10: set @ B] :
( ( ( ord_less_eq @ ( set @ B ) @ T10 @ S3 )
& ( inj_on @ B @ A @ F2 @ T10 ) )
=> ( P2 @ ( image2 @ B @ A @ F2 @ T10 ) ) ) ) ) ).
% all_subset_image_inj
thf(fact_4946_ex__subset__image__inj,axiom,
! [A: $tType,B: $tType,F2: B > A,S3: set @ B,P2: ( set @ A ) > $o] :
( ( ? [T10: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ T10 @ ( image2 @ B @ A @ F2 @ S3 ) )
& ( P2 @ T10 ) ) )
= ( ? [T10: set @ B] :
( ( ord_less_eq @ ( set @ B ) @ T10 @ S3 )
& ( inj_on @ B @ A @ F2 @ T10 )
& ( P2 @ ( image2 @ B @ A @ F2 @ T10 ) ) ) ) ) ).
% ex_subset_image_inj
thf(fact_4947_set__list__bind,axiom,
! [A: $tType,B: $tType,Xs: list @ B,F2: B > ( list @ A )] :
( ( set2 @ A @ ( bind @ B @ A @ Xs @ F2 ) )
= ( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [X2: B] : ( set2 @ A @ ( F2 @ X2 ) )
@ ( set2 @ B @ Xs ) ) ) ) ).
% set_list_bind
thf(fact_4948_bind__simps_I1_J,axiom,
! [B: $tType,A: $tType,F2: B > ( list @ A )] :
( ( bind @ B @ A @ ( nil @ B ) @ F2 )
= ( nil @ A ) ) ).
% bind_simps(1)
thf(fact_4949_inj__Some,axiom,
! [A: $tType,A4: set @ A] : ( inj_on @ A @ ( option @ A ) @ ( some @ A ) @ A4 ) ).
% inj_Some
thf(fact_4950_inj__Suc,axiom,
! [N7: set @ nat] : ( inj_on @ nat @ nat @ suc @ N7 ) ).
% inj_Suc
thf(fact_4951_inj__on__convol__ident,axiom,
! [B: $tType,A: $tType,F2: A > B,X7: set @ A] :
( inj_on @ A @ ( product_prod @ A @ B )
@ ^ [X2: A] : ( product_Pair @ A @ B @ X2 @ ( F2 @ X2 ) )
@ X7 ) ).
% inj_on_convol_ident
thf(fact_4952_inj__of__nat,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ( inj_on @ nat @ A @ ( semiring_1_of_nat @ A ) @ ( top_top @ ( set @ nat ) ) ) ) ).
% inj_of_nat
thf(fact_4953_inj__singleton,axiom,
! [A: $tType,A4: set @ A] :
( inj_on @ A @ ( set @ A )
@ ^ [X2: A] : ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) )
@ A4 ) ).
% inj_singleton
thf(fact_4954_inj__on__diff__nat,axiom,
! [N7: set @ nat,K: nat] :
( ! [N3: nat] :
( ( member2 @ nat @ N3 @ N7 )
=> ( ord_less_eq @ nat @ K @ N3 ) )
=> ( inj_on @ nat @ nat
@ ^ [N: nat] : ( minus_minus @ nat @ N @ K )
@ N7 ) ) ).
% inj_on_diff_nat
thf(fact_4955_swap__inj__on,axiom,
! [B: $tType,A: $tType,A4: set @ ( product_prod @ A @ B )] :
( inj_on @ ( product_prod @ A @ B ) @ ( product_prod @ B @ A )
@ ( product_case_prod @ A @ B @ ( product_prod @ B @ A )
@ ^ [I5: A,J3: B] : ( product_Pair @ B @ A @ J3 @ I5 ) )
@ A4 ) ).
% swap_inj_on
thf(fact_4956_list__bind__cong,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ A,F2: A > ( list @ B ),G: A > ( list @ B )] :
( ( Xs = Ys )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( F2 @ X5 )
= ( G @ X5 ) ) )
=> ( ( bind @ A @ B @ Xs @ F2 )
= ( bind @ A @ B @ Ys @ G ) ) ) ) ).
% list_bind_cong
thf(fact_4957_finite__imp__nat__seg__image__inj__on,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ? [N3: nat,F4: nat > A] :
( ( A4
= ( image2 @ nat @ A @ F4
@ ( collect @ nat
@ ^ [I5: nat] : ( ord_less @ nat @ I5 @ N3 ) ) ) )
& ( inj_on @ nat @ A @ F4
@ ( collect @ nat
@ ^ [I5: nat] : ( ord_less @ nat @ I5 @ N3 ) ) ) ) ) ).
% finite_imp_nat_seg_image_inj_on
thf(fact_4958_finite__imp__inj__to__nat__seg,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ? [F4: A > nat,N3: nat] :
( ( ( image2 @ A @ nat @ F4 @ A4 )
= ( collect @ nat
@ ^ [I5: nat] : ( ord_less @ nat @ I5 @ N3 ) ) )
& ( inj_on @ A @ nat @ F4 @ A4 ) ) ) ).
% finite_imp_inj_to_nat_seg
thf(fact_4959_inj__on__nth,axiom,
! [A: $tType,Xs: list @ A,I6: set @ nat] :
( ( distinct @ A @ Xs )
=> ( ! [X5: nat] :
( ( member2 @ nat @ X5 @ I6 )
=> ( ord_less @ nat @ X5 @ ( size_size @ ( list @ A ) @ Xs ) ) )
=> ( inj_on @ nat @ A @ ( nth @ A @ Xs ) @ I6 ) ) ) ).
% inj_on_nth
thf(fact_4960_infinite__iff__countable__subset,axiom,
! [A: $tType,S3: set @ A] :
( ( ~ ( finite_finite @ A @ S3 ) )
= ( ? [F3: nat > A] :
( ( inj_on @ nat @ A @ F3 @ ( top_top @ ( set @ nat ) ) )
& ( ord_less_eq @ ( set @ A ) @ ( image2 @ nat @ A @ F3 @ ( top_top @ ( set @ nat ) ) ) @ S3 ) ) ) ) ).
% infinite_iff_countable_subset
thf(fact_4961_infinite__countable__subset,axiom,
! [A: $tType,S3: set @ A] :
( ~ ( finite_finite @ A @ S3 )
=> ? [F4: nat > A] :
( ( inj_on @ nat @ A @ F4 @ ( top_top @ ( set @ nat ) ) )
& ( ord_less_eq @ ( set @ A ) @ ( image2 @ nat @ A @ F4 @ ( top_top @ ( set @ nat ) ) ) @ S3 ) ) ) ).
% infinite_countable_subset
thf(fact_4962_inj__on__funpow__least,axiom,
! [A: $tType,N2: nat,F2: A > A,S: A] :
( ( ( compow @ ( A > A ) @ N2 @ F2 @ S )
= S )
=> ( ! [M3: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ M3 )
=> ( ( ord_less @ nat @ M3 @ N2 )
=> ( ( compow @ ( A > A ) @ M3 @ F2 @ S )
!= S ) ) )
=> ( inj_on @ nat @ A
@ ^ [K2: nat] : ( compow @ ( A > A ) @ K2 @ F2 @ S )
@ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% inj_on_funpow_least
thf(fact_4963_has__derivative__power__int_H,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [X: A,N2: int,S3: set @ A] :
( ( X
!= ( zero_zero @ A ) )
=> ( has_derivative @ A @ A
@ ^ [X2: A] : ( power_int @ A @ X2 @ N2 )
@ ^ [Y2: A] : ( times_times @ A @ Y2 @ ( times_times @ A @ ( ring_1_of_int @ A @ N2 ) @ ( power_int @ A @ X @ ( minus_minus @ int @ N2 @ ( one_one @ int ) ) ) ) )
@ ( topolo174197925503356063within @ A @ X @ S3 ) ) ) ) ).
% has_derivative_power_int'
thf(fact_4964_has__derivative__power__int,axiom,
! [A: $tType,C: $tType] :
( ( ( real_V822414075346904944vector @ C )
& ( real_V3459762299906320749_field @ A ) )
=> ! [F2: C > A,X: C,F8: C > A,S3: set @ C,N2: int] :
( ( ( F2 @ X )
!= ( zero_zero @ A ) )
=> ( ( has_derivative @ C @ A @ F2 @ F8 @ ( topolo174197925503356063within @ C @ X @ S3 ) )
=> ( has_derivative @ C @ A
@ ^ [X2: C] : ( power_int @ A @ ( F2 @ X2 ) @ N2 )
@ ^ [H: C] : ( times_times @ A @ ( F8 @ H ) @ ( times_times @ A @ ( ring_1_of_int @ A @ N2 ) @ ( power_int @ A @ ( F2 @ X ) @ ( minus_minus @ int @ N2 @ ( one_one @ int ) ) ) ) )
@ ( topolo174197925503356063within @ C @ X @ S3 ) ) ) ) ) ).
% has_derivative_power_int
thf(fact_4965_DERIV__power__int,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [F2: A > A,D2: A,X: A,S: set @ A,N2: int] :
( ( has_field_derivative @ A @ F2 @ D2 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ( F2 @ X )
!= ( zero_zero @ A ) )
=> ( has_field_derivative @ A
@ ^ [X2: A] : ( power_int @ A @ ( F2 @ X2 ) @ N2 )
@ ( times_times @ A @ ( times_times @ A @ ( ring_1_of_int @ A @ N2 ) @ ( power_int @ A @ ( F2 @ X ) @ ( minus_minus @ int @ N2 @ ( one_one @ int ) ) ) ) @ D2 )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ).
% DERIV_power_int
thf(fact_4966_power__int__1__left,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [N2: int] :
( ( power_int @ A @ ( one_one @ A ) @ N2 )
= ( one_one @ A ) ) ) ).
% power_int_1_left
thf(fact_4967_power__int__mult__numeral,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,M: num,N2: num] :
( ( power_int @ A @ ( power_int @ A @ X @ ( numeral_numeral @ int @ M ) ) @ ( numeral_numeral @ int @ N2 ) )
= ( power_int @ A @ X @ ( numeral_numeral @ int @ ( times_times @ num @ M @ N2 ) ) ) ) ) ).
% power_int_mult_numeral
thf(fact_4968_power__int__1__right,axiom,
! [A: $tType] :
( ( ( inverse @ A )
& ( monoid_mult @ A ) )
=> ! [Y: A] :
( ( power_int @ A @ Y @ ( one_one @ int ) )
= Y ) ) ).
% power_int_1_right
thf(fact_4969_power__int__sgn,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,N2: int] :
( ( sgn_sgn @ A @ ( power_int @ A @ A3 @ N2 ) )
= ( power_int @ A @ ( sgn_sgn @ A @ A3 ) @ N2 ) ) ) ).
% power_int_sgn
thf(fact_4970_power__int__mult__distrib__numeral2,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [X: A,W2: num,M: int] :
( ( power_int @ A @ ( times_times @ A @ X @ ( numeral_numeral @ A @ W2 ) ) @ M )
= ( times_times @ A @ ( power_int @ A @ X @ M ) @ ( power_int @ A @ ( numeral_numeral @ A @ W2 ) @ M ) ) ) ) ).
% power_int_mult_distrib_numeral2
thf(fact_4971_power__int__mult__distrib__numeral1,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [W2: num,Y: A,M: int] :
( ( power_int @ A @ ( times_times @ A @ ( numeral_numeral @ A @ W2 ) @ Y ) @ M )
= ( times_times @ A @ ( power_int @ A @ ( numeral_numeral @ A @ W2 ) @ M ) @ ( power_int @ A @ Y @ M ) ) ) ) ).
% power_int_mult_distrib_numeral1
thf(fact_4972_power__int__eq__0__iff,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,N2: int] :
( ( ( power_int @ A @ X @ N2 )
= ( zero_zero @ A ) )
= ( ( X
= ( zero_zero @ A ) )
& ( N2
!= ( zero_zero @ int ) ) ) ) ) ).
% power_int_eq_0_iff
thf(fact_4973_power__int__0__left,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [M: int] :
( ( M
!= ( zero_zero @ int ) )
=> ( ( power_int @ A @ ( zero_zero @ A ) @ M )
= ( zero_zero @ A ) ) ) ) ).
% power_int_0_left
thf(fact_4974_power__int__0__right,axiom,
! [B: $tType] :
( ( ( inverse @ B )
& ( power @ B ) )
=> ! [X: B] :
( ( power_int @ B @ X @ ( zero_zero @ int ) )
= ( one_one @ B ) ) ) ).
% power_int_0_right
thf(fact_4975_abs__power__int__minus,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,N2: int] :
( ( abs_abs @ A @ ( power_int @ A @ ( uminus_uminus @ A @ A3 ) @ N2 ) )
= ( abs_abs @ A @ ( power_int @ A @ A3 @ N2 ) ) ) ) ).
% abs_power_int_minus
thf(fact_4976_power__int__of__nat,axiom,
! [A: $tType] :
( ( ( inverse @ A )
& ( power @ A ) )
=> ! [X: A,N2: nat] :
( ( power_int @ A @ X @ ( semiring_1_of_nat @ int @ N2 ) )
= ( power_power @ A @ X @ N2 ) ) ) ).
% power_int_of_nat
thf(fact_4977_power__int__numeral,axiom,
! [A: $tType] :
( ( ( inverse @ A )
& ( power @ A ) )
=> ! [X: A,N2: num] :
( ( power_int @ A @ X @ ( numeral_numeral @ int @ N2 ) )
= ( power_power @ A @ X @ ( numeral_numeral @ nat @ N2 ) ) ) ) ).
% power_int_numeral
thf(fact_4978_power__int__minus1__right,axiom,
! [A: $tType] :
( ( ( inverse @ A )
& ( monoid_mult @ A ) )
=> ! [Y: A] :
( ( power_int @ A @ Y @ ( uminus_uminus @ int @ ( one_one @ int ) ) )
= ( inverse_inverse @ A @ Y ) ) ) ).
% power_int_minus1_right
thf(fact_4979_power__int__add__numeral2,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,M: num,N2: num,B2: A] :
( ( times_times @ A @ ( power_int @ A @ X @ ( numeral_numeral @ int @ M ) ) @ ( times_times @ A @ ( power_int @ A @ X @ ( numeral_numeral @ int @ N2 ) ) @ B2 ) )
= ( times_times @ A @ ( power_int @ A @ X @ ( numeral_numeral @ int @ ( plus_plus @ num @ M @ N2 ) ) ) @ B2 ) ) ) ).
% power_int_add_numeral2
thf(fact_4980_power__int__add__numeral,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,M: num,N2: num] :
( ( times_times @ A @ ( power_int @ A @ X @ ( numeral_numeral @ int @ M ) ) @ ( power_int @ A @ X @ ( numeral_numeral @ int @ N2 ) ) )
= ( power_int @ A @ X @ ( numeral_numeral @ int @ ( plus_plus @ num @ M @ N2 ) ) ) ) ) ).
% power_int_add_numeral
thf(fact_4981_power__int__mono__iff,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,N2: int] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ B2 )
=> ( ( ord_less @ int @ ( zero_zero @ int ) @ N2 )
=> ( ( ord_less_eq @ A @ ( power_int @ A @ A3 @ N2 ) @ ( power_int @ A @ B2 @ N2 ) )
= ( ord_less_eq @ A @ A3 @ B2 ) ) ) ) ) ) ).
% power_int_mono_iff
thf(fact_4982_power__int__abs,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,N2: int] :
( ( abs_abs @ A @ ( power_int @ A @ A3 @ N2 ) )
= ( power_int @ A @ ( abs_abs @ A @ A3 ) @ N2 ) ) ) ).
% power_int_abs
thf(fact_4983_power__int__mult__distrib,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [X: A,Y: A,M: int] :
( ( power_int @ A @ ( times_times @ A @ X @ Y ) @ M )
= ( times_times @ A @ ( power_int @ A @ X @ M ) @ ( power_int @ A @ Y @ M ) ) ) ) ).
% power_int_mult_distrib
thf(fact_4984_power__int__commutes,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,N2: int] :
( ( times_times @ A @ ( power_int @ A @ X @ N2 ) @ X )
= ( times_times @ A @ X @ ( power_int @ A @ X @ N2 ) ) ) ) ).
% power_int_commutes
thf(fact_4985_power__int__divide__distrib,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [X: A,Y: A,M: int] :
( ( power_int @ A @ ( divide_divide @ A @ X @ Y ) @ M )
= ( divide_divide @ A @ ( power_int @ A @ X @ M ) @ ( power_int @ A @ Y @ M ) ) ) ) ).
% power_int_divide_distrib
thf(fact_4986_power__int__mult,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,M: int,N2: int] :
( ( power_int @ A @ X @ ( times_times @ int @ M @ N2 ) )
= ( power_int @ A @ ( power_int @ A @ X @ M ) @ N2 ) ) ) ).
% power_int_mult
thf(fact_4987_power__int__inverse,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,N2: int] :
( ( power_int @ A @ ( inverse_inverse @ A @ X ) @ N2 )
= ( inverse_inverse @ A @ ( power_int @ A @ X @ N2 ) ) ) ) ).
% power_int_inverse
thf(fact_4988_zero__le__power__int,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,N2: int] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( power_int @ A @ X @ N2 ) ) ) ) ).
% zero_le_power_int
thf(fact_4989_zero__less__power__int,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,N2: int] :
( ( ord_less @ A @ ( zero_zero @ A ) @ X )
=> ( ord_less @ A @ ( zero_zero @ A ) @ ( power_int @ A @ X @ N2 ) ) ) ) ).
% zero_less_power_int
thf(fact_4990_power__int__one__over,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,N2: int] :
( ( power_int @ A @ ( divide_divide @ A @ ( one_one @ A ) @ X ) @ N2 )
= ( divide_divide @ A @ ( one_one @ A ) @ ( power_int @ A @ X @ N2 ) ) ) ) ).
% power_int_one_over
thf(fact_4991_power__int__not__zero,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,N2: int] :
( ( ( X
!= ( zero_zero @ A ) )
| ( N2
= ( zero_zero @ int ) ) )
=> ( ( power_int @ A @ X @ N2 )
!= ( zero_zero @ A ) ) ) ) ).
% power_int_not_zero
thf(fact_4992_power__int__minus,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,N2: int] :
( ( power_int @ A @ X @ ( uminus_uminus @ int @ N2 ) )
= ( inverse_inverse @ A @ ( power_int @ A @ X @ N2 ) ) ) ) ).
% power_int_minus
thf(fact_4993_continuous__on__power__int,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo4958980785337419405_space @ A )
& ( real_V8999393235501362500lgebra @ B ) )
=> ! [S: set @ A,F2: A > B,N2: int] :
( ( topolo81223032696312382ous_on @ A @ B @ S @ F2 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ S )
=> ( ( F2 @ X5 )
!= ( zero_zero @ B ) ) )
=> ( topolo81223032696312382ous_on @ A @ B @ S
@ ^ [X2: A] : ( power_int @ B @ ( F2 @ X2 ) @ N2 ) ) ) ) ) ).
% continuous_on_power_int
thf(fact_4994_power__int__0__left__If,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [M: int] :
( ( ( M
= ( zero_zero @ int ) )
=> ( ( power_int @ A @ ( zero_zero @ A ) @ M )
= ( one_one @ A ) ) )
& ( ( M
!= ( zero_zero @ int ) )
=> ( ( power_int @ A @ ( zero_zero @ A ) @ M )
= ( zero_zero @ A ) ) ) ) ) ).
% power_int_0_left_If
thf(fact_4995_power__int__increasing,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [N2: int,N7: int,A3: A] :
( ( ord_less_eq @ int @ N2 @ N7 )
=> ( ( ord_less_eq @ A @ ( one_one @ A ) @ A3 )
=> ( ord_less_eq @ A @ ( power_int @ A @ A3 @ N2 ) @ ( power_int @ A @ A3 @ N7 ) ) ) ) ) ).
% power_int_increasing
thf(fact_4996_power__int__strict__increasing,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [N2: int,N7: int,A3: A] :
( ( ord_less @ int @ N2 @ N7 )
=> ( ( ord_less @ A @ ( one_one @ A ) @ A3 )
=> ( ord_less @ A @ ( power_int @ A @ A3 @ N2 ) @ ( power_int @ A @ A3 @ N7 ) ) ) ) ) ).
% power_int_strict_increasing
thf(fact_4997_power__int__diff,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [X: A,M: int,N2: int] :
( ( ( X
!= ( zero_zero @ A ) )
| ( M != N2 ) )
=> ( ( power_int @ A @ X @ ( minus_minus @ int @ M @ N2 ) )
= ( divide_divide @ A @ ( power_int @ A @ X @ M ) @ ( power_int @ A @ X @ N2 ) ) ) ) ) ).
% power_int_diff
thf(fact_4998_tendsto__power__int,axiom,
! [A: $tType,B: $tType] :
( ( real_V8999393235501362500lgebra @ A )
=> ! [F2: B > A,A3: A,F5: filter @ B,N2: int] :
( ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ F5 )
=> ( ( A3
!= ( zero_zero @ A ) )
=> ( filterlim @ B @ A
@ ^ [X2: B] : ( power_int @ A @ ( F2 @ X2 ) @ N2 )
@ ( topolo7230453075368039082e_nhds @ A @ ( power_int @ A @ A3 @ N2 ) )
@ F5 ) ) ) ) ).
% tendsto_power_int
thf(fact_4999_power__int__strict__decreasing,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [N2: int,N7: int,A3: A] :
( ( ord_less @ int @ N2 @ N7 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ A @ A3 @ ( one_one @ A ) )
=> ( ord_less @ A @ ( power_int @ A @ A3 @ N7 ) @ ( power_int @ A @ A3 @ N2 ) ) ) ) ) ) ).
% power_int_strict_decreasing
thf(fact_5000_power__int__mono,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,Y: A,N2: int] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ N2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ord_less_eq @ A @ ( power_int @ A @ X @ N2 ) @ ( power_int @ A @ Y @ N2 ) ) ) ) ) ) ).
% power_int_mono
thf(fact_5001_power__int__strict__antimono,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,N2: int] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ int @ N2 @ ( zero_zero @ int ) )
=> ( ord_less @ A @ ( power_int @ A @ B2 @ N2 ) @ ( power_int @ A @ A3 @ N2 ) ) ) ) ) ) ).
% power_int_strict_antimono
thf(fact_5002_one__le__power__int,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,N2: int] :
( ( ord_less_eq @ A @ ( one_one @ A ) @ X )
=> ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ N2 )
=> ( ord_less_eq @ A @ ( one_one @ A ) @ ( power_int @ A @ X @ N2 ) ) ) ) ) ).
% one_le_power_int
thf(fact_5003_one__less__power__int,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,N2: int] :
( ( ord_less @ A @ ( one_one @ A ) @ A3 )
=> ( ( ord_less @ int @ ( zero_zero @ int ) @ N2 )
=> ( ord_less @ A @ ( one_one @ A ) @ ( power_int @ A @ A3 @ N2 ) ) ) ) ) ).
% one_less_power_int
thf(fact_5004_power__int__add,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,M: int,N2: int] :
( ( ( X
!= ( zero_zero @ A ) )
| ( ( plus_plus @ int @ M @ N2 )
!= ( zero_zero @ int ) ) )
=> ( ( power_int @ A @ X @ ( plus_plus @ int @ M @ N2 ) )
= ( times_times @ A @ ( power_int @ A @ X @ M ) @ ( power_int @ A @ X @ N2 ) ) ) ) ) ).
% power_int_add
thf(fact_5005_power__int__strict__mono,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,N2: int] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ int @ ( zero_zero @ int ) @ N2 )
=> ( ord_less @ A @ ( power_int @ A @ A3 @ N2 ) @ ( power_int @ A @ B2 @ N2 ) ) ) ) ) ) ).
% power_int_strict_mono
thf(fact_5006_power__int__antimono,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [A3: A,B2: A,N2: int] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less @ int @ N2 @ ( zero_zero @ int ) )
=> ( ord_less_eq @ A @ ( power_int @ A @ B2 @ N2 ) @ ( power_int @ A @ A3 @ N2 ) ) ) ) ) ) ).
% power_int_antimono
thf(fact_5007_power__int__decreasing,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [N2: int,N7: int,A3: A] :
( ( ord_less_eq @ int @ N2 @ N7 )
=> ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
=> ( ( ord_less_eq @ A @ A3 @ ( one_one @ A ) )
=> ( ( ( A3
!= ( zero_zero @ A ) )
| ( N7
!= ( zero_zero @ int ) )
| ( N2
= ( zero_zero @ int ) ) )
=> ( ord_less_eq @ A @ ( power_int @ A @ A3 @ N7 ) @ ( power_int @ A @ A3 @ N2 ) ) ) ) ) ) ) ).
% power_int_decreasing
thf(fact_5008_power__int__le__one,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,N2: int] :
( ( ord_less_eq @ A @ ( zero_zero @ A ) @ X )
=> ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ N2 )
=> ( ( ord_less_eq @ A @ X @ ( one_one @ A ) )
=> ( ord_less_eq @ A @ ( power_int @ A @ X @ N2 ) @ ( one_one @ A ) ) ) ) ) ) ).
% power_int_le_one
thf(fact_5009_power__int__le__imp__le__exp,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,M: int,N2: int] :
( ( ord_less @ A @ ( one_one @ A ) @ X )
=> ( ( ord_less_eq @ A @ ( power_int @ A @ X @ M ) @ ( power_int @ A @ X @ N2 ) )
=> ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ N2 )
=> ( ord_less_eq @ int @ M @ N2 ) ) ) ) ) ).
% power_int_le_imp_le_exp
thf(fact_5010_power__int__le__imp__less__exp,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [X: A,M: int,N2: int] :
( ( ord_less @ A @ ( one_one @ A ) @ X )
=> ( ( ord_less @ A @ ( power_int @ A @ X @ M ) @ ( power_int @ A @ X @ N2 ) )
=> ( ( ord_less_eq @ int @ ( zero_zero @ int ) @ N2 )
=> ( ord_less @ int @ M @ N2 ) ) ) ) ) ).
% power_int_le_imp_less_exp
thf(fact_5011_power__int__minus__mult,axiom,
! [A: $tType] :
( ( field @ A )
=> ! [X: A,N2: int] :
( ( ( X
!= ( zero_zero @ A ) )
| ( N2
!= ( zero_zero @ int ) ) )
=> ( ( times_times @ A @ ( power_int @ A @ X @ ( minus_minus @ int @ N2 @ ( one_one @ int ) ) ) @ X )
= ( power_int @ A @ X @ N2 ) ) ) ) ).
% power_int_minus_mult
thf(fact_5012_power__int__add__1_H,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,M: int] :
( ( ( X
!= ( zero_zero @ A ) )
| ( M
!= ( uminus_uminus @ int @ ( one_one @ int ) ) ) )
=> ( ( power_int @ A @ X @ ( plus_plus @ int @ M @ ( one_one @ int ) ) )
= ( times_times @ A @ X @ ( power_int @ A @ X @ M ) ) ) ) ) ).
% power_int_add_1'
thf(fact_5013_power__int__add__1,axiom,
! [A: $tType] :
( ( division_ring @ A )
=> ! [X: A,M: int] :
( ( ( X
!= ( zero_zero @ A ) )
| ( M
!= ( uminus_uminus @ int @ ( one_one @ int ) ) ) )
=> ( ( power_int @ A @ X @ ( plus_plus @ int @ M @ ( one_one @ int ) ) )
= ( times_times @ A @ ( power_int @ A @ X @ M ) @ X ) ) ) ) ).
% power_int_add_1
thf(fact_5014_power__int__def,axiom,
! [A: $tType] :
( ( ( inverse @ A )
& ( power @ A ) )
=> ( ( power_int @ A )
= ( ^ [X2: A,N: int] : ( if @ A @ ( ord_less_eq @ int @ ( zero_zero @ int ) @ N ) @ ( power_power @ A @ X2 @ ( nat2 @ N ) ) @ ( power_power @ A @ ( inverse_inverse @ A @ X2 ) @ ( nat2 @ ( uminus_uminus @ int @ N ) ) ) ) ) ) ) ).
% power_int_def
thf(fact_5015_power__int__numeral__neg__numeral,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [M: num,N2: num] :
( ( power_int @ A @ ( numeral_numeral @ A @ M ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ N2 ) ) )
= ( inverse_inverse @ A @ ( numeral_numeral @ A @ ( pow @ M @ N2 ) ) ) ) ) ).
% power_int_numeral_neg_numeral
thf(fact_5016_pred__nat__def,axiom,
( pred_nat
= ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [M2: nat,N: nat] :
( N
= ( suc @ M2 ) ) ) ) ) ).
% pred_nat_def
thf(fact_5017_eventually__less__ceiling,axiom,
! [B: $tType,A: $tType] :
( ( ( archim2362893244070406136eiling @ B )
& ( topolo2564578578187576103pology @ B ) )
=> ! [F2: A > B,L: B,F5: filter @ A] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L ) @ F5 )
=> ( ~ ( member2 @ B @ L @ ( ring_1_Ints @ B ) )
=> ( eventually @ A
@ ^ [X2: A] : ( ord_less @ B @ ( F2 @ X2 ) @ ( ring_1_of_int @ B @ ( archimedean_ceiling @ B @ L ) ) )
@ F5 ) ) ) ) ).
% eventually_less_ceiling
thf(fact_5018_Ints__sum,axiom,
! [A: $tType,B: $tType] :
( ( ring_1 @ B )
=> ! [A4: set @ A,F2: A > B] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( member2 @ B @ ( F2 @ X5 ) @ ( ring_1_Ints @ B ) ) )
=> ( member2 @ B @ ( groups7311177749621191930dd_sum @ A @ B @ F2 @ A4 ) @ ( ring_1_Ints @ B ) ) ) ) ).
% Ints_sum
thf(fact_5019_Ints__prod,axiom,
! [A: $tType,B: $tType] :
( ( ( comm_monoid_mult @ B )
& ( ring_1 @ B ) )
=> ! [A4: set @ A,F2: A > B] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( member2 @ B @ ( F2 @ X5 ) @ ( ring_1_Ints @ B ) ) )
=> ( member2 @ B @ ( groups7121269368397514597t_prod @ A @ B @ F2 @ A4 ) @ ( ring_1_Ints @ B ) ) ) ) ).
% Ints_prod
thf(fact_5020_frac__eq__0__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ( archimedean_frac @ A @ X )
= ( zero_zero @ A ) )
= ( member2 @ A @ X @ ( ring_1_Ints @ A ) ) ) ) ).
% frac_eq_0_iff
thf(fact_5021_floor__add2,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,Y: A] :
( ( ( member2 @ A @ X @ ( ring_1_Ints @ A ) )
| ( member2 @ A @ Y @ ( ring_1_Ints @ A ) ) )
=> ( ( archim6421214686448440834_floor @ A @ ( plus_plus @ A @ X @ Y ) )
= ( plus_plus @ int @ ( archim6421214686448440834_floor @ A @ X ) @ ( archim6421214686448440834_floor @ A @ Y ) ) ) ) ) ).
% floor_add2
thf(fact_5022_frac__gt__0__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ ( archimedean_frac @ A @ X ) )
= ( ~ ( member2 @ A @ X @ ( ring_1_Ints @ A ) ) ) ) ) ).
% frac_gt_0_iff
thf(fact_5023_Ints__of__nat,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [N2: nat] : ( member2 @ A @ ( semiring_1_of_nat @ A @ N2 ) @ ( ring_1_Ints @ A ) ) ) ).
% Ints_of_nat
thf(fact_5024_Ints__abs,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( member2 @ A @ A3 @ ( ring_1_Ints @ A ) )
=> ( member2 @ A @ ( abs_abs @ A @ A3 ) @ ( ring_1_Ints @ A ) ) ) ) ).
% Ints_abs
thf(fact_5025_Ints__0,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( member2 @ A @ ( zero_zero @ A ) @ ( ring_1_Ints @ A ) ) ) ).
% Ints_0
thf(fact_5026_Ints__numeral,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [N2: num] : ( member2 @ A @ ( numeral_numeral @ A @ N2 ) @ ( ring_1_Ints @ A ) ) ) ).
% Ints_numeral
thf(fact_5027_Ints__mult,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [A3: A,B2: A] :
( ( member2 @ A @ A3 @ ( ring_1_Ints @ A ) )
=> ( ( member2 @ A @ B2 @ ( ring_1_Ints @ A ) )
=> ( member2 @ A @ ( times_times @ A @ A3 @ B2 ) @ ( ring_1_Ints @ A ) ) ) ) ) ).
% Ints_mult
thf(fact_5028_Ints__1,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( member2 @ A @ ( one_one @ A ) @ ( ring_1_Ints @ A ) ) ) ).
% Ints_1
thf(fact_5029_Ints__add,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [A3: A,B2: A] :
( ( member2 @ A @ A3 @ ( ring_1_Ints @ A ) )
=> ( ( member2 @ A @ B2 @ ( ring_1_Ints @ A ) )
=> ( member2 @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( ring_1_Ints @ A ) ) ) ) ) ).
% Ints_add
thf(fact_5030_Ints__diff,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [A3: A,B2: A] :
( ( member2 @ A @ A3 @ ( ring_1_Ints @ A ) )
=> ( ( member2 @ A @ B2 @ ( ring_1_Ints @ A ) )
=> ( member2 @ A @ ( minus_minus @ A @ A3 @ B2 ) @ ( ring_1_Ints @ A ) ) ) ) ) ).
% Ints_diff
thf(fact_5031_Ints__minus,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [A3: A] :
( ( member2 @ A @ A3 @ ( ring_1_Ints @ A ) )
=> ( member2 @ A @ ( uminus_uminus @ A @ A3 ) @ ( ring_1_Ints @ A ) ) ) ) ).
% Ints_minus
thf(fact_5032_minus__in__Ints__iff,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [X: A] :
( ( member2 @ A @ ( uminus_uminus @ A @ X ) @ ( ring_1_Ints @ A ) )
= ( member2 @ A @ X @ ( ring_1_Ints @ A ) ) ) ) ).
% minus_in_Ints_iff
thf(fact_5033_Ints__power,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [A3: A,N2: nat] :
( ( member2 @ A @ A3 @ ( ring_1_Ints @ A ) )
=> ( member2 @ A @ ( power_power @ A @ A3 @ N2 ) @ ( ring_1_Ints @ A ) ) ) ) ).
% Ints_power
thf(fact_5034_Ints__cases,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [Q2: A] :
( ( member2 @ A @ Q2 @ ( ring_1_Ints @ A ) )
=> ~ ! [Z2: int] :
( Q2
!= ( ring_1_of_int @ A @ Z2 ) ) ) ) ).
% Ints_cases
thf(fact_5035_Ints__induct,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [Q2: A,P2: A > $o] :
( ( member2 @ A @ Q2 @ ( ring_1_Ints @ A ) )
=> ( ! [Z2: int] : ( P2 @ ( ring_1_of_int @ A @ Z2 ) )
=> ( P2 @ Q2 ) ) ) ) ).
% Ints_induct
thf(fact_5036_Ints__of__int,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ! [Z: int] : ( member2 @ A @ ( ring_1_of_int @ A @ Z ) @ ( ring_1_Ints @ A ) ) ) ).
% Ints_of_int
thf(fact_5037_Ints__double__eq__0__iff,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [A3: A] :
( ( member2 @ A @ A3 @ ( ring_1_Ints @ A ) )
=> ( ( ( plus_plus @ A @ A3 @ A3 )
= ( zero_zero @ A ) )
= ( A3
= ( zero_zero @ A ) ) ) ) ) ).
% Ints_double_eq_0_iff
thf(fact_5038_Nats__subset__Ints,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( ord_less_eq @ ( set @ A ) @ ( semiring_1_Nats @ A ) @ ( ring_1_Ints @ A ) ) ) ).
% Nats_subset_Ints
thf(fact_5039_finite__int__segment,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [A3: A,B2: A] :
( finite_finite @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ ( ring_1_Ints @ A ) )
& ( ord_less_eq @ A @ A3 @ X2 )
& ( ord_less_eq @ A @ X2 @ B2 ) ) ) ) ) ).
% finite_int_segment
thf(fact_5040_Ints__odd__nonzero,axiom,
! [A: $tType] :
( ( ring_char_0 @ A )
=> ! [A3: A] :
( ( member2 @ A @ A3 @ ( ring_1_Ints @ A ) )
=> ( ( plus_plus @ A @ ( plus_plus @ A @ ( one_one @ A ) @ A3 ) @ A3 )
!= ( zero_zero @ A ) ) ) ) ).
% Ints_odd_nonzero
thf(fact_5041_of__int__divide__in__Ints,axiom,
! [A: $tType] :
( ( idom_divide @ A )
=> ! [B2: int,A3: int] :
( ( dvd_dvd @ int @ B2 @ A3 )
=> ( member2 @ A @ ( divide_divide @ A @ ( ring_1_of_int @ A @ A3 ) @ ( ring_1_of_int @ A @ B2 ) ) @ ( ring_1_Ints @ A ) ) ) ) ).
% of_int_divide_in_Ints
thf(fact_5042_finite__abs__int__segment,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [A3: A] :
( finite_finite @ A
@ ( collect @ A
@ ^ [K2: A] :
( ( member2 @ A @ K2 @ ( ring_1_Ints @ A ) )
& ( ord_less_eq @ A @ ( abs_abs @ A @ K2 ) @ A3 ) ) ) ) ) ).
% finite_abs_int_segment
thf(fact_5043_Nats__altdef2,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ( ( semiring_1_Nats @ A )
= ( collect @ A
@ ^ [N: A] :
( ( member2 @ A @ N @ ( ring_1_Ints @ A ) )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ N ) ) ) ) ) ).
% Nats_altdef2
thf(fact_5044_Ints__def,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( ( ring_1_Ints @ A )
= ( image2 @ int @ A @ ( ring_1_of_int @ A ) @ ( top_top @ ( set @ int ) ) ) ) ) ).
% Ints_def
thf(fact_5045_Ints__odd__less__0,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [A3: A] :
( ( member2 @ A @ A3 @ ( ring_1_Ints @ A ) )
=> ( ( ord_less @ A @ ( plus_plus @ A @ ( plus_plus @ A @ ( one_one @ A ) @ A3 ) @ A3 ) @ ( zero_zero @ A ) )
= ( ord_less @ A @ A3 @ ( zero_zero @ A ) ) ) ) ) ).
% Ints_odd_less_0
thf(fact_5046_Ints__nonzero__abs__ge1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A] :
( ( member2 @ A @ X @ ( ring_1_Ints @ A ) )
=> ( ( X
!= ( zero_zero @ A ) )
=> ( ord_less_eq @ A @ ( one_one @ A ) @ ( abs_abs @ A @ X ) ) ) ) ) ).
% Ints_nonzero_abs_ge1
thf(fact_5047_Ints__nonzero__abs__less1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A] :
( ( member2 @ A @ X @ ( ring_1_Ints @ A ) )
=> ( ( ord_less @ A @ ( abs_abs @ A @ X ) @ ( one_one @ A ) )
=> ( X
= ( zero_zero @ A ) ) ) ) ) ).
% Ints_nonzero_abs_less1
thf(fact_5048_Ints__eq__abs__less1,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: A,Y: A] :
( ( member2 @ A @ X @ ( ring_1_Ints @ A ) )
=> ( ( member2 @ A @ Y @ ( ring_1_Ints @ A ) )
=> ( ( X = Y )
= ( ord_less @ A @ ( abs_abs @ A @ ( minus_minus @ A @ X @ Y ) ) @ ( one_one @ A ) ) ) ) ) ) ).
% Ints_eq_abs_less1
thf(fact_5049_frac__neg,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A] :
( ( ( member2 @ A @ X @ ( ring_1_Ints @ A ) )
=> ( ( archimedean_frac @ A @ ( uminus_uminus @ A @ X ) )
= ( zero_zero @ A ) ) )
& ( ~ ( member2 @ A @ X @ ( ring_1_Ints @ A ) )
=> ( ( archimedean_frac @ A @ ( uminus_uminus @ A @ X ) )
= ( minus_minus @ A @ ( one_one @ A ) @ ( archimedean_frac @ A @ X ) ) ) ) ) ) ).
% frac_neg
thf(fact_5050_le__mult__floor__Ints,axiom,
! [A: $tType,B: $tType] :
( ( ( archim2362893244070406136eiling @ B )
& ( linordered_idom @ A ) )
=> ! [A3: B,B2: B] :
( ( ord_less_eq @ B @ ( zero_zero @ B ) @ A3 )
=> ( ( member2 @ B @ A3 @ ( ring_1_Ints @ B ) )
=> ( ord_less_eq @ A @ ( ring_1_of_int @ A @ ( times_times @ int @ ( archim6421214686448440834_floor @ B @ A3 ) @ ( archim6421214686448440834_floor @ B @ B2 ) ) ) @ ( ring_1_of_int @ A @ ( archim6421214686448440834_floor @ B @ ( times_times @ B @ A3 @ B2 ) ) ) ) ) ) ) ).
% le_mult_floor_Ints
thf(fact_5051_frac__unique__iff,axiom,
! [A: $tType] :
( ( archim2362893244070406136eiling @ A )
=> ! [X: A,A3: A] :
( ( ( archimedean_frac @ A @ X )
= A3 )
= ( ( member2 @ A @ ( minus_minus @ A @ X @ A3 ) @ ( ring_1_Ints @ A ) )
& ( ord_less_eq @ A @ ( zero_zero @ A ) @ A3 )
& ( ord_less @ A @ A3 @ ( one_one @ A ) ) ) ) ) ).
% frac_unique_iff
thf(fact_5052_mult__ceiling__le__Ints,axiom,
! [A: $tType,B: $tType] :
( ( ( archim2362893244070406136eiling @ B )
& ( linordered_idom @ A ) )
=> ! [A3: B,B2: B] :
( ( ord_less_eq @ B @ ( zero_zero @ B ) @ A3 )
=> ( ( member2 @ B @ A3 @ ( ring_1_Ints @ B ) )
=> ( ord_less_eq @ A @ ( ring_1_of_int @ A @ ( archimedean_ceiling @ B @ ( times_times @ B @ A3 @ B2 ) ) ) @ ( ring_1_of_int @ A @ ( times_times @ int @ ( archimedean_ceiling @ B @ A3 ) @ ( archimedean_ceiling @ B @ B2 ) ) ) ) ) ) ) ).
% mult_ceiling_le_Ints
thf(fact_5053_eventually__floor__less,axiom,
! [B: $tType,A: $tType] :
( ( ( archim2362893244070406136eiling @ B )
& ( topolo2564578578187576103pology @ B ) )
=> ! [F2: A > B,L: B,F5: filter @ A] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L ) @ F5 )
=> ( ~ ( member2 @ B @ L @ ( ring_1_Ints @ B ) )
=> ( eventually @ A
@ ^ [X2: A] : ( ord_less @ B @ ( ring_1_of_int @ B @ ( archim6421214686448440834_floor @ B @ L ) ) @ ( F2 @ X2 ) )
@ F5 ) ) ) ) ).
% eventually_floor_less
thf(fact_5054_lenlex__conv,axiom,
! [A: $tType] :
( ( lenlex @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
( collect @ ( product_prod @ ( list @ A ) @ ( list @ A ) )
@ ( product_case_prod @ ( list @ A ) @ ( list @ A ) @ $o
@ ^ [Xs2: list @ A,Ys3: list @ A] :
( ( ord_less @ nat @ ( size_size @ ( list @ A ) @ Xs2 ) @ ( size_size @ ( list @ A ) @ Ys3 ) )
| ( ( ( size_size @ ( list @ A ) @ Xs2 )
= ( size_size @ ( list @ A ) @ Ys3 ) )
& ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs2 @ Ys3 ) @ ( lex @ A @ R4 ) ) ) ) ) ) ) ) ).
% lenlex_conv
thf(fact_5055_VEBT__internal_Ovalid_H_Oelims_I3_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ~ ( vEBT_VEBT_valid @ X @ Xa2 )
=> ( ( ? [Uu2: $o,Uv2: $o] :
( X
= ( vEBT_Leaf @ Uu2 @ Uv2 ) )
=> ( Xa2
= ( one_one @ nat ) ) )
=> ~ ! [Mima: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Mima @ Deg2 @ TreeList3 @ Summary2 ) )
=> ( ( Deg2 = Xa2 )
& ! [X5: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X5 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ( vEBT_VEBT_valid @ X5 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( vEBT_VEBT_valid @ Summary2 @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( case_option @ $o @ ( product_prod @ nat @ nat )
@ ( ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ Summary2 @ X8 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [Mi3: nat,Ma3: nat] :
( ( ord_less_eq @ nat @ Mi3 @ Ma3 )
& ( ord_less @ nat @ Ma3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I5 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary2 @ I5 ) ) )
& ( ( Mi3 = Ma3 )
=> ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
& ( ( Mi3 != Ma3 )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ Ma3 )
& ! [X2: nat] :
( ( ord_less @ nat @ X2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ X2 )
=> ( ( ord_less @ nat @ Mi3 @ X2 )
& ( ord_less_eq @ nat @ X2 @ Ma3 ) ) ) ) ) ) ) )
@ Mima ) ) ) ) ) ).
% VEBT_internal.valid'.elims(3)
thf(fact_5056_VEBT__internal_Ovalid_H_Oelims_I2_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ( vEBT_VEBT_valid @ X @ Xa2 )
=> ( ( ? [Uu2: $o,Uv2: $o] :
( X
= ( vEBT_Leaf @ Uu2 @ Uv2 ) )
=> ( Xa2
!= ( one_one @ nat ) ) )
=> ~ ! [Mima: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Mima @ Deg2 @ TreeList3 @ Summary2 ) )
=> ~ ( ( Deg2 = Xa2 )
& ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ( vEBT_VEBT_valid @ X3 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( vEBT_VEBT_valid @ Summary2 @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( case_option @ $o @ ( product_prod @ nat @ nat )
@ ( ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ Summary2 @ X8 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [Mi3: nat,Ma3: nat] :
( ( ord_less_eq @ nat @ Mi3 @ Ma3 )
& ( ord_less @ nat @ Ma3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I5 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary2 @ I5 ) ) )
& ( ( Mi3 = Ma3 )
=> ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
& ( ( Mi3 != Ma3 )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ Ma3 )
& ! [X2: nat] :
( ( ord_less @ nat @ X2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ X2 )
=> ( ( ord_less @ nat @ Mi3 @ X2 )
& ( ord_less_eq @ nat @ X2 @ Ma3 ) ) ) ) ) ) ) )
@ Mima ) ) ) ) ) ).
% VEBT_internal.valid'.elims(2)
thf(fact_5057_ball__empty,axiom,
! [A: $tType,P2: A > $o,X3: A] :
( ( member2 @ A @ X3 @ ( bot_bot @ ( set @ A ) ) )
=> ( P2 @ X3 ) ) ).
% ball_empty
thf(fact_5058_Nil__lenlex__iff1,axiom,
! [A: $tType,Ns: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Ns ) @ ( lenlex @ A @ R2 ) )
= ( Ns
!= ( nil @ A ) ) ) ).
% Nil_lenlex_iff1
thf(fact_5059_option_Osimps_I5_J,axiom,
! [B: $tType,A: $tType,F1: B,F22: A > B,X22: A] :
( ( case_option @ B @ A @ F1 @ F22 @ ( some @ A @ X22 ) )
= ( F22 @ X22 ) ) ).
% option.simps(5)
thf(fact_5060_Ball__Collect,axiom,
! [A: $tType] :
( ( ball @ A )
= ( ^ [A6: set @ A,P: A > $o] : ( ord_less_eq @ ( set @ A ) @ A6 @ ( collect @ A @ P ) ) ) ) ).
% Ball_Collect
thf(fact_5061_open__diagonal__complement,axiom,
! [A: $tType] :
( ( topological_t2_space @ A )
=> ( topolo1002775350975398744n_open @ ( product_prod @ A @ A )
@ ( collect @ ( product_prod @ A @ A )
@ ^ [Uu3: product_prod @ A @ A] :
? [X2: A,Y2: A] :
( ( Uu3
= ( product_Pair @ A @ A @ X2 @ Y2 ) )
& ( X2 != Y2 ) ) ) ) ) ).
% open_diagonal_complement
thf(fact_5062_finite_Omono,axiom,
! [A: $tType] :
( order_mono @ ( ( set @ A ) > $o ) @ ( ( set @ A ) > $o )
@ ^ [P6: ( set @ A ) > $o,X2: set @ A] :
( ( X2
= ( bot_bot @ ( set @ A ) ) )
| ? [A6: set @ A,A5: A] :
( ( X2
= ( insert2 @ A @ A5 @ A6 ) )
& ( P6 @ A6 ) ) ) ) ).
% finite.mono
thf(fact_5063_closed__diagonal,axiom,
! [A: $tType] :
( ( topological_t2_space @ A )
=> ( topolo7761053866217962861closed @ ( product_prod @ A @ A )
@ ( collect @ ( product_prod @ A @ A )
@ ^ [Y2: product_prod @ A @ A] :
? [X2: A] :
( Y2
= ( product_Pair @ A @ A @ X2 @ X2 ) ) ) ) ) ).
% closed_diagonal
thf(fact_5064_closed__subdiagonal,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ( topolo7761053866217962861closed @ ( product_prod @ A @ A )
@ ( collect @ ( product_prod @ A @ A )
@ ^ [Uu3: product_prod @ A @ A] :
? [X2: A,Y2: A] :
( ( Uu3
= ( product_Pair @ A @ A @ X2 @ Y2 ) )
& ( ord_less_eq @ A @ X2 @ Y2 ) ) ) ) ) ).
% closed_subdiagonal
thf(fact_5065_closed__superdiagonal,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ( topolo7761053866217962861closed @ ( product_prod @ A @ A )
@ ( collect @ ( product_prod @ A @ A )
@ ^ [Uu3: product_prod @ A @ A] :
? [X2: A,Y2: A] :
( ( Uu3
= ( product_Pair @ A @ A @ X2 @ Y2 ) )
& ( ord_less_eq @ A @ Y2 @ X2 ) ) ) ) ) ).
% closed_superdiagonal
thf(fact_5066_open__superdiagonal,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ( topolo1002775350975398744n_open @ ( product_prod @ A @ A )
@ ( collect @ ( product_prod @ A @ A )
@ ^ [Uu3: product_prod @ A @ A] :
? [X2: A,Y2: A] :
( ( Uu3
= ( product_Pair @ A @ A @ X2 @ Y2 ) )
& ( ord_less @ A @ Y2 @ X2 ) ) ) ) ) ).
% open_superdiagonal
thf(fact_5067_open__subdiagonal,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ( topolo1002775350975398744n_open @ ( product_prod @ A @ A )
@ ( collect @ ( product_prod @ A @ A )
@ ^ [Uu3: product_prod @ A @ A] :
? [X2: A,Y2: A] :
( ( Uu3
= ( product_Pair @ A @ A @ X2 @ Y2 ) )
& ( ord_less @ A @ X2 @ Y2 ) ) ) ) ) ).
% open_subdiagonal
thf(fact_5068_lenlex__irreflexive,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),Xs: list @ A] :
( ! [X5: A] :
~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ X5 ) @ R2 )
=> ~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Xs ) @ ( lenlex @ A @ R2 ) ) ) ).
% lenlex_irreflexive
thf(fact_5069_Nil__lenlex__iff2,axiom,
! [A: $tType,Ns: list @ A,R2: set @ ( product_prod @ A @ A )] :
~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Ns @ ( nil @ A ) ) @ ( lenlex @ A @ R2 ) ) ).
% Nil_lenlex_iff2
thf(fact_5070_case__optionE,axiom,
! [A: $tType,P2: $o,Q: A > $o,X: option @ A] :
( ( case_option @ $o @ A @ P2 @ Q @ X )
=> ( ( ( X
= ( none @ A ) )
=> ~ P2 )
=> ~ ! [Y4: A] :
( ( X
= ( some @ A @ Y4 ) )
=> ~ ( Q @ Y4 ) ) ) ) ).
% case_optionE
thf(fact_5071_Sup__eq__Inf,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ( ( complete_Sup_Sup @ A )
= ( ^ [A6: set @ A] :
( complete_Inf_Inf @ A
@ ( collect @ A
@ ^ [B4: A] :
! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( ord_less_eq @ A @ X2 @ B4 ) ) ) ) ) ) ) ).
% Sup_eq_Inf
thf(fact_5072_Inf__eq__Sup,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ( ( complete_Inf_Inf @ A )
= ( ^ [A6: set @ A] :
( complete_Sup_Sup @ A
@ ( collect @ A
@ ^ [B4: A] :
! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( ord_less_eq @ A @ B4 @ X2 ) ) ) ) ) ) ) ).
% Inf_eq_Sup
thf(fact_5073_set__conv__nth,axiom,
! [A: $tType] :
( ( set2 @ A )
= ( ^ [Xs2: list @ A] :
( collect @ A
@ ^ [Uu3: A] :
? [I5: nat] :
( ( Uu3
= ( nth @ A @ Xs2 @ I5 ) )
& ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs2 ) ) ) ) ) ) ).
% set_conv_nth
thf(fact_5074_lenlex__length,axiom,
! [A: $tType,Ms: list @ A,Ns: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Ms @ Ns ) @ ( lenlex @ A @ R2 ) )
=> ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Ms ) @ ( size_size @ ( list @ A ) @ Ns ) ) ) ).
% lenlex_length
thf(fact_5075_VEBT__internal_Ovalid_H_Osimps_I2_J,axiom,
! [Mima2: option @ ( product_prod @ nat @ nat ),Deg: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,Deg4: nat] :
( ( vEBT_VEBT_valid @ ( vEBT_Node @ Mima2 @ Deg @ TreeList2 @ Summary ) @ Deg4 )
= ( ( Deg = Deg4 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ( vEBT_VEBT_valid @ X2 @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( vEBT_VEBT_valid @ Summary @ ( minus_minus @ nat @ Deg @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList2 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( case_option @ $o @ ( product_prod @ nat @ nat )
@ ( ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ Summary @ X8 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [Mi3: nat,Ma3: nat] :
( ( ord_less_eq @ nat @ Mi3 @ Ma3 )
& ( ord_less @ nat @ Ma3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList2 @ I5 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary @ I5 ) ) )
& ( ( Mi3 = Ma3 )
=> ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList2 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
& ( ( Mi3 != Ma3 )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList2 @ Ma3 )
& ! [X2: nat] :
( ( ord_less @ nat @ X2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg ) )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList2 @ X2 )
=> ( ( ord_less @ nat @ Mi3 @ X2 )
& ( ord_less_eq @ nat @ X2 @ Ma3 ) ) ) ) ) ) ) )
@ Mima2 ) ) ) ).
% VEBT_internal.valid'.simps(2)
thf(fact_5076_funpow__inj__finite,axiom,
! [A: $tType,P4: A > A,X: A] :
( ( inj_on @ A @ A @ P4 @ ( top_top @ ( set @ A ) ) )
=> ( ( finite_finite @ A
@ ( collect @ A
@ ^ [Y2: A] :
? [N: nat] :
( Y2
= ( compow @ ( A > A ) @ N @ P4 @ X ) ) ) )
=> ~ ! [N3: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N3 )
=> ( ( compow @ ( A > A ) @ N3 @ P4 @ X )
!= X ) ) ) ) ).
% funpow_inj_finite
thf(fact_5077_VEBT__internal_Ovalid_H_Oelims_I1_J,axiom,
! [X: vEBT_VEBT,Xa2: nat,Y: $o] :
( ( ( vEBT_VEBT_valid @ X @ Xa2 )
= Y )
=> ( ( ? [Uu2: $o,Uv2: $o] :
( X
= ( vEBT_Leaf @ Uu2 @ Uv2 ) )
=> ( Y
= ( Xa2
!= ( one_one @ nat ) ) ) )
=> ~ ! [Mima: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Mima @ Deg2 @ TreeList3 @ Summary2 ) )
=> ( Y
= ( ~ ( ( Deg2 = Xa2 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ( vEBT_VEBT_valid @ X2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( vEBT_VEBT_valid @ Summary2 @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( case_option @ $o @ ( product_prod @ nat @ nat )
@ ( ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ Summary2 @ X8 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [Mi3: nat,Ma3: nat] :
( ( ord_less_eq @ nat @ Mi3 @ Ma3 )
& ( ord_less @ nat @ Ma3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I5 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary2 @ I5 ) ) )
& ( ( Mi3 = Ma3 )
=> ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
& ( ( Mi3 != Ma3 )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ Ma3 )
& ! [X2: nat] :
( ( ord_less @ nat @ X2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ X2 )
=> ( ( ord_less @ nat @ Mi3 @ X2 )
& ( ord_less_eq @ nat @ X2 @ Ma3 ) ) ) ) ) ) ) )
@ Mima ) ) ) ) ) ) ) ).
% VEBT_internal.valid'.elims(1)
thf(fact_5078_VEBT__internal_Ovalid_H_Opelims_I1_J,axiom,
! [X: vEBT_VEBT,Xa2: nat,Y: $o] :
( ( ( vEBT_VEBT_valid @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_VEBT_valid_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [Uu2: $o,Uv2: $o] :
( ( X
= ( vEBT_Leaf @ Uu2 @ Uv2 ) )
=> ( ( Y
= ( Xa2
= ( one_one @ nat ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_VEBT_valid_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ Uu2 @ Uv2 ) @ Xa2 ) ) ) )
=> ~ ! [Mima: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Mima @ Deg2 @ TreeList3 @ Summary2 ) )
=> ( ( Y
= ( ( Deg2 = Xa2 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ( vEBT_VEBT_valid @ X2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( vEBT_VEBT_valid @ Summary2 @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( case_option @ $o @ ( product_prod @ nat @ nat )
@ ( ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ Summary2 @ X8 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [Mi3: nat,Ma3: nat] :
( ( ord_less_eq @ nat @ Mi3 @ Ma3 )
& ( ord_less @ nat @ Ma3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I5 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary2 @ I5 ) ) )
& ( ( Mi3 = Ma3 )
=> ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
& ( ( Mi3 != Ma3 )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ Ma3 )
& ! [X2: nat] :
( ( ord_less @ nat @ X2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ X2 )
=> ( ( ord_less @ nat @ Mi3 @ X2 )
& ( ord_less_eq @ nat @ X2 @ Ma3 ) ) ) ) ) ) ) )
@ Mima ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_VEBT_valid_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Mima @ Deg2 @ TreeList3 @ Summary2 ) @ Xa2 ) ) ) ) ) ) ) ).
% VEBT_internal.valid'.pelims(1)
thf(fact_5079_VEBT__internal_Ovalid_H_Opelims_I2_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ( vEBT_VEBT_valid @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_VEBT_valid_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [Uu2: $o,Uv2: $o] :
( ( X
= ( vEBT_Leaf @ Uu2 @ Uv2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_VEBT_valid_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ Uu2 @ Uv2 ) @ Xa2 ) )
=> ( Xa2
!= ( one_one @ nat ) ) ) )
=> ~ ! [Mima: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Mima @ Deg2 @ TreeList3 @ Summary2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_VEBT_valid_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Mima @ Deg2 @ TreeList3 @ Summary2 ) @ Xa2 ) )
=> ~ ( ( Deg2 = Xa2 )
& ! [X3: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X3 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ( vEBT_VEBT_valid @ X3 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( vEBT_VEBT_valid @ Summary2 @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( case_option @ $o @ ( product_prod @ nat @ nat )
@ ( ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ Summary2 @ X8 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [Mi3: nat,Ma3: nat] :
( ( ord_less_eq @ nat @ Mi3 @ Ma3 )
& ( ord_less @ nat @ Ma3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I5 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary2 @ I5 ) ) )
& ( ( Mi3 = Ma3 )
=> ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
& ( ( Mi3 != Ma3 )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ Ma3 )
& ! [X2: nat] :
( ( ord_less @ nat @ X2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ X2 )
=> ( ( ord_less @ nat @ Mi3 @ X2 )
& ( ord_less_eq @ nat @ X2 @ Ma3 ) ) ) ) ) ) ) )
@ Mima ) ) ) ) ) ) ) ).
% VEBT_internal.valid'.pelims(2)
thf(fact_5080_VEBT__internal_Ovalid_H_Opelims_I3_J,axiom,
! [X: vEBT_VEBT,Xa2: nat] :
( ~ ( vEBT_VEBT_valid @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_VEBT_valid_rel @ ( product_Pair @ vEBT_VEBT @ nat @ X @ Xa2 ) )
=> ( ! [Uu2: $o,Uv2: $o] :
( ( X
= ( vEBT_Leaf @ Uu2 @ Uv2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_VEBT_valid_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Leaf @ Uu2 @ Uv2 ) @ Xa2 ) )
=> ( Xa2
= ( one_one @ nat ) ) ) )
=> ~ ! [Mima: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Mima @ Deg2 @ TreeList3 @ Summary2 ) )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ nat ) @ vEBT_VEBT_valid_rel @ ( product_Pair @ vEBT_VEBT @ nat @ ( vEBT_Node @ Mima @ Deg2 @ TreeList3 @ Summary2 ) @ Xa2 ) )
=> ( ( Deg2 = Xa2 )
& ! [X5: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X5 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ( vEBT_VEBT_valid @ X5 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( vEBT_VEBT_valid @ Summary2 @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
& ( ( size_size @ ( list @ vEBT_VEBT ) @ TreeList3 )
= ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
& ( case_option @ $o @ ( product_prod @ nat @ nat )
@ ( ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ Summary2 @ X8 )
& ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [Mi3: nat,Ma3: nat] :
( ( ord_less_eq @ nat @ Mi3 @ Ma3 )
& ( ord_less @ nat @ Ma3 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ Deg2 @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
=> ( ( ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ TreeList3 @ I5 ) @ X8 ) )
= ( vEBT_V8194947554948674370ptions @ Summary2 @ I5 ) ) )
& ( ( Mi3 = Ma3 )
=> ! [X2: vEBT_VEBT] :
( ( member2 @ vEBT_VEBT @ X2 @ ( set2 @ vEBT_VEBT @ TreeList3 ) )
=> ~ ? [X8: nat] : ( vEBT_V8194947554948674370ptions @ X2 @ X8 ) ) )
& ( ( Mi3 != Ma3 )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ Ma3 )
& ! [X2: nat] :
( ( ord_less @ nat @ X2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ Deg2 ) )
=> ( ( vEBT_V5917875025757280293ildren @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) @ TreeList3 @ X2 )
=> ( ( ord_less @ nat @ Mi3 @ X2 )
& ( ord_less_eq @ nat @ X2 @ Ma3 ) ) ) ) ) ) ) )
@ Mima ) ) ) ) ) ) ) ).
% VEBT_internal.valid'.pelims(3)
thf(fact_5081_finite__Inf__Sup,axiom,
! [A: $tType] :
( ( finite8700451911770168679attice @ A )
=> ! [A4: set @ ( set @ A )] :
( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ ( set @ A ) @ A @ ( complete_Sup_Sup @ A ) @ A4 ) )
@ ( complete_Sup_Sup @ A
@ ( image2 @ ( set @ A ) @ A @ ( complete_Inf_Inf @ A )
@ ( collect @ ( set @ A )
@ ^ [Uu3: set @ A] :
? [F3: ( set @ A ) > A] :
( ( Uu3
= ( image2 @ ( set @ A ) @ A @ F3 @ A4 ) )
& ! [X2: set @ A] :
( ( member2 @ ( set @ A ) @ X2 @ A4 )
=> ( member2 @ A @ ( F3 @ X2 ) @ X2 ) ) ) ) ) ) ) ) ).
% finite_Inf_Sup
thf(fact_5082_Inf__Sup__le,axiom,
! [A: $tType] :
( ( comple592849572758109894attice @ A )
=> ! [A4: set @ ( set @ A )] :
( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ ( set @ A ) @ A @ ( complete_Sup_Sup @ A ) @ A4 ) )
@ ( complete_Sup_Sup @ A
@ ( image2 @ ( set @ A ) @ A @ ( complete_Inf_Inf @ A )
@ ( collect @ ( set @ A )
@ ^ [Uu3: set @ A] :
? [F3: ( set @ A ) > A] :
( ( Uu3
= ( image2 @ ( set @ A ) @ A @ F3 @ A4 ) )
& ! [X2: set @ A] :
( ( member2 @ ( set @ A ) @ X2 @ A4 )
=> ( member2 @ A @ ( F3 @ X2 ) @ X2 ) ) ) ) ) ) ) ) ).
% Inf_Sup_le
thf(fact_5083_Sup__Inf__le,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ ( set @ A )] :
( ord_less_eq @ A
@ ( complete_Sup_Sup @ A
@ ( image2 @ ( set @ A ) @ A @ ( complete_Inf_Inf @ A )
@ ( collect @ ( set @ A )
@ ^ [Uu3: set @ A] :
? [F3: ( set @ A ) > A] :
( ( Uu3
= ( image2 @ ( set @ A ) @ A @ F3 @ A4 ) )
& ! [X2: set @ A] :
( ( member2 @ ( set @ A ) @ X2 @ A4 )
=> ( member2 @ A @ ( F3 @ X2 ) @ X2 ) ) ) ) ) )
@ ( complete_Inf_Inf @ A @ ( image2 @ ( set @ A ) @ A @ ( complete_Sup_Sup @ A ) @ A4 ) ) ) ) ).
% Sup_Inf_le
thf(fact_5084_Nats__altdef1,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( ( semiring_1_Nats @ A )
= ( collect @ A
@ ^ [Uu3: A] :
? [N: int] :
( ( Uu3
= ( ring_1_of_int @ A @ N ) )
& ( ord_less_eq @ int @ ( zero_zero @ int ) @ N ) ) ) ) ) ).
% Nats_altdef1
thf(fact_5085_list__eq__iff__zip__eq,axiom,
! [A: $tType] :
( ( ^ [Y5: list @ A,Z3: list @ A] : ( Y5 = Z3 ) )
= ( ^ [Xs2: list @ A,Ys3: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs2 )
= ( size_size @ ( list @ A ) @ Ys3 ) )
& ! [X2: product_prod @ A @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ X2 @ ( set2 @ ( product_prod @ A @ A ) @ ( zip @ A @ A @ Xs2 @ Ys3 ) ) )
=> ( product_case_prod @ A @ A @ $o
@ ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ X2 ) ) ) ) ) ).
% list_eq_iff_zip_eq
thf(fact_5086_concat__eq__concat__iff,axiom,
! [A: $tType,Xs: list @ ( list @ A ),Ys: list @ ( list @ A )] :
( ! [X5: product_prod @ ( list @ A ) @ ( list @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ X5 @ ( set2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( zip @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) ) )
=> ( product_case_prod @ ( list @ A ) @ ( list @ A ) @ $o
@ ^ [Y2: list @ A,Z6: list @ A] :
( ( size_size @ ( list @ A ) @ Y2 )
= ( size_size @ ( list @ A ) @ Z6 ) )
@ X5 ) )
=> ( ( ( size_size @ ( list @ ( list @ A ) ) @ Xs )
= ( size_size @ ( list @ ( list @ A ) ) @ Ys ) )
=> ( ( ( concat @ A @ Xs )
= ( concat @ A @ Ys ) )
= ( Xs = Ys ) ) ) ) ).
% concat_eq_concat_iff
thf(fact_5087_concat__injective,axiom,
! [A: $tType,Xs: list @ ( list @ A ),Ys: list @ ( list @ A )] :
( ( ( concat @ A @ Xs )
= ( concat @ A @ Ys ) )
=> ( ( ( size_size @ ( list @ ( list @ A ) ) @ Xs )
= ( size_size @ ( list @ ( list @ A ) ) @ Ys ) )
=> ( ! [X5: product_prod @ ( list @ A ) @ ( list @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ X5 @ ( set2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( zip @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) ) )
=> ( product_case_prod @ ( list @ A ) @ ( list @ A ) @ $o
@ ^ [Y2: list @ A,Z6: list @ A] :
( ( size_size @ ( list @ A ) @ Y2 )
= ( size_size @ ( list @ A ) @ Z6 ) )
@ X5 ) )
=> ( Xs = Ys ) ) ) ) ).
% concat_injective
thf(fact_5088_iteratesp_Omono,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [F2: A > A] :
( order_mono @ ( A > $o ) @ ( A > $o )
@ ^ [P6: A > $o,X2: A] :
( ? [Y2: A] :
( ( X2
= ( F2 @ Y2 ) )
& ( P6 @ Y2 ) )
| ? [M9: set @ A] :
( ( X2
= ( complete_Sup_Sup @ A @ M9 ) )
& ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ M9 )
& ! [Y2: A] :
( ( member2 @ A @ Y2 @ M9 )
=> ( P6 @ Y2 ) ) ) ) ) ) ).
% iteratesp.mono
thf(fact_5089_listrel__iff__zip,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ B,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ Xs @ Ys ) @ ( listrel @ A @ B @ R2 ) )
= ( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
& ! [X2: product_prod @ A @ B] :
( ( member2 @ ( product_prod @ A @ B ) @ X2 @ ( set2 @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) ) )
=> ( product_case_prod @ A @ B @ $o
@ ^ [Y2: A,Z6: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Y2 @ Z6 ) @ R2 )
@ X2 ) ) ) ) ).
% listrel_iff_zip
thf(fact_5090_take__bit__numeral__numeral,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: num,N2: num] :
( ( bit_se2584673776208193580ke_bit @ A @ ( numeral_numeral @ nat @ M ) @ ( numeral_numeral @ A @ N2 ) )
= ( case_option @ A @ num @ ( zero_zero @ A ) @ ( numeral_numeral @ A ) @ ( bit_take_bit_num @ ( numeral_numeral @ nat @ M ) @ N2 ) ) ) ) ).
% take_bit_numeral_numeral
thf(fact_5091_take__bit__num__simps_I1_J,axiom,
! [M: num] :
( ( bit_take_bit_num @ ( zero_zero @ nat ) @ M )
= ( none @ num ) ) ).
% take_bit_num_simps(1)
thf(fact_5092_take__bit__num__simps_I2_J,axiom,
! [N2: nat] :
( ( bit_take_bit_num @ ( suc @ N2 ) @ one2 )
= ( some @ num @ one2 ) ) ).
% take_bit_num_simps(2)
thf(fact_5093_take__bit__num__simps_I3_J,axiom,
! [N2: nat,M: num] :
( ( bit_take_bit_num @ ( suc @ N2 ) @ ( bit0 @ M ) )
= ( case_option @ ( option @ num ) @ num @ ( none @ num )
@ ^ [Q5: num] : ( some @ num @ ( bit0 @ Q5 ) )
@ ( bit_take_bit_num @ N2 @ M ) ) ) ).
% take_bit_num_simps(3)
thf(fact_5094_take__bit__num__simps_I4_J,axiom,
! [N2: nat,M: num] :
( ( bit_take_bit_num @ ( suc @ N2 ) @ ( bit1 @ M ) )
= ( some @ num @ ( case_option @ num @ num @ one2 @ bit1 @ ( bit_take_bit_num @ N2 @ M ) ) ) ) ).
% take_bit_num_simps(4)
thf(fact_5095_chain__subset,axiom,
! [A: $tType,Ord: A > A > $o,A4: set @ A,B3: set @ A] :
( ( comple1602240252501008431_chain @ A @ Ord @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( comple1602240252501008431_chain @ A @ Ord @ B3 ) ) ) ).
% chain_subset
thf(fact_5096_chain__empty,axiom,
! [A: $tType,Ord: A > A > $o] : ( comple1602240252501008431_chain @ A @ Ord @ ( bot_bot @ ( set @ A ) ) ) ).
% chain_empty
thf(fact_5097_ccpo__Sup__upper,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [A4: set @ A,X: A] :
( ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ A @ X @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ).
% ccpo_Sup_upper
thf(fact_5098_ccpo__Sup__least,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [A4: set @ A,Z: A] :
( ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ A4 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ A @ X5 @ Z ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ A4 ) @ Z ) ) ) ) ).
% ccpo_Sup_least
thf(fact_5099_listrel__Nil2,axiom,
! [B: $tType,A: $tType,Xs: list @ A,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ Xs @ ( nil @ B ) ) @ ( listrel @ A @ B @ R2 ) )
=> ( Xs
= ( nil @ A ) ) ) ).
% listrel_Nil2
thf(fact_5100_listrel__Nil1,axiom,
! [A: $tType,B: $tType,Xs: list @ B,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ ( nil @ A ) @ Xs ) @ ( listrel @ A @ B @ R2 ) )
=> ( Xs
= ( nil @ B ) ) ) ).
% listrel_Nil1
thf(fact_5101_listrel_ONil,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ B )] : ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ ( nil @ A ) @ ( nil @ B ) ) @ ( listrel @ A @ B @ R2 ) ) ).
% listrel.Nil
thf(fact_5102_listrel__eq__len,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ Xs @ Ys ) @ ( listrel @ A @ B @ R2 ) )
=> ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) ) ) ).
% listrel_eq_len
thf(fact_5103_listrel__mono,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ B ),S: set @ ( product_prod @ A @ B )] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) ) @ R2 @ S )
=> ( ord_less_eq @ ( set @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) ) @ ( listrel @ A @ B @ R2 ) @ ( listrel @ A @ B @ S ) ) ) ).
% listrel_mono
thf(fact_5104_chain__singleton,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [X: A] : ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% chain_singleton
thf(fact_5105_take__bit__num__eq__None__imp,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,N2: num] :
( ( ( bit_take_bit_num @ M @ N2 )
= ( none @ num ) )
=> ( ( bit_se2584673776208193580ke_bit @ A @ M @ ( numeral_numeral @ A @ N2 ) )
= ( zero_zero @ A ) ) ) ) ).
% take_bit_num_eq_None_imp
thf(fact_5106_listrel__iff__nth,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ Xs @ Ys ) @ ( listrel @ A @ B @ R2 ) )
= ( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
& ! [N: nat] :
( ( ord_less @ nat @ N @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ ( nth @ A @ Xs @ N ) @ ( nth @ B @ Ys @ N ) ) @ R2 ) ) ) ) ).
% listrel_iff_nth
thf(fact_5107_take__bit__num__def,axiom,
( bit_take_bit_num
= ( ^ [N: nat,M2: num] :
( if @ ( option @ num )
@ ( ( bit_se2584673776208193580ke_bit @ nat @ N @ ( numeral_numeral @ nat @ M2 ) )
= ( zero_zero @ nat ) )
@ ( none @ num )
@ ( some @ num @ ( num_of_nat @ ( bit_se2584673776208193580ke_bit @ nat @ N @ ( numeral_numeral @ nat @ M2 ) ) ) ) ) ) ) ).
% take_bit_num_def
thf(fact_5108_in__chain__finite,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [A4: set @ A] :
( ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ A4 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ A @ ( complete_Sup_Sup @ A @ A4 ) @ A4 ) ) ) ) ) ).
% in_chain_finite
thf(fact_5109_Rats__eq__int__div__nat,axiom,
( ( field_char_0_Rats @ real )
= ( collect @ real
@ ^ [Uu3: real] :
? [I5: int,N: nat] :
( ( Uu3
= ( divide_divide @ real @ ( ring_1_of_int @ real @ I5 ) @ ( semiring_1_of_nat @ real @ N ) ) )
& ( N
!= ( zero_zero @ nat ) ) ) ) ) ).
% Rats_eq_int_div_nat
thf(fact_5110_image2__def,axiom,
! [A: $tType,B: $tType,C: $tType] :
( ( bNF_Greatest_image2 @ C @ A @ B )
= ( ^ [A6: set @ C,F3: C > A,G2: C > B] :
( collect @ ( product_prod @ A @ B )
@ ^ [Uu3: product_prod @ A @ B] :
? [A5: C] :
( ( Uu3
= ( product_Pair @ A @ B @ ( F3 @ A5 ) @ ( G2 @ A5 ) ) )
& ( member2 @ C @ A5 @ A6 ) ) ) ) ) ).
% image2_def
thf(fact_5111_Rats__add,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ! [A3: A,B2: A] :
( ( member2 @ A @ A3 @ ( field_char_0_Rats @ A ) )
=> ( ( member2 @ A @ B2 @ ( field_char_0_Rats @ A ) )
=> ( member2 @ A @ ( plus_plus @ A @ A3 @ B2 ) @ ( field_char_0_Rats @ A ) ) ) ) ) ).
% Rats_add
thf(fact_5112_Rats__0,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ( member2 @ A @ ( zero_zero @ A ) @ ( field_char_0_Rats @ A ) ) ) ).
% Rats_0
thf(fact_5113_Ints__subset__Rats,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ( ord_less_eq @ ( set @ A ) @ ( ring_1_Ints @ A ) @ ( field_char_0_Rats @ A ) ) ) ).
% Ints_subset_Rats
thf(fact_5114_Nats__subset__Rats,axiom,
! [A: $tType] :
( ( field_char_0 @ A )
=> ( ord_less_eq @ ( set @ A ) @ ( semiring_1_Nats @ A ) @ ( field_char_0_Rats @ A ) ) ) ).
% Nats_subset_Rats
thf(fact_5115_image2__eqI,axiom,
! [A: $tType,C: $tType,B: $tType,B2: A,F2: B > A,X: B,C2: C,G: B > C,A4: set @ B] :
( ( B2
= ( F2 @ X ) )
=> ( ( C2
= ( G @ X ) )
=> ( ( member2 @ B @ X @ A4 )
=> ( member2 @ ( product_prod @ A @ C ) @ ( product_Pair @ A @ C @ B2 @ C2 ) @ ( bNF_Greatest_image2 @ B @ A @ C @ A4 @ F2 @ G ) ) ) ) ) ).
% image2_eqI
thf(fact_5116_set__zip,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ B] :
( ( set2 @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) )
= ( collect @ ( product_prod @ A @ B )
@ ^ [Uu3: product_prod @ A @ B] :
? [I5: nat] :
( ( Uu3
= ( product_Pair @ A @ B @ ( nth @ A @ Xs @ I5 ) @ ( nth @ B @ Ys @ I5 ) ) )
& ( ord_less @ nat @ I5 @ ( ord_min @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ B ) @ Ys ) ) ) ) ) ) ).
% set_zip
thf(fact_5117_UN__le__eq__Un0,axiom,
! [A: $tType,M7: nat > ( set @ A ),N2: nat] :
( ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ M7 @ ( set_ord_atMost @ nat @ N2 ) ) )
= ( sup_sup @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ M7 @ ( set_or1337092689740270186AtMost @ nat @ ( one_one @ nat ) @ N2 ) ) ) @ ( M7 @ ( zero_zero @ nat ) ) ) ) ).
% UN_le_eq_Un0
thf(fact_5118_set__nths,axiom,
! [A: $tType,Xs: list @ A,I6: set @ nat] :
( ( set2 @ A @ ( nths @ A @ Xs @ I6 ) )
= ( collect @ A
@ ^ [Uu3: A] :
? [I5: nat] :
( ( Uu3
= ( nth @ A @ Xs @ I5 ) )
& ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs ) )
& ( member2 @ nat @ I5 @ I6 ) ) ) ) ).
% set_nths
thf(fact_5119_sup_Oidem,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A3: A] :
( ( sup_sup @ A @ A3 @ A3 )
= A3 ) ) ).
% sup.idem
thf(fact_5120_sup__idem,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A] :
( ( sup_sup @ A @ X @ X )
= X ) ) ).
% sup_idem
thf(fact_5121_sup_Oleft__idem,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A3: A,B2: A] :
( ( sup_sup @ A @ A3 @ ( sup_sup @ A @ A3 @ B2 ) )
= ( sup_sup @ A @ A3 @ B2 ) ) ) ).
% sup.left_idem
thf(fact_5122_sup__left__idem,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A,Y: A] :
( ( sup_sup @ A @ X @ ( sup_sup @ A @ X @ Y ) )
= ( sup_sup @ A @ X @ Y ) ) ) ).
% sup_left_idem
thf(fact_5123_sup_Oright__idem,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A3: A,B2: A] :
( ( sup_sup @ A @ ( sup_sup @ A @ A3 @ B2 ) @ B2 )
= ( sup_sup @ A @ A3 @ B2 ) ) ) ).
% sup.right_idem
thf(fact_5124_sup__apply,axiom,
! [B: $tType,A: $tType] :
( ( semilattice_sup @ B )
=> ( ( sup_sup @ ( A > B ) )
= ( ^ [F3: A > B,G2: A > B,X2: A] : ( sup_sup @ B @ ( F3 @ X2 ) @ ( G2 @ X2 ) ) ) ) ) ).
% sup_apply
thf(fact_5125_min_Oidem,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A] :
( ( ord_min @ A @ A3 @ A3 )
= A3 ) ) ).
% min.idem
thf(fact_5126_min_Oleft__idem,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_min @ A @ A3 @ ( ord_min @ A @ A3 @ B2 ) )
= ( ord_min @ A @ A3 @ B2 ) ) ) ).
% min.left_idem
thf(fact_5127_min_Oright__idem,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_min @ A @ ( ord_min @ A @ A3 @ B2 ) @ B2 )
= ( ord_min @ A @ A3 @ B2 ) ) ) ).
% min.right_idem
thf(fact_5128_sup_Obounded__iff,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less_eq @ A @ ( sup_sup @ A @ B2 @ C2 ) @ A3 )
= ( ( ord_less_eq @ A @ B2 @ A3 )
& ( ord_less_eq @ A @ C2 @ A3 ) ) ) ) ).
% sup.bounded_iff
thf(fact_5129_le__sup__iff,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less_eq @ A @ ( sup_sup @ A @ X @ Y ) @ Z )
= ( ( ord_less_eq @ A @ X @ Z )
& ( ord_less_eq @ A @ Y @ Z ) ) ) ) ).
% le_sup_iff
thf(fact_5130_sup__top__right,axiom,
! [A: $tType] :
( ( bounded_lattice_top @ A )
=> ! [X: A] :
( ( sup_sup @ A @ X @ ( top_top @ A ) )
= ( top_top @ A ) ) ) ).
% sup_top_right
thf(fact_5131_sup__top__left,axiom,
! [A: $tType] :
( ( bounded_lattice_top @ A )
=> ! [X: A] :
( ( sup_sup @ A @ ( top_top @ A ) @ X )
= ( top_top @ A ) ) ) ).
% sup_top_left
thf(fact_5132_sup__bot__left,axiom,
! [A: $tType] :
( ( bounde4967611905675639751up_bot @ A )
=> ! [X: A] :
( ( sup_sup @ A @ ( bot_bot @ A ) @ X )
= X ) ) ).
% sup_bot_left
thf(fact_5133_sup__bot__right,axiom,
! [A: $tType] :
( ( bounde4967611905675639751up_bot @ A )
=> ! [X: A] :
( ( sup_sup @ A @ X @ ( bot_bot @ A ) )
= X ) ) ).
% sup_bot_right
thf(fact_5134_bot__eq__sup__iff,axiom,
! [A: $tType] :
( ( bounde4967611905675639751up_bot @ A )
=> ! [X: A,Y: A] :
( ( ( bot_bot @ A )
= ( sup_sup @ A @ X @ Y ) )
= ( ( X
= ( bot_bot @ A ) )
& ( Y
= ( bot_bot @ A ) ) ) ) ) ).
% bot_eq_sup_iff
thf(fact_5135_sup__eq__bot__iff,axiom,
! [A: $tType] :
( ( bounde4967611905675639751up_bot @ A )
=> ! [X: A,Y: A] :
( ( ( sup_sup @ A @ X @ Y )
= ( bot_bot @ A ) )
= ( ( X
= ( bot_bot @ A ) )
& ( Y
= ( bot_bot @ A ) ) ) ) ) ).
% sup_eq_bot_iff
thf(fact_5136_sup__bot_Oeq__neutr__iff,axiom,
! [A: $tType] :
( ( bounde4967611905675639751up_bot @ A )
=> ! [A3: A,B2: A] :
( ( ( sup_sup @ A @ A3 @ B2 )
= ( bot_bot @ A ) )
= ( ( A3
= ( bot_bot @ A ) )
& ( B2
= ( bot_bot @ A ) ) ) ) ) ).
% sup_bot.eq_neutr_iff
thf(fact_5137_sup__bot_Oleft__neutral,axiom,
! [A: $tType] :
( ( bounde4967611905675639751up_bot @ A )
=> ! [A3: A] :
( ( sup_sup @ A @ ( bot_bot @ A ) @ A3 )
= A3 ) ) ).
% sup_bot.left_neutral
thf(fact_5138_sup__bot_Oneutr__eq__iff,axiom,
! [A: $tType] :
( ( bounde4967611905675639751up_bot @ A )
=> ! [A3: A,B2: A] :
( ( ( bot_bot @ A )
= ( sup_sup @ A @ A3 @ B2 ) )
= ( ( A3
= ( bot_bot @ A ) )
& ( B2
= ( bot_bot @ A ) ) ) ) ) ).
% sup_bot.neutr_eq_iff
thf(fact_5139_sup__bot_Oright__neutral,axiom,
! [A: $tType] :
( ( bounde4967611905675639751up_bot @ A )
=> ! [A3: A] :
( ( sup_sup @ A @ A3 @ ( bot_bot @ A ) )
= A3 ) ) ).
% sup_bot.right_neutral
thf(fact_5140_sup__inf__absorb,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A] :
( ( sup_sup @ A @ X @ ( inf_inf @ A @ X @ Y ) )
= X ) ) ).
% sup_inf_absorb
thf(fact_5141_inf__sup__absorb,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A] :
( ( inf_inf @ A @ X @ ( sup_sup @ A @ X @ Y ) )
= X ) ) ).
% inf_sup_absorb
thf(fact_5142_min_Obounded__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ ( ord_min @ A @ B2 @ C2 ) )
= ( ( ord_less_eq @ A @ A3 @ B2 )
& ( ord_less_eq @ A @ A3 @ C2 ) ) ) ) ).
% min.bounded_iff
thf(fact_5143_min_Oabsorb2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( ord_min @ A @ A3 @ B2 )
= B2 ) ) ) ).
% min.absorb2
thf(fact_5144_min_Oabsorb1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_min @ A @ A3 @ B2 )
= A3 ) ) ) ).
% min.absorb1
thf(fact_5145_Un__empty,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ( sup_sup @ ( set @ A ) @ A4 @ B3 )
= ( bot_bot @ ( set @ A ) ) )
= ( ( A4
= ( bot_bot @ ( set @ A ) ) )
& ( B3
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% Un_empty
thf(fact_5146_Un__subset__iff,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,C5: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) @ C5 )
= ( ( ord_less_eq @ ( set @ A ) @ A4 @ C5 )
& ( ord_less_eq @ ( set @ A ) @ B3 @ C5 ) ) ) ).
% Un_subset_iff
thf(fact_5147_min_Oabsorb3,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( ord_min @ A @ A3 @ B2 )
= A3 ) ) ) ).
% min.absorb3
thf(fact_5148_min_Oabsorb4,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ( ord_min @ A @ A3 @ B2 )
= B2 ) ) ) ).
% min.absorb4
thf(fact_5149_min__less__iff__conj,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Z: A,X: A,Y: A] :
( ( ord_less @ A @ Z @ ( ord_min @ A @ X @ Y ) )
= ( ( ord_less @ A @ Z @ X )
& ( ord_less @ A @ Z @ Y ) ) ) ) ).
% min_less_iff_conj
thf(fact_5150_min__bot2,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ! [X: A] :
( ( ord_min @ A @ X @ ( bot_bot @ A ) )
= ( bot_bot @ A ) ) ) ).
% min_bot2
thf(fact_5151_min__bot,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ! [X: A] :
( ( ord_min @ A @ ( bot_bot @ A ) @ X )
= ( bot_bot @ A ) ) ) ).
% min_bot
thf(fact_5152_max__min__same_I4_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Y: A,X: A] :
( ( ord_max @ A @ Y @ ( ord_min @ A @ X @ Y ) )
= Y ) ) ).
% max_min_same(4)
thf(fact_5153_max__min__same_I3_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( ord_max @ A @ ( ord_min @ A @ X @ Y ) @ Y )
= Y ) ) ).
% max_min_same(3)
thf(fact_5154_max__min__same_I2_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( ord_max @ A @ ( ord_min @ A @ X @ Y ) @ X )
= X ) ) ).
% max_min_same(2)
thf(fact_5155_max__min__same_I1_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A] :
( ( ord_max @ A @ X @ ( ord_min @ A @ X @ Y ) )
= X ) ) ).
% max_min_same(1)
thf(fact_5156_min__Suc__Suc,axiom,
! [M: nat,N2: nat] :
( ( ord_min @ nat @ ( suc @ M ) @ ( suc @ N2 ) )
= ( suc @ ( ord_min @ nat @ M @ N2 ) ) ) ).
% min_Suc_Suc
thf(fact_5157_min__0L,axiom,
! [N2: nat] :
( ( ord_min @ nat @ ( zero_zero @ nat ) @ N2 )
= ( zero_zero @ nat ) ) ).
% min_0L
thf(fact_5158_min__0R,axiom,
! [N2: nat] :
( ( ord_min @ nat @ N2 @ ( zero_zero @ nat ) )
= ( zero_zero @ nat ) ) ).
% min_0R
thf(fact_5159_nths__nil,axiom,
! [A: $tType,A4: set @ nat] :
( ( nths @ A @ ( nil @ A ) @ A4 )
= ( nil @ A ) ) ).
% nths_nil
thf(fact_5160_take__take,axiom,
! [A: $tType,N2: nat,M: nat,Xs: list @ A] :
( ( take @ A @ N2 @ ( take @ A @ M @ Xs ) )
= ( take @ A @ ( ord_min @ nat @ N2 @ M ) @ Xs ) ) ).
% take_take
thf(fact_5161_min__number__of_I1_J,axiom,
! [A: $tType] :
( ( ( numeral @ A )
& ( ord @ A ) )
=> ! [U: num,V2: num] :
( ( ( ord_less_eq @ A @ ( numeral_numeral @ A @ U ) @ ( numeral_numeral @ A @ V2 ) )
=> ( ( ord_min @ A @ ( numeral_numeral @ A @ U ) @ ( numeral_numeral @ A @ V2 ) )
= ( numeral_numeral @ A @ U ) ) )
& ( ~ ( ord_less_eq @ A @ ( numeral_numeral @ A @ U ) @ ( numeral_numeral @ A @ V2 ) )
=> ( ( ord_min @ A @ ( numeral_numeral @ A @ U ) @ ( numeral_numeral @ A @ V2 ) )
= ( numeral_numeral @ A @ V2 ) ) ) ) ) ).
% min_number_of(1)
thf(fact_5162_min__0__1_I3_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [X: num] :
( ( ord_min @ A @ ( zero_zero @ A ) @ ( numeral_numeral @ A @ X ) )
= ( zero_zero @ A ) ) ) ).
% min_0_1(3)
thf(fact_5163_min__0__1_I4_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [X: num] :
( ( ord_min @ A @ ( numeral_numeral @ A @ X ) @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% min_0_1(4)
thf(fact_5164_min__0__1_I2_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ( ( ord_min @ A @ ( one_one @ A ) @ ( zero_zero @ A ) )
= ( zero_zero @ A ) ) ) ).
% min_0_1(2)
thf(fact_5165_min__0__1_I1_J,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ( ( ord_min @ A @ ( zero_zero @ A ) @ ( one_one @ A ) )
= ( zero_zero @ A ) ) ) ).
% min_0_1(1)
thf(fact_5166_length__take,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( size_size @ ( list @ A ) @ ( take @ A @ N2 @ Xs ) )
= ( ord_min @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 ) ) ).
% length_take
thf(fact_5167_nths__upt__eq__take,axiom,
! [A: $tType,L: list @ A,N2: nat] :
( ( nths @ A @ L @ ( set_ord_lessThan @ nat @ N2 ) )
= ( take @ A @ N2 @ L ) ) ).
% nths_upt_eq_take
thf(fact_5168_take__replicate,axiom,
! [A: $tType,I: nat,K: nat,X: A] :
( ( take @ A @ I @ ( replicate @ A @ K @ X ) )
= ( replicate @ A @ ( ord_min @ nat @ I @ K ) @ X ) ) ).
% take_replicate
thf(fact_5169_nths__empty,axiom,
! [A: $tType,Xs: list @ A] :
( ( nths @ A @ Xs @ ( bot_bot @ ( set @ nat ) ) )
= ( nil @ A ) ) ).
% nths_empty
thf(fact_5170_set__union,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( set2 @ A @ ( union @ A @ Xs @ Ys ) )
= ( sup_sup @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ Ys ) ) ) ).
% set_union
thf(fact_5171_min__number__of_I4_J,axiom,
! [A: $tType] :
( ( ( uminus @ A )
& ( numeral @ A )
& ( ord @ A ) )
=> ! [U: num,V2: num] :
( ( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
=> ( ( ord_min @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
=> ( ( ord_min @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) ) ) ) ) ).
% min_number_of(4)
thf(fact_5172_min__number__of_I3_J,axiom,
! [A: $tType] :
( ( ( uminus @ A )
& ( numeral @ A )
& ( ord @ A ) )
=> ! [U: num,V2: num] :
( ( ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( numeral_numeral @ A @ V2 ) )
=> ( ( ord_min @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( numeral_numeral @ A @ V2 ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( numeral_numeral @ A @ V2 ) )
=> ( ( ord_min @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ U ) ) @ ( numeral_numeral @ A @ V2 ) )
= ( numeral_numeral @ A @ V2 ) ) ) ) ) ).
% min_number_of(3)
thf(fact_5173_min__number__of_I2_J,axiom,
! [A: $tType] :
( ( ( uminus @ A )
& ( numeral @ A )
& ( ord @ A ) )
=> ! [U: num,V2: num] :
( ( ( ord_less_eq @ A @ ( numeral_numeral @ A @ U ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
=> ( ( ord_min @ A @ ( numeral_numeral @ A @ U ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
= ( numeral_numeral @ A @ U ) ) )
& ( ~ ( ord_less_eq @ A @ ( numeral_numeral @ A @ U ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
=> ( ( ord_min @ A @ ( numeral_numeral @ A @ U ) @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) )
= ( uminus_uminus @ A @ ( numeral_numeral @ A @ V2 ) ) ) ) ) ) ).
% min_number_of(2)
thf(fact_5174_Int__atLeastAtMost,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ ( set_or1337092689740270186AtMost @ A @ C2 @ D2 ) )
= ( set_or1337092689740270186AtMost @ A @ ( ord_max @ A @ A3 @ C2 ) @ ( ord_min @ A @ B2 @ D2 ) ) ) ) ).
% Int_atLeastAtMost
thf(fact_5175_Int__atLeastLessThan,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ A3 @ B2 ) @ ( set_or7035219750837199246ssThan @ A @ C2 @ D2 ) )
= ( set_or7035219750837199246ssThan @ A @ ( ord_max @ A @ A3 @ C2 ) @ ( ord_min @ A @ B2 @ D2 ) ) ) ) ).
% Int_atLeastLessThan
thf(fact_5176_Int__greaterThanLessThan,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) @ ( set_or5935395276787703475ssThan @ A @ C2 @ D2 ) )
= ( set_or5935395276787703475ssThan @ A @ ( ord_max @ A @ A3 @ C2 ) @ ( ord_min @ A @ B2 @ D2 ) ) ) ) ).
% Int_greaterThanLessThan
thf(fact_5177_Int__greaterThanAtMost,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A,D2: A] :
( ( inf_inf @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ A3 @ B2 ) @ ( set_or3652927894154168847AtMost @ A @ C2 @ D2 ) )
= ( set_or3652927894154168847AtMost @ A @ ( ord_max @ A @ A3 @ C2 ) @ ( ord_min @ A @ B2 @ D2 ) ) ) ) ).
% Int_greaterThanAtMost
thf(fact_5178_min__numeral__Suc,axiom,
! [K: num,N2: nat] :
( ( ord_min @ nat @ ( numeral_numeral @ nat @ K ) @ ( suc @ N2 ) )
= ( suc @ ( ord_min @ nat @ ( pred_numeral @ K ) @ N2 ) ) ) ).
% min_numeral_Suc
thf(fact_5179_min__Suc__numeral,axiom,
! [N2: nat,K: num] :
( ( ord_min @ nat @ ( suc @ N2 ) @ ( numeral_numeral @ nat @ K ) )
= ( suc @ ( ord_min @ nat @ N2 @ ( pred_numeral @ K ) ) ) ) ).
% min_Suc_numeral
thf(fact_5180_zip__replicate,axiom,
! [A: $tType,B: $tType,I: nat,X: A,J: nat,Y: B] :
( ( zip @ A @ B @ ( replicate @ A @ I @ X ) @ ( replicate @ B @ J @ Y ) )
= ( replicate @ ( product_prod @ A @ B ) @ ( ord_min @ nat @ I @ J ) @ ( product_Pair @ A @ B @ X @ Y ) ) ) ).
% zip_replicate
thf(fact_5181_UN__simps_I3_J,axiom,
! [E2: $tType,F: $tType,C5: set @ F,A4: set @ E2,B3: F > ( set @ E2 )] :
( ( ( C5
= ( bot_bot @ ( set @ F ) ) )
=> ( ( complete_Sup_Sup @ ( set @ E2 )
@ ( image2 @ F @ ( set @ E2 )
@ ^ [X2: F] : ( sup_sup @ ( set @ E2 ) @ A4 @ ( B3 @ X2 ) )
@ C5 ) )
= ( bot_bot @ ( set @ E2 ) ) ) )
& ( ( C5
!= ( bot_bot @ ( set @ F ) ) )
=> ( ( complete_Sup_Sup @ ( set @ E2 )
@ ( image2 @ F @ ( set @ E2 )
@ ^ [X2: F] : ( sup_sup @ ( set @ E2 ) @ A4 @ ( B3 @ X2 ) )
@ C5 ) )
= ( sup_sup @ ( set @ E2 ) @ A4 @ ( complete_Sup_Sup @ ( set @ E2 ) @ ( image2 @ F @ ( set @ E2 ) @ B3 @ C5 ) ) ) ) ) ) ).
% UN_simps(3)
thf(fact_5182_UN__simps_I2_J,axiom,
! [C: $tType,D: $tType,C5: set @ C,A4: C > ( set @ D ),B3: set @ D] :
( ( ( C5
= ( bot_bot @ ( set @ C ) ) )
=> ( ( complete_Sup_Sup @ ( set @ D )
@ ( image2 @ C @ ( set @ D )
@ ^ [X2: C] : ( sup_sup @ ( set @ D ) @ ( A4 @ X2 ) @ B3 )
@ C5 ) )
= ( bot_bot @ ( set @ D ) ) ) )
& ( ( C5
!= ( bot_bot @ ( set @ C ) ) )
=> ( ( complete_Sup_Sup @ ( set @ D )
@ ( image2 @ C @ ( set @ D )
@ ^ [X2: C] : ( sup_sup @ ( set @ D ) @ ( A4 @ X2 ) @ B3 )
@ C5 ) )
= ( sup_sup @ ( set @ D ) @ ( complete_Sup_Sup @ ( set @ D ) @ ( image2 @ C @ ( set @ D ) @ A4 @ C5 ) ) @ B3 ) ) ) ) ).
% UN_simps(2)
thf(fact_5183_length__zip,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B] :
( ( size_size @ ( list @ ( product_prod @ A @ B ) ) @ ( zip @ A @ B @ Xs @ Ys ) )
= ( ord_min @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ B ) @ Ys ) ) ) ).
% length_zip
thf(fact_5184_min__def__raw,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( ord_min @ A )
= ( ^ [A5: A,B4: A] : ( if @ A @ ( ord_less_eq @ A @ A5 @ B4 ) @ A5 @ B4 ) ) ) ) ).
% min_def_raw
thf(fact_5185_nat__mult__min__left,axiom,
! [M: nat,N2: nat,Q2: nat] :
( ( times_times @ nat @ ( ord_min @ nat @ M @ N2 ) @ Q2 )
= ( ord_min @ nat @ ( times_times @ nat @ M @ Q2 ) @ ( times_times @ nat @ N2 @ Q2 ) ) ) ).
% nat_mult_min_left
thf(fact_5186_nat__mult__min__right,axiom,
! [M: nat,N2: nat,Q2: nat] :
( ( times_times @ nat @ M @ ( ord_min @ nat @ N2 @ Q2 ) )
= ( ord_min @ nat @ ( times_times @ nat @ M @ N2 ) @ ( times_times @ nat @ M @ Q2 ) ) ) ).
% nat_mult_min_right
thf(fact_5187_sup_OcoboundedI2,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less_eq @ A @ C2 @ B2 )
=> ( ord_less_eq @ A @ C2 @ ( sup_sup @ A @ A3 @ B2 ) ) ) ) ).
% sup.coboundedI2
thf(fact_5188_sup_OcoboundedI1,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ C2 @ A3 )
=> ( ord_less_eq @ A @ C2 @ ( sup_sup @ A @ A3 @ B2 ) ) ) ) ).
% sup.coboundedI1
thf(fact_5189_sup_Oabsorb__iff2,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [A5: A,B4: A] :
( ( sup_sup @ A @ A5 @ B4 )
= B4 ) ) ) ) ).
% sup.absorb_iff2
thf(fact_5190_sup_Oabsorb__iff1,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [B4: A,A5: A] :
( ( sup_sup @ A @ A5 @ B4 )
= A5 ) ) ) ) ).
% sup.absorb_iff1
thf(fact_5191_sup_Ocobounded2,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [B2: A,A3: A] : ( ord_less_eq @ A @ B2 @ ( sup_sup @ A @ A3 @ B2 ) ) ) ).
% sup.cobounded2
thf(fact_5192_sup_Ocobounded1,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ A @ A3 @ ( sup_sup @ A @ A3 @ B2 ) ) ) ).
% sup.cobounded1
thf(fact_5193_sup_Oorder__iff,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [B4: A,A5: A] :
( A5
= ( sup_sup @ A @ A5 @ B4 ) ) ) ) ) ).
% sup.order_iff
thf(fact_5194_sup_OboundedI,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( ord_less_eq @ A @ C2 @ A3 )
=> ( ord_less_eq @ A @ ( sup_sup @ A @ B2 @ C2 ) @ A3 ) ) ) ) ).
% sup.boundedI
thf(fact_5195_sup_OboundedE,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less_eq @ A @ ( sup_sup @ A @ B2 @ C2 ) @ A3 )
=> ~ ( ( ord_less_eq @ A @ B2 @ A3 )
=> ~ ( ord_less_eq @ A @ C2 @ A3 ) ) ) ) ).
% sup.boundedE
thf(fact_5196_sup__absorb2,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( sup_sup @ A @ X @ Y )
= Y ) ) ) ).
% sup_absorb2
thf(fact_5197_sup__absorb1,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ Y @ X )
=> ( ( sup_sup @ A @ X @ Y )
= X ) ) ) ).
% sup_absorb1
thf(fact_5198_sup_Oabsorb2,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( sup_sup @ A @ A3 @ B2 )
= B2 ) ) ) ).
% sup.absorb2
thf(fact_5199_sup_Oabsorb1,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( ( sup_sup @ A @ A3 @ B2 )
= A3 ) ) ) ).
% sup.absorb1
thf(fact_5200_sup__unique,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [F2: A > A > A,X: A,Y: A] :
( ! [X5: A,Y4: A] : ( ord_less_eq @ A @ X5 @ ( F2 @ X5 @ Y4 ) )
=> ( ! [X5: A,Y4: A] : ( ord_less_eq @ A @ Y4 @ ( F2 @ X5 @ Y4 ) )
=> ( ! [X5: A,Y4: A,Z2: A] :
( ( ord_less_eq @ A @ Y4 @ X5 )
=> ( ( ord_less_eq @ A @ Z2 @ X5 )
=> ( ord_less_eq @ A @ ( F2 @ Y4 @ Z2 ) @ X5 ) ) )
=> ( ( sup_sup @ A @ X @ Y )
= ( F2 @ X @ Y ) ) ) ) ) ) ).
% sup_unique
thf(fact_5201_sup_OorderI,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A3: A,B2: A] :
( ( A3
= ( sup_sup @ A @ A3 @ B2 ) )
=> ( ord_less_eq @ A @ B2 @ A3 ) ) ) ).
% sup.orderI
thf(fact_5202_sup_OorderE,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [B2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ A3 )
=> ( A3
= ( sup_sup @ A @ A3 @ B2 ) ) ) ) ).
% sup.orderE
thf(fact_5203_le__iff__sup,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [X2: A,Y2: A] :
( ( sup_sup @ A @ X2 @ Y2 )
= Y2 ) ) ) ) ).
% le_iff_sup
thf(fact_5204_sup__least,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [Y: A,X: A,Z: A] :
( ( ord_less_eq @ A @ Y @ X )
=> ( ( ord_less_eq @ A @ Z @ X )
=> ( ord_less_eq @ A @ ( sup_sup @ A @ Y @ Z ) @ X ) ) ) ) ).
% sup_least
thf(fact_5205_sup__mono,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A3: A,C2: A,B2: A,D2: A] :
( ( ord_less_eq @ A @ A3 @ C2 )
=> ( ( ord_less_eq @ A @ B2 @ D2 )
=> ( ord_less_eq @ A @ ( sup_sup @ A @ A3 @ B2 ) @ ( sup_sup @ A @ C2 @ D2 ) ) ) ) ) ).
% sup_mono
thf(fact_5206_sup_Omono,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [C2: A,A3: A,D2: A,B2: A] :
( ( ord_less_eq @ A @ C2 @ A3 )
=> ( ( ord_less_eq @ A @ D2 @ B2 )
=> ( ord_less_eq @ A @ ( sup_sup @ A @ C2 @ D2 ) @ ( sup_sup @ A @ A3 @ B2 ) ) ) ) ) ).
% sup.mono
thf(fact_5207_le__supI2,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A,B2: A,A3: A] :
( ( ord_less_eq @ A @ X @ B2 )
=> ( ord_less_eq @ A @ X @ ( sup_sup @ A @ A3 @ B2 ) ) ) ) ).
% le_supI2
thf(fact_5208_le__supI1,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A,A3: A,B2: A] :
( ( ord_less_eq @ A @ X @ A3 )
=> ( ord_less_eq @ A @ X @ ( sup_sup @ A @ A3 @ B2 ) ) ) ) ).
% le_supI1
thf(fact_5209_sup__ge2,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [Y: A,X: A] : ( ord_less_eq @ A @ Y @ ( sup_sup @ A @ X @ Y ) ) ) ).
% sup_ge2
thf(fact_5210_sup__ge1,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ A @ X @ ( sup_sup @ A @ X @ Y ) ) ) ).
% sup_ge1
thf(fact_5211_le__supI,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A3: A,X: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ X )
=> ( ( ord_less_eq @ A @ B2 @ X )
=> ( ord_less_eq @ A @ ( sup_sup @ A @ A3 @ B2 ) @ X ) ) ) ) ).
% le_supI
thf(fact_5212_le__supE,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A3: A,B2: A,X: A] :
( ( ord_less_eq @ A @ ( sup_sup @ A @ A3 @ B2 ) @ X )
=> ~ ( ( ord_less_eq @ A @ A3 @ X )
=> ~ ( ord_less_eq @ A @ B2 @ X ) ) ) ) ).
% le_supE
thf(fact_5213_inf__sup__ord_I3_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A] : ( ord_less_eq @ A @ X @ ( sup_sup @ A @ X @ Y ) ) ) ).
% inf_sup_ord(3)
thf(fact_5214_inf__sup__ord_I4_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [Y: A,X: A] : ( ord_less_eq @ A @ Y @ ( sup_sup @ A @ X @ Y ) ) ) ).
% inf_sup_ord(4)
thf(fact_5215_min__absorb2,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [Y: A,X: A] :
( ( ord_less_eq @ A @ Y @ X )
=> ( ( ord_min @ A @ X @ Y )
= Y ) ) ) ).
% min_absorb2
thf(fact_5216_min__absorb1,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [X: A,Y: A] :
( ( ord_less_eq @ A @ X @ Y )
=> ( ( ord_min @ A @ X @ Y )
= X ) ) ) ).
% min_absorb1
thf(fact_5217_min__def,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( ord_min @ A )
= ( ^ [A5: A,B4: A] : ( if @ A @ ( ord_less_eq @ A @ A5 @ B4 ) @ A5 @ B4 ) ) ) ) ).
% min_def
thf(fact_5218_min__le__iff__disj,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less_eq @ A @ ( ord_min @ A @ X @ Y ) @ Z )
= ( ( ord_less_eq @ A @ X @ Z )
| ( ord_less_eq @ A @ Y @ Z ) ) ) ) ).
% min_le_iff_disj
thf(fact_5219_min_OcoboundedI2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less_eq @ A @ B2 @ C2 )
=> ( ord_less_eq @ A @ ( ord_min @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% min.coboundedI2
thf(fact_5220_min_OcoboundedI1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ C2 )
=> ( ord_less_eq @ A @ ( ord_min @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% min.coboundedI1
thf(fact_5221_min_Oabsorb__iff2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [B4: A,A5: A] :
( ( ord_min @ A @ A5 @ B4 )
= B4 ) ) ) ) ).
% min.absorb_iff2
thf(fact_5222_min_Oabsorb__iff1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [A5: A,B4: A] :
( ( ord_min @ A @ A5 @ B4 )
= A5 ) ) ) ) ).
% min.absorb_iff1
thf(fact_5223_min_Ocobounded2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ A @ ( ord_min @ A @ A3 @ B2 ) @ B2 ) ) ).
% min.cobounded2
thf(fact_5224_min_Ocobounded1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] : ( ord_less_eq @ A @ ( ord_min @ A @ A3 @ B2 ) @ A3 ) ) ).
% min.cobounded1
thf(fact_5225_min_Oorder__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_less_eq @ A )
= ( ^ [A5: A,B4: A] :
( A5
= ( ord_min @ A @ A5 @ B4 ) ) ) ) ) ).
% min.order_iff
thf(fact_5226_min_OboundedI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ( ord_less_eq @ A @ A3 @ C2 )
=> ( ord_less_eq @ A @ A3 @ ( ord_min @ A @ B2 @ C2 ) ) ) ) ) ).
% min.boundedI
thf(fact_5227_min_OboundedE,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less_eq @ A @ A3 @ ( ord_min @ A @ B2 @ C2 ) )
=> ~ ( ( ord_less_eq @ A @ A3 @ B2 )
=> ~ ( ord_less_eq @ A @ A3 @ C2 ) ) ) ) ).
% min.boundedE
thf(fact_5228_min_OorderI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( A3
= ( ord_min @ A @ A3 @ B2 ) )
=> ( ord_less_eq @ A @ A3 @ B2 ) ) ) ).
% min.orderI
thf(fact_5229_min_OorderE,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A] :
( ( ord_less_eq @ A @ A3 @ B2 )
=> ( A3
= ( ord_min @ A @ A3 @ B2 ) ) ) ) ).
% min.orderE
thf(fact_5230_min_Omono,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,C2: A,B2: A,D2: A] :
( ( ord_less_eq @ A @ A3 @ C2 )
=> ( ( ord_less_eq @ A @ B2 @ D2 )
=> ( ord_less_eq @ A @ ( ord_min @ A @ A3 @ B2 ) @ ( ord_min @ A @ C2 @ D2 ) ) ) ) ) ).
% min.mono
thf(fact_5231_subset__Un__eq,axiom,
! [A: $tType] :
( ( ord_less_eq @ ( set @ A ) )
= ( ^ [A6: set @ A,B6: set @ A] :
( ( sup_sup @ ( set @ A ) @ A6 @ B6 )
= B6 ) ) ) ).
% subset_Un_eq
thf(fact_5232_subset__UnE,axiom,
! [A: $tType,C5: set @ A,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ C5 @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
=> ~ ! [A17: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A17 @ A4 )
=> ! [B12: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B12 @ B3 )
=> ( C5
!= ( sup_sup @ ( set @ A ) @ A17 @ B12 ) ) ) ) ) ).
% subset_UnE
thf(fact_5233_Un__absorb2,axiom,
! [A: $tType,B3: set @ A,A4: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( sup_sup @ ( set @ A ) @ A4 @ B3 )
= A4 ) ) ).
% Un_absorb2
thf(fact_5234_Un__absorb1,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( sup_sup @ ( set @ A ) @ A4 @ B3 )
= B3 ) ) ).
% Un_absorb1
thf(fact_5235_Un__upper2,axiom,
! [A: $tType,B3: set @ A,A4: set @ A] : ( ord_less_eq @ ( set @ A ) @ B3 @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) ) ).
% Un_upper2
thf(fact_5236_Un__upper1,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] : ( ord_less_eq @ ( set @ A ) @ A4 @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) ) ).
% Un_upper1
thf(fact_5237_Un__least,axiom,
! [A: $tType,A4: set @ A,C5: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ C5 )
=> ( ord_less_eq @ ( set @ A ) @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) @ C5 ) ) ) ).
% Un_least
thf(fact_5238_Un__mono,axiom,
! [A: $tType,A4: set @ A,C5: set @ A,B3: set @ A,D6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ D6 )
=> ( ord_less_eq @ ( set @ A ) @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) @ ( sup_sup @ ( set @ A ) @ C5 @ D6 ) ) ) ) ).
% Un_mono
thf(fact_5239_boolean__algebra_Odisj__zero__right,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A] :
( ( sup_sup @ A @ X @ ( bot_bot @ A ) )
= X ) ) ).
% boolean_algebra.disj_zero_right
thf(fact_5240_Un__empty__right,axiom,
! [A: $tType,A4: set @ A] :
( ( sup_sup @ ( set @ A ) @ A4 @ ( bot_bot @ ( set @ A ) ) )
= A4 ) ).
% Un_empty_right
thf(fact_5241_Un__empty__left,axiom,
! [A: $tType,B3: set @ A] :
( ( sup_sup @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) @ B3 )
= B3 ) ).
% Un_empty_left
thf(fact_5242_distinct__nthsI,axiom,
! [A: $tType,Xs: list @ A,I6: set @ nat] :
( ( distinct @ A @ Xs )
=> ( distinct @ A @ ( nths @ A @ Xs @ I6 ) ) ) ).
% distinct_nthsI
thf(fact_5243_max__min__distrib1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_max @ A @ ( ord_min @ A @ B2 @ C2 ) @ A3 )
= ( ord_min @ A @ ( ord_max @ A @ B2 @ A3 ) @ ( ord_max @ A @ C2 @ A3 ) ) ) ) ).
% max_min_distrib1
thf(fact_5244_max__min__distrib2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_max @ A @ A3 @ ( ord_min @ A @ B2 @ C2 ) )
= ( ord_min @ A @ ( ord_max @ A @ A3 @ B2 ) @ ( ord_max @ A @ A3 @ C2 ) ) ) ) ).
% max_min_distrib2
thf(fact_5245_min__max__distrib1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_min @ A @ ( ord_max @ A @ B2 @ C2 ) @ A3 )
= ( ord_max @ A @ ( ord_min @ A @ B2 @ A3 ) @ ( ord_min @ A @ C2 @ A3 ) ) ) ) ).
% min_max_distrib1
thf(fact_5246_min__max__distrib2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_min @ A @ A3 @ ( ord_max @ A @ B2 @ C2 ) )
= ( ord_max @ A @ ( ord_min @ A @ A3 @ B2 ) @ ( ord_min @ A @ A3 @ C2 ) ) ) ) ).
% min_max_distrib2
thf(fact_5247_min__less__iff__disj,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less @ A @ ( ord_min @ A @ X @ Y ) @ Z )
= ( ( ord_less @ A @ X @ Z )
| ( ord_less @ A @ Y @ Z ) ) ) ) ).
% min_less_iff_disj
thf(fact_5248_min_Ostrict__boundedE,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_less @ A @ A3 @ ( ord_min @ A @ B2 @ C2 ) )
=> ~ ( ( ord_less @ A @ A3 @ B2 )
=> ~ ( ord_less @ A @ A3 @ C2 ) ) ) ) ).
% min.strict_boundedE
thf(fact_5249_min_Ostrict__order__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_less @ A )
= ( ^ [A5: A,B4: A] :
( ( A5
= ( ord_min @ A @ A5 @ B4 ) )
& ( A5 != B4 ) ) ) ) ) ).
% min.strict_order_iff
thf(fact_5250_min_Ostrict__coboundedI1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( ord_less @ A @ A3 @ C2 )
=> ( ord_less @ A @ ( ord_min @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% min.strict_coboundedI1
thf(fact_5251_min_Ostrict__coboundedI2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less @ A @ B2 @ C2 )
=> ( ord_less @ A @ ( ord_min @ A @ A3 @ B2 ) @ C2 ) ) ) ).
% min.strict_coboundedI2
thf(fact_5252_min__add__distrib__left,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [X: A,Y: A,Z: A] :
( ( plus_plus @ A @ ( ord_min @ A @ X @ Y ) @ Z )
= ( ord_min @ A @ ( plus_plus @ A @ X @ Z ) @ ( plus_plus @ A @ Y @ Z ) ) ) ) ).
% min_add_distrib_left
thf(fact_5253_min__add__distrib__right,axiom,
! [A: $tType] :
( ( ordere2412721322843649153imp_le @ A )
=> ! [X: A,Y: A,Z: A] :
( ( plus_plus @ A @ X @ ( ord_min @ A @ Y @ Z ) )
= ( ord_min @ A @ ( plus_plus @ A @ X @ Y ) @ ( plus_plus @ A @ X @ Z ) ) ) ) ).
% min_add_distrib_right
thf(fact_5254_min__diff__distrib__left,axiom,
! [A: $tType] :
( ( ordered_ab_group_add @ A )
=> ! [X: A,Y: A,Z: A] :
( ( minus_minus @ A @ ( ord_min @ A @ X @ Y ) @ Z )
= ( ord_min @ A @ ( minus_minus @ A @ X @ Z ) @ ( minus_minus @ A @ Y @ Z ) ) ) ) ).
% min_diff_distrib_left
thf(fact_5255_inf__sup__aci_I8_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A] :
( ( sup_sup @ A @ X @ ( sup_sup @ A @ X @ Y ) )
= ( sup_sup @ A @ X @ Y ) ) ) ).
% inf_sup_aci(8)
thf(fact_5256_inf__sup__aci_I7_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A,Z: A] :
( ( sup_sup @ A @ X @ ( sup_sup @ A @ Y @ Z ) )
= ( sup_sup @ A @ Y @ ( sup_sup @ A @ X @ Z ) ) ) ) ).
% inf_sup_aci(7)
thf(fact_5257_inf__sup__aci_I6_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A,Z: A] :
( ( sup_sup @ A @ ( sup_sup @ A @ X @ Y ) @ Z )
= ( sup_sup @ A @ X @ ( sup_sup @ A @ Y @ Z ) ) ) ) ).
% inf_sup_aci(6)
thf(fact_5258_inf__sup__aci_I5_J,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ( ( sup_sup @ A )
= ( ^ [X2: A,Y2: A] : ( sup_sup @ A @ Y2 @ X2 ) ) ) ) ).
% inf_sup_aci(5)
thf(fact_5259_min_Oassoc,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( ord_min @ A @ ( ord_min @ A @ A3 @ B2 ) @ C2 )
= ( ord_min @ A @ A3 @ ( ord_min @ A @ B2 @ C2 ) ) ) ) ).
% min.assoc
thf(fact_5260_min_Ocommute,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_min @ A )
= ( ^ [A5: A,B4: A] : ( ord_min @ A @ B4 @ A5 ) ) ) ) ).
% min.commute
thf(fact_5261_min_Oleft__commute,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( ord_min @ A @ B2 @ ( ord_min @ A @ A3 @ C2 ) )
= ( ord_min @ A @ A3 @ ( ord_min @ A @ B2 @ C2 ) ) ) ) ).
% min.left_commute
thf(fact_5262_sup_Oassoc,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( sup_sup @ A @ ( sup_sup @ A @ A3 @ B2 ) @ C2 )
= ( sup_sup @ A @ A3 @ ( sup_sup @ A @ B2 @ C2 ) ) ) ) ).
% sup.assoc
thf(fact_5263_sup__assoc,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A,Y: A,Z: A] :
( ( sup_sup @ A @ ( sup_sup @ A @ X @ Y ) @ Z )
= ( sup_sup @ A @ X @ ( sup_sup @ A @ Y @ Z ) ) ) ) ).
% sup_assoc
thf(fact_5264_sup_Ocommute,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ( ( sup_sup @ A )
= ( ^ [A5: A,B4: A] : ( sup_sup @ A @ B4 @ A5 ) ) ) ) ).
% sup.commute
thf(fact_5265_sup__commute,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ( ( sup_sup @ A )
= ( ^ [X2: A,Y2: A] : ( sup_sup @ A @ Y2 @ X2 ) ) ) ) ).
% sup_commute
thf(fact_5266_sup_Oleft__commute,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [B2: A,A3: A,C2: A] :
( ( sup_sup @ A @ B2 @ ( sup_sup @ A @ A3 @ C2 ) )
= ( sup_sup @ A @ A3 @ ( sup_sup @ A @ B2 @ C2 ) ) ) ) ).
% sup.left_commute
thf(fact_5267_sup__left__commute,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A,Y: A,Z: A] :
( ( sup_sup @ A @ X @ ( sup_sup @ A @ Y @ Z ) )
= ( sup_sup @ A @ Y @ ( sup_sup @ A @ X @ Z ) ) ) ) ).
% sup_left_commute
thf(fact_5268_sup__fun__def,axiom,
! [B: $tType,A: $tType] :
( ( semilattice_sup @ B )
=> ( ( sup_sup @ ( A > B ) )
= ( ^ [F3: A > B,G2: A > B,X2: A] : ( sup_sup @ B @ ( F3 @ X2 ) @ ( G2 @ X2 ) ) ) ) ) ).
% sup_fun_def
thf(fact_5269_less__supI1,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A,A3: A,B2: A] :
( ( ord_less @ A @ X @ A3 )
=> ( ord_less @ A @ X @ ( sup_sup @ A @ A3 @ B2 ) ) ) ) ).
% less_supI1
thf(fact_5270_less__supI2,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A,B2: A,A3: A] :
( ( ord_less @ A @ X @ B2 )
=> ( ord_less @ A @ X @ ( sup_sup @ A @ A3 @ B2 ) ) ) ) ).
% less_supI2
thf(fact_5271_sup_Oabsorb3,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [B2: A,A3: A] :
( ( ord_less @ A @ B2 @ A3 )
=> ( ( sup_sup @ A @ A3 @ B2 )
= A3 ) ) ) ).
% sup.absorb3
thf(fact_5272_sup_Oabsorb4,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A3: A,B2: A] :
( ( ord_less @ A @ A3 @ B2 )
=> ( ( sup_sup @ A @ A3 @ B2 )
= B2 ) ) ) ).
% sup.absorb4
thf(fact_5273_sup_Ostrict__boundedE,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [B2: A,C2: A,A3: A] :
( ( ord_less @ A @ ( sup_sup @ A @ B2 @ C2 ) @ A3 )
=> ~ ( ( ord_less @ A @ B2 @ A3 )
=> ~ ( ord_less @ A @ C2 @ A3 ) ) ) ) ).
% sup.strict_boundedE
thf(fact_5274_sup_Ostrict__order__iff,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ( ( ord_less @ A )
= ( ^ [B4: A,A5: A] :
( ( A5
= ( sup_sup @ A @ A5 @ B4 ) )
& ( A5 != B4 ) ) ) ) ) ).
% sup.strict_order_iff
thf(fact_5275_sup_Ostrict__coboundedI1,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( ord_less @ A @ C2 @ A3 )
=> ( ord_less @ A @ C2 @ ( sup_sup @ A @ A3 @ B2 ) ) ) ) ).
% sup.strict_coboundedI1
thf(fact_5276_sup_Ostrict__coboundedI2,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [C2: A,B2: A,A3: A] :
( ( ord_less @ A @ C2 @ B2 )
=> ( ord_less @ A @ C2 @ ( sup_sup @ A @ A3 @ B2 ) ) ) ) ).
% sup.strict_coboundedI2
thf(fact_5277_of__int__min,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [X: int,Y: int] :
( ( ring_1_of_int @ A @ ( ord_min @ int @ X @ Y ) )
= ( ord_min @ A @ ( ring_1_of_int @ A @ X ) @ ( ring_1_of_int @ A @ Y ) ) ) ) ).
% of_int_min
thf(fact_5278_of__nat__min,axiom,
! [A: $tType] :
( ( linord181362715937106298miring @ A )
=> ! [X: nat,Y: nat] :
( ( semiring_1_of_nat @ A @ ( ord_min @ nat @ X @ Y ) )
= ( ord_min @ A @ ( semiring_1_of_nat @ A @ X ) @ ( semiring_1_of_nat @ A @ Y ) ) ) ) ).
% of_nat_min
thf(fact_5279_min__diff,axiom,
! [M: nat,I: nat,N2: nat] :
( ( ord_min @ nat @ ( minus_minus @ nat @ M @ I ) @ ( minus_minus @ nat @ N2 @ I ) )
= ( minus_minus @ nat @ ( ord_min @ nat @ M @ N2 ) @ I ) ) ).
% min_diff
thf(fact_5280_sup__max,axiom,
! [A: $tType] :
( ( ( semilattice_sup @ A )
& ( linorder @ A ) )
=> ( ( sup_sup @ A )
= ( ord_max @ A ) ) ) ).
% sup_max
thf(fact_5281_complete__linorder__sup__max,axiom,
! [A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ( ( sup_sup @ A )
= ( ord_max @ A ) ) ) ).
% complete_linorder_sup_max
thf(fact_5282_inf__min,axiom,
! [A: $tType] :
( ( ( semilattice_inf @ A )
& ( linorder @ A ) )
=> ( ( inf_inf @ A )
= ( ord_min @ A ) ) ) ).
% inf_min
thf(fact_5283_inf__nat__def,axiom,
( ( inf_inf @ nat )
= ( ord_min @ nat ) ) ).
% inf_nat_def
thf(fact_5284_sup__inf__distrib2,axiom,
! [A: $tType] :
( ( distrib_lattice @ A )
=> ! [Y: A,Z: A,X: A] :
( ( sup_sup @ A @ ( inf_inf @ A @ Y @ Z ) @ X )
= ( inf_inf @ A @ ( sup_sup @ A @ Y @ X ) @ ( sup_sup @ A @ Z @ X ) ) ) ) ).
% sup_inf_distrib2
thf(fact_5285_sup__inf__distrib1,axiom,
! [A: $tType] :
( ( distrib_lattice @ A )
=> ! [X: A,Y: A,Z: A] :
( ( sup_sup @ A @ X @ ( inf_inf @ A @ Y @ Z ) )
= ( inf_inf @ A @ ( sup_sup @ A @ X @ Y ) @ ( sup_sup @ A @ X @ Z ) ) ) ) ).
% sup_inf_distrib1
thf(fact_5286_inf__sup__distrib2,axiom,
! [A: $tType] :
( ( distrib_lattice @ A )
=> ! [Y: A,Z: A,X: A] :
( ( inf_inf @ A @ ( sup_sup @ A @ Y @ Z ) @ X )
= ( sup_sup @ A @ ( inf_inf @ A @ Y @ X ) @ ( inf_inf @ A @ Z @ X ) ) ) ) ).
% inf_sup_distrib2
thf(fact_5287_inf__sup__distrib1,axiom,
! [A: $tType] :
( ( distrib_lattice @ A )
=> ! [X: A,Y: A,Z: A] :
( ( inf_inf @ A @ X @ ( sup_sup @ A @ Y @ Z ) )
= ( sup_sup @ A @ ( inf_inf @ A @ X @ Y ) @ ( inf_inf @ A @ X @ Z ) ) ) ) ).
% inf_sup_distrib1
thf(fact_5288_distrib__imp2,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A,Z: A] :
( ! [X5: A,Y4: A,Z2: A] :
( ( sup_sup @ A @ X5 @ ( inf_inf @ A @ Y4 @ Z2 ) )
= ( inf_inf @ A @ ( sup_sup @ A @ X5 @ Y4 ) @ ( sup_sup @ A @ X5 @ Z2 ) ) )
=> ( ( inf_inf @ A @ X @ ( sup_sup @ A @ Y @ Z ) )
= ( sup_sup @ A @ ( inf_inf @ A @ X @ Y ) @ ( inf_inf @ A @ X @ Z ) ) ) ) ) ).
% distrib_imp2
thf(fact_5289_distrib__imp1,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A,Z: A] :
( ! [X5: A,Y4: A,Z2: A] :
( ( inf_inf @ A @ X5 @ ( sup_sup @ A @ Y4 @ Z2 ) )
= ( sup_sup @ A @ ( inf_inf @ A @ X5 @ Y4 ) @ ( inf_inf @ A @ X5 @ Z2 ) ) )
=> ( ( sup_sup @ A @ X @ ( inf_inf @ A @ Y @ Z ) )
= ( inf_inf @ A @ ( sup_sup @ A @ X @ Y ) @ ( sup_sup @ A @ X @ Z ) ) ) ) ) ).
% distrib_imp1
thf(fact_5290_notin__set__nthsI,axiom,
! [A: $tType,X: A,Xs: list @ A,I6: set @ nat] :
( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ~ ( member2 @ A @ X @ ( set2 @ A @ ( nths @ A @ Xs @ I6 ) ) ) ) ).
% notin_set_nthsI
thf(fact_5291_in__set__nthsD,axiom,
! [A: $tType,X: A,Xs: list @ A,I6: set @ nat] :
( ( member2 @ A @ X @ ( set2 @ A @ ( nths @ A @ Xs @ I6 ) ) )
=> ( member2 @ A @ X @ ( set2 @ A @ Xs ) ) ) ).
% in_set_nthsD
thf(fact_5292_min__of__mono,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( linorder @ B ) )
=> ! [F2: A > B,M: A,N2: A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( ord_min @ B @ ( F2 @ M ) @ ( F2 @ N2 ) )
= ( F2 @ ( ord_min @ A @ M @ N2 ) ) ) ) ) ).
% min_of_mono
thf(fact_5293_distrib__inf__le,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A,Z: A] : ( ord_less_eq @ A @ ( sup_sup @ A @ ( inf_inf @ A @ X @ Y ) @ ( inf_inf @ A @ X @ Z ) ) @ ( inf_inf @ A @ X @ ( sup_sup @ A @ Y @ Z ) ) ) ) ).
% distrib_inf_le
thf(fact_5294_distrib__sup__le,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [X: A,Y: A,Z: A] : ( ord_less_eq @ A @ ( sup_sup @ A @ X @ ( inf_inf @ A @ Y @ Z ) ) @ ( inf_inf @ A @ ( sup_sup @ A @ X @ Y ) @ ( sup_sup @ A @ X @ Z ) ) ) ) ).
% distrib_sup_le
thf(fact_5295_minus__max__eq__min,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [X: A,Y: A] :
( ( uminus_uminus @ A @ ( ord_max @ A @ X @ Y ) )
= ( ord_min @ A @ ( uminus_uminus @ A @ X ) @ ( uminus_uminus @ A @ Y ) ) ) ) ).
% minus_max_eq_min
thf(fact_5296_minus__min__eq__max,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [X: A,Y: A] :
( ( uminus_uminus @ A @ ( ord_min @ A @ X @ Y ) )
= ( ord_max @ A @ ( uminus_uminus @ A @ X ) @ ( uminus_uminus @ A @ Y ) ) ) ) ).
% minus_min_eq_max
thf(fact_5297_mono__sup,axiom,
! [B: $tType,A: $tType] :
( ( ( semilattice_sup @ A )
& ( semilattice_sup @ B ) )
=> ! [F2: A > B,A4: A,B3: A] :
( ( order_mono @ A @ B @ F2 )
=> ( ord_less_eq @ B @ ( sup_sup @ B @ ( F2 @ A4 ) @ ( F2 @ B3 ) ) @ ( F2 @ ( sup_sup @ A @ A4 @ B3 ) ) ) ) ) ).
% mono_sup
thf(fact_5298_ivl__disj__un__two__touch_I4_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less_eq @ A @ L @ M )
=> ( ( ord_less_eq @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ L @ M ) @ ( set_or1337092689740270186AtMost @ A @ M @ U ) )
= ( set_or1337092689740270186AtMost @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two_touch(4)
thf(fact_5299_singleton__Un__iff,axiom,
! [A: $tType,X: A,A4: set @ A,B3: set @ A] :
( ( ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) )
= ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( ( ( A4
= ( bot_bot @ ( set @ A ) ) )
& ( B3
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
| ( ( A4
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
& ( B3
= ( bot_bot @ ( set @ A ) ) ) )
| ( ( A4
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
& ( B3
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% singleton_Un_iff
thf(fact_5300_Un__singleton__iff,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,X: A] :
( ( ( sup_sup @ ( set @ A ) @ A4 @ B3 )
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( ( ( A4
= ( bot_bot @ ( set @ A ) ) )
& ( B3
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
| ( ( A4
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
& ( B3
= ( bot_bot @ ( set @ A ) ) ) )
| ( ( A4
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
& ( B3
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% Un_singleton_iff
thf(fact_5301_insert__is__Un,axiom,
! [A: $tType] :
( ( insert2 @ A )
= ( ^ [A5: A] : ( sup_sup @ ( set @ A ) @ ( insert2 @ A @ A5 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% insert_is_Un
thf(fact_5302_ivl__disj__un__two_I3_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less_eq @ A @ L @ M )
=> ( ( ord_less_eq @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ L @ M ) @ ( set_or7035219750837199246ssThan @ A @ M @ U ) )
= ( set_or7035219750837199246ssThan @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two(3)
thf(fact_5303_Un__Int__assoc__eq,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,C5: set @ A] :
( ( ( sup_sup @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) @ C5 )
= ( inf_inf @ ( set @ A ) @ A4 @ ( sup_sup @ ( set @ A ) @ B3 @ C5 ) ) )
= ( ord_less_eq @ ( set @ A ) @ C5 @ A4 ) ) ).
% Un_Int_assoc_eq
thf(fact_5304_Diff__partition,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( sup_sup @ ( set @ A ) @ A4 @ ( minus_minus @ ( set @ A ) @ B3 @ A4 ) )
= B3 ) ) ).
% Diff_partition
thf(fact_5305_Diff__subset__conv,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,C5: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) @ C5 )
= ( ord_less_eq @ ( set @ A ) @ A4 @ ( sup_sup @ ( set @ A ) @ B3 @ C5 ) ) ) ).
% Diff_subset_conv
thf(fact_5306_ivl__disj__un__two_I6_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less_eq @ A @ L @ M )
=> ( ( ord_less_eq @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ L @ M ) @ ( set_or3652927894154168847AtMost @ A @ M @ U ) )
= ( set_or3652927894154168847AtMost @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two(6)
thf(fact_5307_max__of__antimono,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( linorder @ B ) )
=> ! [F2: A > B,X: A,Y: A] :
( ( order_antimono @ A @ B @ F2 )
=> ( ( ord_max @ B @ ( F2 @ X ) @ ( F2 @ Y ) )
= ( F2 @ ( ord_min @ A @ X @ Y ) ) ) ) ) ).
% max_of_antimono
thf(fact_5308_min__of__antimono,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( linorder @ B ) )
=> ! [F2: A > B,X: A,Y: A] :
( ( order_antimono @ A @ B @ F2 )
=> ( ( ord_min @ B @ ( F2 @ X ) @ ( F2 @ Y ) )
= ( F2 @ ( ord_max @ A @ X @ Y ) ) ) ) ) ).
% min_of_antimono
thf(fact_5309_set__shuffles,axiom,
! [A: $tType,Zs: list @ A,Xs: list @ A,Ys: list @ A] :
( ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ Xs @ Ys ) )
=> ( ( set2 @ A @ Zs )
= ( sup_sup @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ Ys ) ) ) ) ).
% set_shuffles
thf(fact_5310_mono__Un,axiom,
! [B: $tType,A: $tType,F2: ( set @ A ) > ( set @ B ),A4: set @ A,B3: set @ A] :
( ( order_mono @ ( set @ A ) @ ( set @ B ) @ F2 )
=> ( ord_less_eq @ ( set @ B ) @ ( sup_sup @ ( set @ B ) @ ( F2 @ A4 ) @ ( F2 @ B3 ) ) @ ( F2 @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) ) ) ) ).
% mono_Un
thf(fact_5311_set__nths__subset,axiom,
! [A: $tType,Xs: list @ A,I6: set @ nat] : ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ ( nths @ A @ Xs @ I6 ) ) @ ( set2 @ A @ Xs ) ) ).
% set_nths_subset
thf(fact_5312_nths__all,axiom,
! [A: $tType,Xs: list @ A,I6: set @ nat] :
( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( member2 @ nat @ I3 @ I6 ) )
=> ( ( nths @ A @ Xs @ I6 )
= Xs ) ) ).
% nths_all
thf(fact_5313_sup__shunt,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A] :
( ( ( sup_sup @ A @ X @ Y )
= ( top_top @ A ) )
= ( ord_less_eq @ A @ ( uminus_uminus @ A @ X ) @ Y ) ) ) ).
% sup_shunt
thf(fact_5314_shunt1,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less_eq @ A @ ( inf_inf @ A @ X @ Y ) @ Z )
= ( ord_less_eq @ A @ X @ ( sup_sup @ A @ ( uminus_uminus @ A @ Y ) @ Z ) ) ) ) ).
% shunt1
thf(fact_5315_shunt2,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A,Z: A] :
( ( ord_less_eq @ A @ ( inf_inf @ A @ X @ ( uminus_uminus @ A @ Y ) ) @ Z )
= ( ord_less_eq @ A @ X @ ( sup_sup @ A @ Y @ Z ) ) ) ) ).
% shunt2
thf(fact_5316_sup__neg__inf,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [P4: A,Q2: A,R2: A] :
( ( ord_less_eq @ A @ P4 @ ( sup_sup @ A @ Q2 @ R2 ) )
= ( ord_less_eq @ A @ ( inf_inf @ A @ P4 @ ( uminus_uminus @ A @ Q2 ) ) @ R2 ) ) ) ).
% sup_neg_inf
thf(fact_5317_boolean__algebra_Ocomplement__unique,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [A3: A,X: A,Y: A] :
( ( ( inf_inf @ A @ A3 @ X )
= ( bot_bot @ A ) )
=> ( ( ( sup_sup @ A @ A3 @ X )
= ( top_top @ A ) )
=> ( ( ( inf_inf @ A @ A3 @ Y )
= ( bot_bot @ A ) )
=> ( ( ( sup_sup @ A @ A3 @ Y )
= ( top_top @ A ) )
=> ( X = Y ) ) ) ) ) ) ).
% boolean_algebra.complement_unique
thf(fact_5318_finite__Sup__in,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ( member2 @ A @ Y4 @ A4 )
=> ( member2 @ A @ ( sup_sup @ A @ X5 @ Y4 ) @ A4 ) ) )
=> ( member2 @ A @ ( complete_Sup_Sup @ A @ A4 ) @ A4 ) ) ) ) ) ).
% finite_Sup_in
thf(fact_5319_less__eq__Inf__inter,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A,B3: set @ A] : ( ord_less_eq @ A @ ( sup_sup @ A @ ( complete_Inf_Inf @ A @ A4 ) @ ( complete_Inf_Inf @ A @ B3 ) ) @ ( complete_Inf_Inf @ A @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) ) ) ).
% less_eq_Inf_inter
thf(fact_5320_zip__obtain__same__length,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,P2: ( list @ ( product_prod @ A @ B ) ) > $o] :
( ! [Zs2: list @ A,Ws: list @ B,N3: nat] :
( ( ( size_size @ ( list @ A ) @ Zs2 )
= ( size_size @ ( list @ B ) @ Ws ) )
=> ( ( N3
= ( ord_min @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ B ) @ Ys ) ) )
=> ( ( Zs2
= ( take @ A @ N3 @ Xs ) )
=> ( ( Ws
= ( take @ B @ N3 @ Ys ) )
=> ( P2 @ ( zip @ A @ B @ Zs2 @ Ws ) ) ) ) ) )
=> ( P2 @ ( zip @ A @ B @ Xs @ Ys ) ) ) ).
% zip_obtain_same_length
thf(fact_5321_ivl__disj__un__two_I7_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less_eq @ A @ L @ M )
=> ( ( ord_less_eq @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ L @ M ) @ ( set_or1337092689740270186AtMost @ A @ M @ U ) )
= ( set_or1337092689740270186AtMost @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two(7)
thf(fact_5322_ivl__disj__un__one_I2_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less_eq @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_ord_lessThan @ A @ L ) @ ( set_or7035219750837199246ssThan @ A @ L @ U ) )
= ( set_ord_lessThan @ A @ U ) ) ) ) ).
% ivl_disj_un_one(2)
thf(fact_5323_Union__image__empty,axiom,
! [B: $tType,A: $tType,A4: set @ A,F2: B > ( set @ A )] :
( ( sup_sup @ ( set @ A ) @ A4 @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ F2 @ ( bot_bot @ ( set @ B ) ) ) ) )
= A4 ) ).
% Union_image_empty
thf(fact_5324_card__Un__le,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] : ( ord_less_eq @ nat @ ( finite_card @ A @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) ) @ ( plus_plus @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ B3 ) ) ) ).
% card_Un_le
thf(fact_5325_atLeastLessThan__add__Un,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( set_or7035219750837199246ssThan @ nat @ I @ ( plus_plus @ nat @ J @ K ) )
= ( sup_sup @ ( set @ nat ) @ ( set_or7035219750837199246ssThan @ nat @ I @ J ) @ ( set_or7035219750837199246ssThan @ nat @ J @ ( plus_plus @ nat @ J @ K ) ) ) ) ) ).
% atLeastLessThan_add_Un
thf(fact_5326_ivl__disj__un__two_I8_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less_eq @ A @ L @ M )
=> ( ( ord_less_eq @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ L @ M ) @ ( set_or3652927894154168847AtMost @ A @ M @ U ) )
= ( set_or1337092689740270186AtMost @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two(8)
thf(fact_5327_ivl__disj__un__one_I8_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less_eq @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ L @ U ) @ ( set_ord_atLeast @ A @ U ) )
= ( set_ord_atLeast @ A @ L ) ) ) ) ).
% ivl_disj_un_one(8)
thf(fact_5328_ivl__disj__un__one_I3_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less_eq @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_ord_atMost @ A @ L ) @ ( set_or3652927894154168847AtMost @ A @ L @ U ) )
= ( set_ord_atMost @ A @ U ) ) ) ) ).
% ivl_disj_un_one(3)
thf(fact_5329_ivl__disj__un__one_I5_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less_eq @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ L @ U ) @ ( set_ord_greaterThan @ A @ U ) )
= ( set_ord_greaterThan @ A @ L ) ) ) ) ).
% ivl_disj_un_one(5)
thf(fact_5330_UN__extend__simps_I3_J,axiom,
! [E2: $tType,F: $tType,C5: set @ F,A4: set @ E2,B3: F > ( set @ E2 )] :
( ( ( C5
= ( bot_bot @ ( set @ F ) ) )
=> ( ( sup_sup @ ( set @ E2 ) @ A4 @ ( complete_Sup_Sup @ ( set @ E2 ) @ ( image2 @ F @ ( set @ E2 ) @ B3 @ C5 ) ) )
= A4 ) )
& ( ( C5
!= ( bot_bot @ ( set @ F ) ) )
=> ( ( sup_sup @ ( set @ E2 ) @ A4 @ ( complete_Sup_Sup @ ( set @ E2 ) @ ( image2 @ F @ ( set @ E2 ) @ B3 @ C5 ) ) )
= ( complete_Sup_Sup @ ( set @ E2 )
@ ( image2 @ F @ ( set @ E2 )
@ ^ [X2: F] : ( sup_sup @ ( set @ E2 ) @ A4 @ ( B3 @ X2 ) )
@ C5 ) ) ) ) ) ).
% UN_extend_simps(3)
thf(fact_5331_UN__extend__simps_I2_J,axiom,
! [D: $tType,C: $tType,C5: set @ C,A4: C > ( set @ D ),B3: set @ D] :
( ( ( C5
= ( bot_bot @ ( set @ C ) ) )
=> ( ( sup_sup @ ( set @ D ) @ ( complete_Sup_Sup @ ( set @ D ) @ ( image2 @ C @ ( set @ D ) @ A4 @ C5 ) ) @ B3 )
= B3 ) )
& ( ( C5
!= ( bot_bot @ ( set @ C ) ) )
=> ( ( sup_sup @ ( set @ D ) @ ( complete_Sup_Sup @ ( set @ D ) @ ( image2 @ C @ ( set @ D ) @ A4 @ C5 ) ) @ B3 )
= ( complete_Sup_Sup @ ( set @ D )
@ ( image2 @ C @ ( set @ D )
@ ^ [X2: C] : ( sup_sup @ ( set @ D ) @ ( A4 @ X2 ) @ B3 )
@ C5 ) ) ) ) ) ).
% UN_extend_simps(2)
thf(fact_5332_Inter__Un__subset,axiom,
! [A: $tType,A4: set @ ( set @ A ),B3: set @ ( set @ A )] : ( ord_less_eq @ ( set @ A ) @ ( sup_sup @ ( set @ A ) @ ( complete_Inf_Inf @ ( set @ A ) @ A4 ) @ ( complete_Inf_Inf @ ( set @ A ) @ B3 ) ) @ ( complete_Inf_Inf @ ( set @ A ) @ ( inf_inf @ ( set @ ( set @ A ) ) @ A4 @ B3 ) ) ) ).
% Inter_Un_subset
thf(fact_5333_min__mult__distrib__right,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [P4: A,X: A,Y: A] :
( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( times_times @ A @ ( ord_min @ A @ X @ Y ) @ P4 )
= ( ord_min @ A @ ( times_times @ A @ X @ P4 ) @ ( times_times @ A @ Y @ P4 ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( times_times @ A @ ( ord_min @ A @ X @ Y ) @ P4 )
= ( ord_max @ A @ ( times_times @ A @ X @ P4 ) @ ( times_times @ A @ Y @ P4 ) ) ) ) ) ) ).
% min_mult_distrib_right
thf(fact_5334_max__mult__distrib__right,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [P4: A,X: A,Y: A] :
( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( times_times @ A @ ( ord_max @ A @ X @ Y ) @ P4 )
= ( ord_max @ A @ ( times_times @ A @ X @ P4 ) @ ( times_times @ A @ Y @ P4 ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( times_times @ A @ ( ord_max @ A @ X @ Y ) @ P4 )
= ( ord_min @ A @ ( times_times @ A @ X @ P4 ) @ ( times_times @ A @ Y @ P4 ) ) ) ) ) ) ).
% max_mult_distrib_right
thf(fact_5335_min__mult__distrib__left,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [P4: A,X: A,Y: A] :
( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( times_times @ A @ P4 @ ( ord_min @ A @ X @ Y ) )
= ( ord_min @ A @ ( times_times @ A @ P4 @ X ) @ ( times_times @ A @ P4 @ Y ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( times_times @ A @ P4 @ ( ord_min @ A @ X @ Y ) )
= ( ord_max @ A @ ( times_times @ A @ P4 @ X ) @ ( times_times @ A @ P4 @ Y ) ) ) ) ) ) ).
% min_mult_distrib_left
thf(fact_5336_max__mult__distrib__left,axiom,
! [A: $tType] :
( ( linordered_idom @ A )
=> ! [P4: A,X: A,Y: A] :
( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( times_times @ A @ P4 @ ( ord_max @ A @ X @ Y ) )
= ( ord_max @ A @ ( times_times @ A @ P4 @ X ) @ ( times_times @ A @ P4 @ Y ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( times_times @ A @ P4 @ ( ord_max @ A @ X @ Y ) )
= ( ord_min @ A @ ( times_times @ A @ P4 @ X ) @ ( times_times @ A @ P4 @ Y ) ) ) ) ) ) ).
% max_mult_distrib_left
thf(fact_5337_min__divide__distrib__right,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [P4: A,X: A,Y: A] :
( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( divide_divide @ A @ ( ord_min @ A @ X @ Y ) @ P4 )
= ( ord_min @ A @ ( divide_divide @ A @ X @ P4 ) @ ( divide_divide @ A @ Y @ P4 ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( divide_divide @ A @ ( ord_min @ A @ X @ Y ) @ P4 )
= ( ord_max @ A @ ( divide_divide @ A @ X @ P4 ) @ ( divide_divide @ A @ Y @ P4 ) ) ) ) ) ) ).
% min_divide_distrib_right
thf(fact_5338_max__divide__distrib__right,axiom,
! [A: $tType] :
( ( linordered_field @ A )
=> ! [P4: A,X: A,Y: A] :
( ( ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( divide_divide @ A @ ( ord_max @ A @ X @ Y ) @ P4 )
= ( ord_max @ A @ ( divide_divide @ A @ X @ P4 ) @ ( divide_divide @ A @ Y @ P4 ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( zero_zero @ A ) @ P4 )
=> ( ( divide_divide @ A @ ( ord_max @ A @ X @ Y ) @ P4 )
= ( ord_min @ A @ ( divide_divide @ A @ X @ P4 ) @ ( divide_divide @ A @ Y @ P4 ) ) ) ) ) ) ).
% max_divide_distrib_right
thf(fact_5339_min__Suc1,axiom,
! [N2: nat,M: nat] :
( ( ord_min @ nat @ ( suc @ N2 ) @ M )
= ( case_nat @ nat @ ( zero_zero @ nat )
@ ^ [M5: nat] : ( suc @ ( ord_min @ nat @ N2 @ M5 ) )
@ M ) ) ).
% min_Suc1
thf(fact_5340_min__Suc2,axiom,
! [M: nat,N2: nat] :
( ( ord_min @ nat @ M @ ( suc @ N2 ) )
= ( case_nat @ nat @ ( zero_zero @ nat )
@ ^ [M5: nat] : ( suc @ ( ord_min @ nat @ M5 @ N2 ) )
@ M ) ) ).
% min_Suc2
thf(fact_5341_Inf__insert__finite,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [S3: set @ A,X: A] :
( ( finite_finite @ A @ S3 )
=> ( ( ( S3
= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Inf_Inf @ A @ ( insert2 @ A @ X @ S3 ) )
= X ) )
& ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Inf_Inf @ A @ ( insert2 @ A @ X @ S3 ) )
= ( ord_min @ A @ X @ ( complete_Inf_Inf @ A @ S3 ) ) ) ) ) ) ) ).
% Inf_insert_finite
thf(fact_5342_boolean__algebra__class_Oboolean__algebra_Ocompl__unique,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ! [X: A,Y: A] :
( ( ( inf_inf @ A @ X @ Y )
= ( bot_bot @ A ) )
=> ( ( ( sup_sup @ A @ X @ Y )
= ( top_top @ A ) )
=> ( ( uminus_uminus @ A @ X )
= Y ) ) ) ) ).
% boolean_algebra_class.boolean_algebra.compl_unique
thf(fact_5343_ivl__disj__un__two__touch_I2_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less_eq @ A @ L @ M )
=> ( ( ord_less @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ L @ M ) @ ( set_or7035219750837199246ssThan @ A @ M @ U ) )
= ( set_or7035219750837199246ssThan @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two_touch(2)
thf(fact_5344_sum_Ounion__inter,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,B3: set @ B,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ G @ ( sup_sup @ ( set @ B ) @ A4 @ B3 ) ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ ( inf_inf @ ( set @ B ) @ A4 @ B3 ) ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ B3 ) ) ) ) ) ) ).
% sum.union_inter
thf(fact_5345_card__Un__Int,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ A @ B3 )
=> ( ( plus_plus @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ B3 ) )
= ( plus_plus @ nat @ ( finite_card @ A @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) ) @ ( finite_card @ A @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) ) ) ) ) ).
% card_Un_Int
thf(fact_5346_ivl__disj__un__two__touch_I3_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less @ A @ L @ M )
=> ( ( ord_less_eq @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ L @ M ) @ ( set_or1337092689740270186AtMost @ A @ M @ U ) )
= ( set_or3652927894154168847AtMost @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two_touch(3)
thf(fact_5347_ivl__disj__un__two_I1_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less @ A @ L @ M )
=> ( ( ord_less_eq @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ L @ M ) @ ( set_or7035219750837199246ssThan @ A @ M @ U ) )
= ( set_or5935395276787703475ssThan @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two(1)
thf(fact_5348_ivl__disj__un__one_I4_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less_eq @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_ord_lessThan @ A @ L ) @ ( set_or1337092689740270186AtMost @ A @ L @ U ) )
= ( set_ord_atMost @ A @ U ) ) ) ) ).
% ivl_disj_un_one(4)
thf(fact_5349_ivl__disj__un__singleton_I2_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [U: A] :
( ( sup_sup @ ( set @ A ) @ ( set_ord_lessThan @ A @ U ) @ ( insert2 @ A @ U @ ( bot_bot @ ( set @ A ) ) ) )
= ( set_ord_atMost @ A @ U ) ) ) ).
% ivl_disj_un_singleton(2)
thf(fact_5350_ivl__disj__un__two_I2_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less_eq @ A @ L @ M )
=> ( ( ord_less @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ L @ M ) @ ( set_or5935395276787703475ssThan @ A @ M @ U ) )
= ( set_or5935395276787703475ssThan @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two(2)
thf(fact_5351_Max_Ounion,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798349783984er_Max @ A @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( ord_max @ A @ ( lattic643756798349783984er_Max @ A @ A4 ) @ ( lattic643756798349783984er_Max @ A @ B3 ) ) ) ) ) ) ) ) ).
% Max.union
thf(fact_5352_ivl__disj__un__one_I1_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_ord_atMost @ A @ L ) @ ( set_or5935395276787703475ssThan @ A @ L @ U ) )
= ( set_ord_lessThan @ A @ U ) ) ) ) ).
% ivl_disj_un_one(1)
thf(fact_5353_ivl__disj__un__one_I7_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less_eq @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ L @ U ) @ ( set_ord_greaterThan @ A @ U ) )
= ( set_ord_atLeast @ A @ L ) ) ) ) ).
% ivl_disj_un_one(7)
thf(fact_5354_ivl__disj__un__singleton_I1_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A] :
( ( sup_sup @ ( set @ A ) @ ( insert2 @ A @ L @ ( bot_bot @ ( set @ A ) ) ) @ ( set_ord_greaterThan @ A @ L ) )
= ( set_ord_atLeast @ A @ L ) ) ) ).
% ivl_disj_un_singleton(1)
thf(fact_5355_ivl__disj__un__two__touch_I1_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less @ A @ L @ M )
=> ( ( ord_less @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or3652927894154168847AtMost @ A @ L @ M ) @ ( set_or7035219750837199246ssThan @ A @ M @ U ) )
= ( set_or5935395276787703475ssThan @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two_touch(1)
thf(fact_5356_SUP__nat__binary,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: A,B3: A] :
( ( sup_sup @ A @ A4
@ ( complete_Sup_Sup @ A
@ ( image2 @ nat @ A
@ ^ [X2: nat] : B3
@ ( collect @ nat @ ( ord_less @ nat @ ( zero_zero @ nat ) ) ) ) ) )
= ( sup_sup @ A @ A4 @ B3 ) ) ) ).
% SUP_nat_binary
thf(fact_5357_ivl__disj__un__one_I6_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ L @ U ) @ ( set_ord_atLeast @ A @ U ) )
= ( set_ord_greaterThan @ A @ L ) ) ) ) ).
% ivl_disj_un_one(6)
thf(fact_5358_inj__on__disjoint__Un,axiom,
! [B: $tType,A: $tType,F2: A > B,A4: set @ A,G: A > B,B3: set @ A] :
( ( inj_on @ A @ B @ F2 @ A4 )
=> ( ( inj_on @ A @ B @ G @ B3 )
=> ( ( ( inf_inf @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ ( image2 @ A @ B @ G @ B3 ) )
= ( bot_bot @ ( set @ B ) ) )
=> ( inj_on @ A @ B
@ ^ [X2: A] : ( if @ B @ ( member2 @ A @ X2 @ A4 ) @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) ) ) ) ) ).
% inj_on_disjoint_Un
thf(fact_5359_sup__bot_Osemilattice__neutr__order__axioms,axiom,
! [A: $tType] :
( ( bounde4967611905675639751up_bot @ A )
=> ( semila1105856199041335345_order @ A @ ( sup_sup @ A ) @ ( bot_bot @ A )
@ ^ [X2: A,Y2: A] : ( ord_less_eq @ A @ Y2 @ X2 )
@ ^ [X2: A,Y2: A] : ( ord_less @ A @ Y2 @ X2 ) ) ) ).
% sup_bot.semilattice_neutr_order_axioms
thf(fact_5360_length__nths,axiom,
! [A: $tType,Xs: list @ A,I6: set @ nat] :
( ( size_size @ ( list @ A ) @ ( nths @ A @ Xs @ I6 ) )
= ( finite_card @ nat
@ ( collect @ nat
@ ^ [I5: nat] :
( ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs ) )
& ( member2 @ nat @ I5 @ I6 ) ) ) ) ) ).
% length_nths
thf(fact_5361_sum_Ounion__inter__neutral,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,B3: set @ B,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( inf_inf @ ( set @ B ) @ A4 @ B3 ) )
=> ( ( G @ X5 )
= ( zero_zero @ A ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( sup_sup @ ( set @ B ) @ A4 @ B3 ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ B3 ) ) ) ) ) ) ) ).
% sum.union_inter_neutral
thf(fact_5362_sum__Un,axiom,
! [A: $tType,B: $tType] :
( ( ab_group_add @ A )
=> ! [A4: set @ B,B3: set @ B,F2: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ F2 @ ( sup_sup @ ( set @ B ) @ A4 @ B3 ) )
= ( minus_minus @ A @ ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ A4 ) @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ B3 ) ) @ ( groups7311177749621191930dd_sum @ B @ A @ F2 @ ( inf_inf @ ( set @ B ) @ A4 @ B3 ) ) ) ) ) ) ) ).
% sum_Un
thf(fact_5363_sum_Ounion__disjoint,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,B3: set @ B,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ( ( inf_inf @ ( set @ B ) @ A4 @ B3 )
= ( bot_bot @ ( set @ B ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( sup_sup @ ( set @ B ) @ A4 @ B3 ) )
= ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ G @ A4 ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ B3 ) ) ) ) ) ) ) ).
% sum.union_disjoint
thf(fact_5364_prod_Ounion__disjoint,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [A4: set @ B,B3: set @ B,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ( ( inf_inf @ ( set @ B ) @ A4 @ B3 )
= ( bot_bot @ ( set @ B ) ) )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ ( sup_sup @ ( set @ B ) @ A4 @ B3 ) )
= ( times_times @ A @ ( groups7121269368397514597t_prod @ B @ A @ G @ A4 ) @ ( groups7121269368397514597t_prod @ B @ A @ G @ B3 ) ) ) ) ) ) ) ).
% prod.union_disjoint
thf(fact_5365_ivl__disj__un__singleton_I6_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less_eq @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or7035219750837199246ssThan @ A @ L @ U ) @ ( insert2 @ A @ U @ ( bot_bot @ ( set @ A ) ) ) )
= ( set_or1337092689740270186AtMost @ A @ L @ U ) ) ) ) ).
% ivl_disj_un_singleton(6)
thf(fact_5366_sum_Ounion__diff2,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [A4: set @ B,B3: set @ B,G: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( sup_sup @ ( set @ B ) @ A4 @ B3 ) )
= ( plus_plus @ A @ ( plus_plus @ A @ ( groups7311177749621191930dd_sum @ B @ A @ G @ ( minus_minus @ ( set @ B ) @ A4 @ B3 ) ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ ( minus_minus @ ( set @ B ) @ B3 @ A4 ) ) ) @ ( groups7311177749621191930dd_sum @ B @ A @ G @ ( inf_inf @ ( set @ B ) @ A4 @ B3 ) ) ) ) ) ) ) ).
% sum.union_diff2
thf(fact_5367_sum__Un2,axiom,
! [B: $tType,A: $tType] :
( ( comm_monoid_add @ B )
=> ! [A4: set @ A,B3: set @ A,F2: A > B] :
( ( finite_finite @ A @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
=> ( ( groups7311177749621191930dd_sum @ A @ B @ F2 @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( plus_plus @ B @ ( plus_plus @ B @ ( groups7311177749621191930dd_sum @ A @ B @ F2 @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) ) @ ( groups7311177749621191930dd_sum @ A @ B @ F2 @ ( minus_minus @ ( set @ A ) @ B3 @ A4 ) ) ) @ ( groups7311177749621191930dd_sum @ A @ B @ F2 @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) ) ) ) ) ).
% sum_Un2
thf(fact_5368_card__Un__disjoint,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ A @ B3 )
=> ( ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_card @ A @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( plus_plus @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ B3 ) ) ) ) ) ) ).
% card_Un_disjoint
thf(fact_5369_inj__on__Un,axiom,
! [A: $tType,B: $tType,F2: A > B,A4: set @ A,B3: set @ A] :
( ( inj_on @ A @ B @ F2 @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( ( inj_on @ A @ B @ F2 @ A4 )
& ( inj_on @ A @ B @ F2 @ B3 )
& ( ( inf_inf @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ ( minus_minus @ ( set @ A ) @ A4 @ B3 ) ) @ ( image2 @ A @ B @ F2 @ ( minus_minus @ ( set @ A ) @ B3 @ A4 ) ) )
= ( bot_bot @ ( set @ B ) ) ) ) ) ).
% inj_on_Un
thf(fact_5370_ivl__disj__un__singleton_I5_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less_eq @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( insert2 @ A @ L @ ( bot_bot @ ( set @ A ) ) ) @ ( set_or3652927894154168847AtMost @ A @ L @ U ) )
= ( set_or1337092689740270186AtMost @ A @ L @ U ) ) ) ) ).
% ivl_disj_un_singleton(5)
thf(fact_5371_ivl__disj__un__two_I4_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less_eq @ A @ L @ M )
=> ( ( ord_less @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ L @ M ) @ ( set_or5935395276787703475ssThan @ A @ M @ U ) )
= ( set_or7035219750837199246ssThan @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two(4)
thf(fact_5372_ivl__disj__un__singleton_I3_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( insert2 @ A @ L @ ( bot_bot @ ( set @ A ) ) ) @ ( set_or5935395276787703475ssThan @ A @ L @ U ) )
= ( set_or7035219750837199246ssThan @ A @ L @ U ) ) ) ) ).
% ivl_disj_un_singleton(3)
thf(fact_5373_sum__Un__nat,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,F2: A > nat] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ A @ B3 )
=> ( ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( minus_minus @ nat @ ( plus_plus @ nat @ ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ A4 ) @ ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ B3 ) ) @ ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) ) ) ) ) ).
% sum_Un_nat
thf(fact_5374_ivl__disj__un__two_I5_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,M: A,U: A] :
( ( ord_less @ A @ L @ M )
=> ( ( ord_less_eq @ A @ M @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ L @ M ) @ ( set_or1337092689740270186AtMost @ A @ M @ U ) )
= ( set_or3652927894154168847AtMost @ A @ L @ U ) ) ) ) ) ).
% ivl_disj_un_two(5)
thf(fact_5375_ivl__disj__un__singleton_I4_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: A,U: A] :
( ( ord_less @ A @ L @ U )
=> ( ( sup_sup @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ L @ U ) @ ( insert2 @ A @ U @ ( bot_bot @ ( set @ A ) ) ) )
= ( set_or3652927894154168847AtMost @ A @ L @ U ) ) ) ) ).
% ivl_disj_un_singleton(4)
thf(fact_5376_prod__Un,axiom,
! [A: $tType,B: $tType] :
( ( field @ A )
=> ! [A4: set @ B,B3: set @ B,F2: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( inf_inf @ ( set @ B ) @ A4 @ B3 ) )
=> ( ( F2 @ X5 )
!= ( zero_zero @ A ) ) )
=> ( ( groups7121269368397514597t_prod @ B @ A @ F2 @ ( sup_sup @ ( set @ B ) @ A4 @ B3 ) )
= ( divide_divide @ A @ ( times_times @ A @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ A4 ) @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ B3 ) ) @ ( groups7121269368397514597t_prod @ B @ A @ F2 @ ( inf_inf @ ( set @ B ) @ A4 @ B3 ) ) ) ) ) ) ) ) ).
% prod_Un
thf(fact_5377_If__the__inv__into__in__Func,axiom,
! [B: $tType,A: $tType,G: A > B,C5: set @ A,B3: set @ A,X: A] :
( ( inj_on @ A @ B @ G @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ C5 @ ( sup_sup @ ( set @ A ) @ B3 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( member2 @ ( B > A )
@ ^ [I5: B] : ( if @ A @ ( member2 @ B @ I5 @ ( image2 @ A @ B @ G @ C5 ) ) @ ( the_inv_into @ A @ B @ C5 @ G @ I5 ) @ X )
@ ( bNF_Wellorder_Func @ B @ A @ ( top_top @ ( set @ B ) ) @ ( sup_sup @ ( set @ A ) @ B3 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% If_the_inv_into_in_Func
thf(fact_5378_lexord__take__index__conv,axiom,
! [A: $tType,X: list @ A,Y: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Y ) @ ( lexord @ A @ R2 ) )
= ( ( ( ord_less @ nat @ ( size_size @ ( list @ A ) @ X ) @ ( size_size @ ( list @ A ) @ Y ) )
& ( ( take @ A @ ( size_size @ ( list @ A ) @ X ) @ Y )
= X ) )
| ? [I5: nat] :
( ( ord_less @ nat @ I5 @ ( ord_min @ nat @ ( size_size @ ( list @ A ) @ X ) @ ( size_size @ ( list @ A ) @ Y ) ) )
& ( ( take @ A @ I5 @ X )
= ( take @ A @ I5 @ Y ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ ( nth @ A @ X @ I5 ) @ ( nth @ A @ Y @ I5 ) ) @ R2 ) ) ) ) ).
% lexord_take_index_conv
thf(fact_5379_UNION__fun__upd,axiom,
! [B: $tType,A: $tType,A4: B > ( set @ A ),I: B,B3: set @ A,J4: set @ B] :
( ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ ( fun_upd @ B @ ( set @ A ) @ A4 @ I @ B3 ) @ J4 ) )
= ( sup_sup @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ B @ ( set @ A ) @ A4 @ ( minus_minus @ ( set @ B ) @ J4 @ ( insert2 @ B @ I @ ( bot_bot @ ( set @ B ) ) ) ) ) ) @ ( if @ ( set @ A ) @ ( member2 @ B @ I @ J4 ) @ B3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% UNION_fun_upd
thf(fact_5380_sup__Un__eq2,axiom,
! [B: $tType,A: $tType,R: set @ ( product_prod @ A @ B ),S3: set @ ( product_prod @ A @ B )] :
( ( sup_sup @ ( A > B > $o )
@ ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R )
@ ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ S3 ) )
= ( ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( sup_sup @ ( set @ ( product_prod @ A @ B ) ) @ R @ S3 ) ) ) ) ).
% sup_Un_eq2
thf(fact_5381_sup__int__def,axiom,
( ( sup_sup @ int )
= ( ord_max @ int ) ) ).
% sup_int_def
thf(fact_5382_sup__nat__def,axiom,
( ( sup_sup @ nat )
= ( ord_max @ nat ) ) ).
% sup_nat_def
thf(fact_5383_inf__int__def,axiom,
( ( inf_inf @ int )
= ( ord_min @ int ) ) ).
% inf_int_def
thf(fact_5384_lexord__irreflexive,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),Xs: list @ A] :
( ! [X5: A] :
~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ X5 ) @ R2 )
=> ~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Xs ) @ ( lexord @ A @ R2 ) ) ) ).
% lexord_irreflexive
thf(fact_5385_lexord__linear,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),X: list @ A,Y: list @ A] :
( ! [A7: A,B5: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A7 @ B5 ) @ R2 )
| ( A7 = B5 )
| ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B5 @ A7 ) @ R2 ) )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Y ) @ ( lexord @ A @ R2 ) )
| ( X = Y )
| ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Y @ X ) @ ( lexord @ A @ R2 ) ) ) ) ).
% lexord_linear
thf(fact_5386_lexord__Nil__right,axiom,
! [A: $tType,X: list @ A,R2: set @ ( product_prod @ A @ A )] :
~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ ( nil @ A ) ) @ ( lexord @ A @ R2 ) ) ).
% lexord_Nil_right
thf(fact_5387_lexord__partial__trans,axiom,
! [A: $tType,Xs: list @ A,R2: set @ ( product_prod @ A @ A ),Ys: list @ A,Zs: list @ A] :
( ! [X5: A,Y4: A,Z2: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Y4 ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z2 ) @ R2 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Z2 ) @ R2 ) ) ) )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( lexord @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Ys @ Zs ) @ ( lexord @ A @ R2 ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Zs ) @ ( lexord @ A @ R2 ) ) ) ) ) ).
% lexord_partial_trans
thf(fact_5388_lexord__lex,axiom,
! [A: $tType,X: list @ A,Y: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Y ) @ ( lex @ A @ R2 ) )
= ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Y ) @ ( lexord @ A @ R2 ) )
& ( ( size_size @ ( list @ A ) @ X )
= ( size_size @ ( list @ A ) @ Y ) ) ) ) ).
% lexord_lex
thf(fact_5389_fun__upd__image,axiom,
! [A: $tType,B: $tType,X: B,A4: set @ B,F2: B > A,Y: A] :
( ( ( member2 @ B @ X @ A4 )
=> ( ( image2 @ B @ A @ ( fun_upd @ B @ A @ F2 @ X @ Y ) @ A4 )
= ( insert2 @ A @ Y @ ( image2 @ B @ A @ F2 @ ( minus_minus @ ( set @ B ) @ A4 @ ( insert2 @ B @ X @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) )
& ( ~ ( member2 @ B @ X @ A4 )
=> ( ( image2 @ B @ A @ ( fun_upd @ B @ A @ F2 @ X @ Y ) @ A4 )
= ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ).
% fun_upd_image
thf(fact_5390_List_Olexordp__def,axiom,
! [A: $tType] :
( ( lexordp @ A )
= ( ^ [R4: A > A > $o,Xs2: list @ A,Ys3: list @ A] : ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs2 @ Ys3 ) @ ( lexord @ A @ ( collect @ ( product_prod @ A @ A ) @ ( product_case_prod @ A @ A @ $o @ R4 ) ) ) ) ) ) ).
% List.lexordp_def
thf(fact_5391_Func__map__surj,axiom,
! [C: $tType,A: $tType,D: $tType,B: $tType,F1: B > A,A18: set @ B,B1: set @ A,F22: C > D,B22: set @ C,A26: set @ D] :
( ( ( image2 @ B @ A @ F1 @ A18 )
= B1 )
=> ( ( inj_on @ C @ D @ F22 @ B22 )
=> ( ( ord_less_eq @ ( set @ D ) @ ( image2 @ C @ D @ F22 @ B22 ) @ A26 )
=> ( ( ( B22
= ( bot_bot @ ( set @ C ) ) )
=> ( A26
= ( bot_bot @ ( set @ D ) ) ) )
=> ( ( bNF_Wellorder_Func @ C @ A @ B22 @ B1 )
= ( image2 @ ( D > B ) @ ( C > A ) @ ( bNF_We4925052301507509544nc_map @ C @ B @ A @ D @ B22 @ F1 @ F22 ) @ ( bNF_Wellorder_Func @ D @ B @ A26 @ A18 ) ) ) ) ) ) ) ).
% Func_map_surj
thf(fact_5392_Func__is__emp,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ( ( bNF_Wellorder_Func @ A @ B @ A4 @ B3 )
= ( bot_bot @ ( set @ ( A > B ) ) ) )
= ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
& ( B3
= ( bot_bot @ ( set @ B ) ) ) ) ) ).
% Func_is_emp
thf(fact_5393_Func__map,axiom,
! [A: $tType,B: $tType,D: $tType,C: $tType,G: A > B,A26: set @ A,A18: set @ B,F1: B > C,B1: set @ C,F22: D > A,B22: set @ D] :
( ( member2 @ ( A > B ) @ G @ ( bNF_Wellorder_Func @ A @ B @ A26 @ A18 ) )
=> ( ( ord_less_eq @ ( set @ C ) @ ( image2 @ B @ C @ F1 @ A18 ) @ B1 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image2 @ D @ A @ F22 @ B22 ) @ A26 )
=> ( member2 @ ( D > C ) @ ( bNF_We4925052301507509544nc_map @ D @ B @ C @ A @ B22 @ F1 @ F22 @ G ) @ ( bNF_Wellorder_Func @ D @ C @ B22 @ B1 ) ) ) ) ) ).
% Func_map
thf(fact_5394_Func__non__emp,axiom,
! [A: $tType,B: $tType,B3: set @ A,A4: set @ B] :
( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( bNF_Wellorder_Func @ B @ A @ A4 @ B3 )
!= ( bot_bot @ ( set @ ( B > A ) ) ) ) ) ).
% Func_non_emp
thf(fact_5395_image__map__upd,axiom,
! [B: $tType,A: $tType,X: A,A4: set @ A,M: A > ( option @ B ),Y: B] :
( ~ ( member2 @ A @ X @ A4 )
=> ( ( image2 @ A @ ( option @ B ) @ ( fun_upd @ A @ ( option @ B ) @ M @ X @ ( some @ B @ Y ) ) @ A4 )
= ( image2 @ A @ ( option @ B ) @ M @ A4 ) ) ) ).
% image_map_upd
thf(fact_5396_finite__range__updI,axiom,
! [A: $tType,B: $tType,F2: B > ( option @ A ),A3: B,B2: A] :
( ( finite_finite @ ( option @ A ) @ ( image2 @ B @ ( option @ A ) @ F2 @ ( top_top @ ( set @ B ) ) ) )
=> ( finite_finite @ ( option @ A ) @ ( image2 @ B @ ( option @ A ) @ ( fun_upd @ B @ ( option @ A ) @ F2 @ A3 @ ( some @ A @ B2 ) ) @ ( top_top @ ( set @ B ) ) ) ) ) ).
% finite_range_updI
thf(fact_5397_map__upd__nonempty,axiom,
! [B: $tType,A: $tType,T2: A > ( option @ B ),K: A,X: B] :
( ( fun_upd @ A @ ( option @ B ) @ T2 @ K @ ( some @ B @ X ) )
!= ( ^ [X2: A] : ( none @ B ) ) ) ).
% map_upd_nonempty
thf(fact_5398_map__upd__Some__unfold,axiom,
! [B: $tType,A: $tType,M: B > ( option @ A ),A3: B,B2: A,X: B,Y: A] :
( ( ( fun_upd @ B @ ( option @ A ) @ M @ A3 @ ( some @ A @ B2 ) @ X )
= ( some @ A @ Y ) )
= ( ( ( X = A3 )
& ( B2 = Y ) )
| ( ( X != A3 )
& ( ( M @ X )
= ( some @ A @ Y ) ) ) ) ) ).
% map_upd_Some_unfold
thf(fact_5399_map__upd__triv,axiom,
! [A: $tType,B: $tType,T2: B > ( option @ A ),K: B,X: A] :
( ( ( T2 @ K )
= ( some @ A @ X ) )
=> ( ( fun_upd @ B @ ( option @ A ) @ T2 @ K @ ( some @ A @ X ) )
= T2 ) ) ).
% map_upd_triv
thf(fact_5400_map__upd__eqD1,axiom,
! [A: $tType,B: $tType,M: A > ( option @ B ),A3: A,X: B,N2: A > ( option @ B ),Y: B] :
( ( ( fun_upd @ A @ ( option @ B ) @ M @ A3 @ ( some @ B @ X ) )
= ( fun_upd @ A @ ( option @ B ) @ N2 @ A3 @ ( some @ B @ Y ) ) )
=> ( X = Y ) ) ).
% map_upd_eqD1
thf(fact_5401_restrict__upd__same,axiom,
! [B: $tType,A: $tType,M: A > ( option @ B ),X: A,Y: B] :
( ( restrict_map @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ M @ X @ ( some @ B @ Y ) ) @ ( uminus_uminus @ ( set @ A ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( restrict_map @ A @ B @ M @ ( uminus_uminus @ ( set @ A ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% restrict_upd_same
thf(fact_5402_fun__upd__None__restrict,axiom,
! [B: $tType,A: $tType,X: A,D6: set @ A,M: A > ( option @ B )] :
( ( ( member2 @ A @ X @ D6 )
=> ( ( fun_upd @ A @ ( option @ B ) @ ( restrict_map @ A @ B @ M @ D6 ) @ X @ ( none @ B ) )
= ( restrict_map @ A @ B @ M @ ( minus_minus @ ( set @ A ) @ D6 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) )
& ( ~ ( member2 @ A @ X @ D6 )
=> ( ( fun_upd @ A @ ( option @ B ) @ ( restrict_map @ A @ B @ M @ D6 ) @ X @ ( none @ B ) )
= ( restrict_map @ A @ B @ M @ D6 ) ) ) ) ).
% fun_upd_None_restrict
thf(fact_5403_ran__map__upd,axiom,
! [A: $tType,B: $tType,M: B > ( option @ A ),A3: B,B2: A] :
( ( ( M @ A3 )
= ( none @ A ) )
=> ( ( ran @ B @ A @ ( fun_upd @ B @ ( option @ A ) @ M @ A3 @ ( some @ A @ B2 ) ) )
= ( insert2 @ A @ B2 @ ( ran @ B @ A @ M ) ) ) ) ).
% ran_map_upd
thf(fact_5404_restrict__map__to__empty,axiom,
! [B: $tType,A: $tType,M: A > ( option @ B )] :
( ( restrict_map @ A @ B @ M @ ( bot_bot @ ( set @ A ) ) )
= ( ^ [X2: A] : ( none @ B ) ) ) ).
% restrict_map_to_empty
thf(fact_5405_ran__empty,axiom,
! [B: $tType,A: $tType] :
( ( ran @ B @ A
@ ^ [X2: B] : ( none @ A ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% ran_empty
thf(fact_5406_restrict__fun__upd,axiom,
! [B: $tType,A: $tType,X: A,D6: set @ A,M: A > ( option @ B ),Y: option @ B] :
( ( ( member2 @ A @ X @ D6 )
=> ( ( restrict_map @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ M @ X @ Y ) @ D6 )
= ( fun_upd @ A @ ( option @ B ) @ ( restrict_map @ A @ B @ M @ ( minus_minus @ ( set @ A ) @ D6 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) @ X @ Y ) ) )
& ( ~ ( member2 @ A @ X @ D6 )
=> ( ( restrict_map @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ M @ X @ Y ) @ D6 )
= ( restrict_map @ A @ B @ M @ D6 ) ) ) ) ).
% restrict_fun_upd
thf(fact_5407_fun__upd__restrict__conv,axiom,
! [A: $tType,B: $tType,X: A,D6: set @ A,M: A > ( option @ B ),Y: option @ B] :
( ( member2 @ A @ X @ D6 )
=> ( ( fun_upd @ A @ ( option @ B ) @ ( restrict_map @ A @ B @ M @ D6 ) @ X @ Y )
= ( fun_upd @ A @ ( option @ B ) @ ( restrict_map @ A @ B @ M @ ( minus_minus @ ( set @ A ) @ D6 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) @ X @ Y ) ) ) ).
% fun_upd_restrict_conv
thf(fact_5408_ran__restrictD,axiom,
! [B: $tType,A: $tType,Y: A,M: B > ( option @ A ),A4: set @ B] :
( ( member2 @ A @ Y @ ( ran @ B @ A @ ( restrict_map @ B @ A @ M @ A4 ) ) )
=> ? [X5: B] :
( ( member2 @ B @ X5 @ A4 )
& ( ( M @ X5 )
= ( some @ A @ Y ) ) ) ) ).
% ran_restrictD
thf(fact_5409_ranI,axiom,
! [A: $tType,B: $tType,M: B > ( option @ A ),A3: B,B2: A] :
( ( ( M @ A3 )
= ( some @ A @ B2 ) )
=> ( member2 @ A @ B2 @ ( ran @ B @ A @ M ) ) ) ).
% ranI
thf(fact_5410_ran__def,axiom,
! [B: $tType,A: $tType] :
( ( ran @ A @ B )
= ( ^ [M2: A > ( option @ B )] :
( collect @ B
@ ^ [B4: B] :
? [A5: A] :
( ( M2 @ A5 )
= ( some @ B @ B4 ) ) ) ) ) ).
% ran_def
thf(fact_5411_fun__upd__restrict,axiom,
! [A: $tType,B: $tType,M: A > ( option @ B ),D6: set @ A,X: A,Y: option @ B] :
( ( fun_upd @ A @ ( option @ B ) @ ( restrict_map @ A @ B @ M @ D6 ) @ X @ Y )
= ( fun_upd @ A @ ( option @ B ) @ ( restrict_map @ A @ B @ M @ ( minus_minus @ ( set @ A ) @ D6 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) @ X @ Y ) ) ).
% fun_upd_restrict
thf(fact_5412_restrict__complement__singleton__eq,axiom,
! [A: $tType,B: $tType,F2: A > ( option @ B ),X: A] :
( ( restrict_map @ A @ B @ F2 @ ( uminus_uminus @ ( set @ A ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( fun_upd @ A @ ( option @ B ) @ F2 @ X @ ( none @ B ) ) ) ).
% restrict_complement_singleton_eq
thf(fact_5413_ran__map__upd__Some,axiom,
! [B: $tType,A: $tType,M: B > ( option @ A ),X: B,Y: A,Z: A] :
( ( ( M @ X )
= ( some @ A @ Y ) )
=> ( ( inj_on @ B @ ( option @ A ) @ M @ ( dom @ B @ A @ M ) )
=> ( ~ ( member2 @ A @ Z @ ( ran @ B @ A @ M ) )
=> ( ( ran @ B @ A @ ( fun_upd @ B @ ( option @ A ) @ M @ X @ ( some @ A @ Z ) ) )
= ( sup_sup @ ( set @ A ) @ ( minus_minus @ ( set @ A ) @ ( ran @ B @ A @ M ) @ ( insert2 @ A @ Y @ ( bot_bot @ ( set @ A ) ) ) ) @ ( insert2 @ A @ Z @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% ran_map_upd_Some
thf(fact_5414_restrict__map__upds,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,D6: set @ A,M: A > ( option @ B )] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs ) @ D6 )
=> ( ( restrict_map @ A @ B @ ( map_upds @ A @ B @ M @ Xs @ Ys ) @ D6 )
= ( map_upds @ A @ B @ ( restrict_map @ A @ B @ M @ ( minus_minus @ ( set @ A ) @ D6 @ ( set2 @ A @ Xs ) ) ) @ Xs @ Ys ) ) ) ) ).
% restrict_map_upds
thf(fact_5415_fold__union__pair,axiom,
! [B: $tType,A: $tType,B3: set @ A,X: B,A4: set @ ( product_prod @ B @ A )] :
( ( finite_finite @ A @ B3 )
=> ( ( sup_sup @ ( set @ ( product_prod @ B @ A ) )
@ ( complete_Sup_Sup @ ( set @ ( product_prod @ B @ A ) )
@ ( image2 @ A @ ( set @ ( product_prod @ B @ A ) )
@ ^ [Y2: A] : ( insert2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ X @ Y2 ) @ ( bot_bot @ ( set @ ( product_prod @ B @ A ) ) ) )
@ B3 ) )
@ A4 )
= ( finite_fold @ A @ ( set @ ( product_prod @ B @ A ) )
@ ^ [Y2: A] : ( insert2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ X @ Y2 ) )
@ A4
@ B3 ) ) ) ).
% fold_union_pair
thf(fact_5416_fold__empty,axiom,
! [B: $tType,A: $tType,F2: B > A > A,Z: A] :
( ( finite_fold @ B @ A @ F2 @ Z @ ( bot_bot @ ( set @ B ) ) )
= Z ) ).
% fold_empty
thf(fact_5417_map__upds__apply__nontin,axiom,
! [B: $tType,A: $tType,X: A,Xs: list @ A,F2: A > ( option @ B ),Ys: list @ B] :
( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( map_upds @ A @ B @ F2 @ Xs @ Ys @ X )
= ( F2 @ X ) ) ) ).
% map_upds_apply_nontin
thf(fact_5418_dom__eq__empty__conv,axiom,
! [B: $tType,A: $tType,F2: A > ( option @ B )] :
( ( ( dom @ A @ B @ F2 )
= ( bot_bot @ ( set @ A ) ) )
= ( F2
= ( ^ [X2: A] : ( none @ B ) ) ) ) ).
% dom_eq_empty_conv
thf(fact_5419_dom__const,axiom,
! [B: $tType,A: $tType,F2: A > B] :
( ( dom @ A @ B
@ ^ [X2: A] : ( some @ B @ ( F2 @ X2 ) ) )
= ( top_top @ ( set @ A ) ) ) ).
% dom_const
thf(fact_5420_dom__empty,axiom,
! [B: $tType,A: $tType] :
( ( dom @ A @ B
@ ^ [X2: A] : ( none @ B ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% dom_empty
thf(fact_5421_map__upds__list__update2__drop,axiom,
! [A: $tType,B: $tType,Xs: list @ A,I: nat,M: A > ( option @ B ),Ys: list @ B,Y: B] :
( ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ I )
=> ( ( map_upds @ A @ B @ M @ Xs @ ( list_update @ B @ Ys @ I @ Y ) )
= ( map_upds @ A @ B @ M @ Xs @ Ys ) ) ) ).
% map_upds_list_update2_drop
thf(fact_5422_map__upds__twist,axiom,
! [A: $tType,B: $tType,A3: A,As: list @ A,M: A > ( option @ B ),B2: B,Bs: list @ B] :
( ~ ( member2 @ A @ A3 @ ( set2 @ A @ As ) )
=> ( ( map_upds @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ M @ A3 @ ( some @ B @ B2 ) ) @ As @ Bs )
= ( fun_upd @ A @ ( option @ B ) @ ( map_upds @ A @ B @ M @ As @ Bs ) @ A3 @ ( some @ B @ B2 ) ) ) ) ).
% map_upds_twist
thf(fact_5423_dom__fun__upd,axiom,
! [B: $tType,A: $tType,Y: option @ B,F2: A > ( option @ B ),X: A] :
( ( ( Y
= ( none @ B ) )
=> ( ( dom @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ F2 @ X @ Y ) )
= ( minus_minus @ ( set @ A ) @ ( dom @ A @ B @ F2 ) @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) )
& ( ( Y
!= ( none @ B ) )
=> ( ( dom @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ F2 @ X @ Y ) )
= ( insert2 @ A @ X @ ( dom @ A @ B @ F2 ) ) ) ) ) ).
% dom_fun_upd
thf(fact_5424_dom__map__upds,axiom,
! [B: $tType,A: $tType,M: A > ( option @ B ),Xs: list @ A,Ys: list @ B] :
( ( dom @ A @ B @ ( map_upds @ A @ B @ M @ Xs @ Ys ) )
= ( sup_sup @ ( set @ A ) @ ( set2 @ A @ ( take @ A @ ( size_size @ ( list @ B ) @ Ys ) @ Xs ) ) @ ( dom @ A @ B @ M ) ) ) ).
% dom_map_upds
thf(fact_5425_domI,axiom,
! [A: $tType,B: $tType,M: B > ( option @ A ),A3: B,B2: A] :
( ( ( M @ A3 )
= ( some @ A @ B2 ) )
=> ( member2 @ B @ A3 @ ( dom @ B @ A @ M ) ) ) ).
% domI
thf(fact_5426_domD,axiom,
! [A: $tType,B: $tType,A3: A,M: A > ( option @ B )] :
( ( member2 @ A @ A3 @ ( dom @ A @ B @ M ) )
=> ? [B5: B] :
( ( M @ A3 )
= ( some @ B @ B5 ) ) ) ).
% domD
thf(fact_5427_insert__dom,axiom,
! [A: $tType,B: $tType,F2: B > ( option @ A ),X: B,Y: A] :
( ( ( F2 @ X )
= ( some @ A @ Y ) )
=> ( ( insert2 @ B @ X @ ( dom @ B @ A @ F2 ) )
= ( dom @ B @ A @ F2 ) ) ) ).
% insert_dom
thf(fact_5428_finite__set__of__finite__maps,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( finite_finite @ ( A > ( option @ B ) )
@ ( collect @ ( A > ( option @ B ) )
@ ^ [M2: A > ( option @ B )] :
( ( ( dom @ A @ B @ M2 )
= A4 )
& ( ord_less_eq @ ( set @ B ) @ ( ran @ A @ B @ M2 ) @ B3 ) ) ) ) ) ) ).
% finite_set_of_finite_maps
thf(fact_5429_Sup__fold__sup,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( complete_Sup_Sup @ A @ A4 )
= ( finite_fold @ A @ A @ ( sup_sup @ A ) @ ( bot_bot @ A ) @ A4 ) ) ) ) ).
% Sup_fold_sup
thf(fact_5430_sum_Oeq__fold,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ( ( groups7311177749621191930dd_sum @ B @ A )
= ( ^ [G2: B > A] : ( finite_fold @ B @ A @ ( comp @ A @ ( A > A ) @ B @ ( plus_plus @ A ) @ G2 ) @ ( zero_zero @ A ) ) ) ) ) ).
% sum.eq_fold
thf(fact_5431_Max_Oeq__fold,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( lattic643756798349783984er_Max @ A @ ( insert2 @ A @ X @ A4 ) )
= ( finite_fold @ A @ A @ ( ord_max @ A ) @ X @ A4 ) ) ) ) ).
% Max.eq_fold
thf(fact_5432_image__fold__insert,axiom,
! [B: $tType,A: $tType,A4: set @ A,F2: A > B] :
( ( finite_finite @ A @ A4 )
=> ( ( image2 @ A @ B @ F2 @ A4 )
= ( finite_fold @ A @ ( set @ B )
@ ^ [K2: A] : ( insert2 @ B @ ( F2 @ K2 ) )
@ ( bot_bot @ ( set @ B ) )
@ A4 ) ) ) ).
% image_fold_insert
thf(fact_5433_finite__Map__induct,axiom,
! [B: $tType,A: $tType,M: A > ( option @ B ),P2: ( A > ( option @ B ) ) > $o] :
( ( finite_finite @ A @ ( dom @ A @ B @ M ) )
=> ( ( P2
@ ^ [X2: A] : ( none @ B ) )
=> ( ! [K3: A,V3: B,M3: A > ( option @ B )] :
( ( finite_finite @ A @ ( dom @ A @ B @ M3 ) )
=> ( ~ ( member2 @ A @ K3 @ ( dom @ A @ B @ M3 ) )
=> ( ( P2 @ M3 )
=> ( P2 @ ( fun_upd @ A @ ( option @ B ) @ M3 @ K3 @ ( some @ B @ V3 ) ) ) ) ) )
=> ( P2 @ M ) ) ) ) ).
% finite_Map_induct
thf(fact_5434_dom__eq__singleton__conv,axiom,
! [A: $tType,B: $tType,F2: A > ( option @ B ),X: A] :
( ( ( dom @ A @ B @ F2 )
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( ? [V5: B] :
( F2
= ( fun_upd @ A @ ( option @ B )
@ ^ [X2: A] : ( none @ B )
@ X
@ ( some @ B @ V5 ) ) ) ) ) ).
% dom_eq_singleton_conv
thf(fact_5435_SUP__fold__sup,axiom,
! [A: $tType,B: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ B,F2: B > A] :
( ( finite_finite @ B @ A4 )
=> ( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
= ( finite_fold @ B @ A @ ( comp @ A @ ( A > A ) @ B @ ( sup_sup @ A ) @ F2 ) @ ( bot_bot @ A ) @ A4 ) ) ) ) ).
% SUP_fold_sup
thf(fact_5436_map__upd__upds__conv__if,axiom,
! [A: $tType,B: $tType,X: A,Ys: list @ B,Xs: list @ A,F2: A > ( option @ B ),Y: B] :
( ( ( member2 @ A @ X @ ( set2 @ A @ ( take @ A @ ( size_size @ ( list @ B ) @ Ys ) @ Xs ) ) )
=> ( ( map_upds @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ F2 @ X @ ( some @ B @ Y ) ) @ Xs @ Ys )
= ( map_upds @ A @ B @ F2 @ Xs @ Ys ) ) )
& ( ~ ( member2 @ A @ X @ ( set2 @ A @ ( take @ A @ ( size_size @ ( list @ B ) @ Ys ) @ Xs ) ) )
=> ( ( map_upds @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ F2 @ X @ ( some @ B @ Y ) ) @ Xs @ Ys )
= ( fun_upd @ A @ ( option @ B ) @ ( map_upds @ A @ B @ F2 @ Xs @ Ys ) @ X @ ( some @ B @ Y ) ) ) ) ) ).
% map_upd_upds_conv_if
thf(fact_5437_Set__filter__fold,axiom,
! [A: $tType,A4: set @ A,P2: A > $o] :
( ( finite_finite @ A @ A4 )
=> ( ( filter3 @ A @ P2 @ A4 )
= ( finite_fold @ A @ ( set @ A )
@ ^ [X2: A,A19: set @ A] : ( if @ ( set @ A ) @ ( P2 @ X2 ) @ ( insert2 @ A @ X2 @ A19 ) @ A19 )
@ ( bot_bot @ ( set @ A ) )
@ A4 ) ) ) ).
% Set_filter_fold
thf(fact_5438_graph__map__upd,axiom,
! [A: $tType,B: $tType,M: A > ( option @ B ),K: A,V2: B] :
( ( graph @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ M @ K @ ( some @ B @ V2 ) ) )
= ( insert2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ K @ V2 ) @ ( graph @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ M @ K @ ( none @ B ) ) ) ) ) ).
% graph_map_upd
thf(fact_5439_Id__on__fold,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( id_on @ A @ A4 )
= ( finite_fold @ A @ ( set @ ( product_prod @ A @ A ) )
@ ^ [X2: A] : ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ X2 ) )
@ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) )
@ A4 ) ) ) ).
% Id_on_fold
thf(fact_5440_Id__onI,axiom,
! [A: $tType,A3: A,A4: set @ A] :
( ( member2 @ A @ A3 @ A4 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ A3 ) @ ( id_on @ A @ A4 ) ) ) ).
% Id_onI
thf(fact_5441_Id__on__empty,axiom,
! [A: $tType] :
( ( id_on @ A @ ( bot_bot @ ( set @ A ) ) )
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ).
% Id_on_empty
thf(fact_5442_graph__empty,axiom,
! [B: $tType,A: $tType] :
( ( graph @ A @ B
@ ^ [X2: A] : ( none @ B ) )
= ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) ) ).
% graph_empty
thf(fact_5443_Id__onE,axiom,
! [A: $tType,C2: product_prod @ A @ A,A4: set @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ C2 @ ( id_on @ A @ A4 ) )
=> ~ ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( C2
!= ( product_Pair @ A @ A @ X5 @ X5 ) ) ) ) ).
% Id_onE
thf(fact_5444_Id__on__eqI,axiom,
! [A: $tType,A3: A,B2: A,A4: set @ A] :
( ( A3 = B2 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( id_on @ A @ A4 ) ) ) ) ).
% Id_on_eqI
thf(fact_5445_Id__on__iff,axiom,
! [A: $tType,X: A,Y: A,A4: set @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( id_on @ A @ A4 ) )
= ( ( X = Y )
& ( member2 @ A @ X @ A4 ) ) ) ).
% Id_on_iff
thf(fact_5446_in__graphI,axiom,
! [A: $tType,B: $tType,M: B > ( option @ A ),K: B,V2: A] :
( ( ( M @ K )
= ( some @ A @ V2 ) )
=> ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ K @ V2 ) @ ( graph @ B @ A @ M ) ) ) ).
% in_graphI
thf(fact_5447_in__graphD,axiom,
! [A: $tType,B: $tType,K: A,V2: B,M: A > ( option @ B )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ K @ V2 ) @ ( graph @ A @ B @ M ) )
=> ( ( M @ K )
= ( some @ B @ V2 ) ) ) ).
% in_graphD
thf(fact_5448_graph__restrictD_I1_J,axiom,
! [B: $tType,A: $tType,K: A,V2: B,M: A > ( option @ B ),A4: set @ A] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ K @ V2 ) @ ( graph @ A @ B @ ( restrict_map @ A @ B @ M @ A4 ) ) )
=> ( member2 @ A @ K @ A4 ) ) ).
% graph_restrictD(1)
thf(fact_5449_card_Oeq__fold,axiom,
! [A: $tType] :
( ( finite_card @ A )
= ( finite_fold @ A @ nat
@ ^ [Uu3: A] : suc
@ ( zero_zero @ nat ) ) ) ).
% card.eq_fold
thf(fact_5450_sorted__list__of__set_Ofold__insort__key_Oeq__fold,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( linord4507533701916653071of_set @ A )
= ( finite_fold @ A @ ( list @ A )
@ ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2 )
@ ( nil @ A ) ) ) ) ).
% sorted_list_of_set.fold_insort_key.eq_fold
thf(fact_5451_graph__restrictD_I2_J,axiom,
! [A: $tType,B: $tType,K: A,V2: B,M: A > ( option @ B ),A4: set @ A] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ K @ V2 ) @ ( graph @ A @ B @ ( restrict_map @ A @ B @ M @ A4 ) ) )
=> ( ( M @ K )
= ( some @ B @ V2 ) ) ) ).
% graph_restrictD(2)
thf(fact_5452_graph__def,axiom,
! [B: $tType,A: $tType] :
( ( graph @ A @ B )
= ( ^ [M2: A > ( option @ B )] :
( collect @ ( product_prod @ A @ B )
@ ^ [Uu3: product_prod @ A @ B] :
? [A5: A,B4: B] :
( ( Uu3
= ( product_Pair @ A @ B @ A5 @ B4 ) )
& ( ( M2 @ A5 )
= ( some @ B @ B4 ) ) ) ) ) ) ).
% graph_def
thf(fact_5453_Id__on__def,axiom,
! [A: $tType] :
( ( id_on @ A )
= ( ^ [A6: set @ A] :
( complete_Sup_Sup @ ( set @ ( product_prod @ A @ A ) )
@ ( image2 @ A @ ( set @ ( product_prod @ A @ A ) )
@ ^ [X2: A] : ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ X2 ) @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
@ A6 ) ) ) ) ).
% Id_on_def
thf(fact_5454_Pow__fold,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( pow2 @ A @ A4 )
= ( finite_fold @ A @ ( set @ ( set @ A ) )
@ ^ [X2: A,A6: set @ ( set @ A )] : ( sup_sup @ ( set @ ( set @ A ) ) @ A6 @ ( image2 @ ( set @ A ) @ ( set @ A ) @ ( insert2 @ A @ X2 ) @ A6 ) )
@ ( insert2 @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) @ ( bot_bot @ ( set @ ( set @ A ) ) ) )
@ A4 ) ) ) ).
% Pow_fold
thf(fact_5455_comp__fun__commute__product__fold,axiom,
! [A: $tType,B: $tType,B3: set @ A] :
( ( finite_finite @ A @ B3 )
=> ( finite6289374366891150609ommute @ B @ ( set @ ( product_prod @ B @ A ) )
@ ^ [X2: B,Z6: set @ ( product_prod @ B @ A )] :
( finite_fold @ A @ ( set @ ( product_prod @ B @ A ) )
@ ^ [Y2: A] : ( insert2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ X2 @ Y2 ) )
@ Z6
@ B3 ) ) ) ).
% comp_fun_commute_product_fold
thf(fact_5456_comp__fun__commute__on_Ofold__set__union__disj,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,A4: set @ A,B3: set @ A,Z: B] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ S3 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ A @ B3 )
=> ( ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_fold @ A @ B @ F2 @ Z @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( finite_fold @ A @ B @ F2 @ ( finite_fold @ A @ B @ F2 @ Z @ A4 ) @ B3 ) ) ) ) ) ) ) ) ).
% comp_fun_commute_on.fold_set_union_disj
thf(fact_5457_Pow__iff,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( member2 @ ( set @ A ) @ A4 @ ( pow2 @ A @ B3 ) )
= ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ).
% Pow_iff
thf(fact_5458_PowI,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( member2 @ ( set @ A ) @ A4 @ ( pow2 @ A @ B3 ) ) ) ).
% PowI
thf(fact_5459_Pow__empty,axiom,
! [A: $tType] :
( ( pow2 @ A @ ( bot_bot @ ( set @ A ) ) )
= ( insert2 @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) @ ( bot_bot @ ( set @ ( set @ A ) ) ) ) ) ).
% Pow_empty
thf(fact_5460_Pow__singleton__iff,axiom,
! [A: $tType,X7: set @ A,Y6: set @ A] :
( ( ( pow2 @ A @ X7 )
= ( insert2 @ ( set @ A ) @ Y6 @ ( bot_bot @ ( set @ ( set @ A ) ) ) ) )
= ( ( X7
= ( bot_bot @ ( set @ A ) ) )
& ( Y6
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% Pow_singleton_iff
thf(fact_5461_Pow__not__empty,axiom,
! [A: $tType,A4: set @ A] :
( ( pow2 @ A @ A4 )
!= ( bot_bot @ ( set @ ( set @ A ) ) ) ) ).
% Pow_not_empty
thf(fact_5462_Pow__bottom,axiom,
! [A: $tType,B3: set @ A] : ( member2 @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) @ ( pow2 @ A @ B3 ) ) ).
% Pow_bottom
thf(fact_5463_PowD,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( member2 @ ( set @ A ) @ A4 @ ( pow2 @ A @ B3 ) )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ B3 ) ) ).
% PowD
thf(fact_5464_Pow__def,axiom,
! [A: $tType] :
( ( pow2 @ A )
= ( ^ [A6: set @ A] :
( collect @ ( set @ A )
@ ^ [B6: set @ A] : ( ord_less_eq @ ( set @ A ) @ B6 @ A6 ) ) ) ) ).
% Pow_def
thf(fact_5465_Pow__mono,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ ( set @ ( set @ A ) ) @ ( pow2 @ A @ A4 ) @ ( pow2 @ A @ B3 ) ) ) ).
% Pow_mono
thf(fact_5466_comp__fun__commute__relcomp__fold,axiom,
! [A: $tType,B: $tType,C: $tType,S3: set @ ( product_prod @ A @ B )] :
( ( finite_finite @ ( product_prod @ A @ B ) @ S3 )
=> ( finite6289374366891150609ommute @ ( product_prod @ C @ A ) @ ( set @ ( product_prod @ C @ B ) )
@ ( product_case_prod @ C @ A @ ( ( set @ ( product_prod @ C @ B ) ) > ( set @ ( product_prod @ C @ B ) ) )
@ ^ [X2: C,Y2: A,A6: set @ ( product_prod @ C @ B )] :
( finite_fold @ ( product_prod @ A @ B ) @ ( set @ ( product_prod @ C @ B ) )
@ ( product_case_prod @ A @ B @ ( ( set @ ( product_prod @ C @ B ) ) > ( set @ ( product_prod @ C @ B ) ) )
@ ^ [W3: A,Z6: B,A19: set @ ( product_prod @ C @ B )] : ( if @ ( set @ ( product_prod @ C @ B ) ) @ ( Y2 = W3 ) @ ( insert2 @ ( product_prod @ C @ B ) @ ( product_Pair @ C @ B @ X2 @ Z6 ) @ A19 ) @ A19 ) )
@ A6
@ S3 ) ) ) ) ).
% comp_fun_commute_relcomp_fold
thf(fact_5467_Finite__Set_Ofold__cong,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,G: A > B > B,A4: set @ A,S: B,T2: B,B3: set @ A] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( finite4664212375090638736ute_on @ A @ B @ S3 @ G )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ( F2 @ X5 )
= ( G @ X5 ) ) )
=> ( ( S = T2 )
=> ( ( A4 = B3 )
=> ( ( finite_fold @ A @ B @ F2 @ S @ A4 )
= ( finite_fold @ A @ B @ G @ T2 @ B3 ) ) ) ) ) ) ) ) ) ).
% Finite_Set.fold_cong
thf(fact_5468_image__Pow__mono,axiom,
! [B: $tType,A: $tType,F2: B > A,A4: set @ B,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ F2 @ A4 ) @ B3 )
=> ( ord_less_eq @ ( set @ ( set @ A ) ) @ ( image2 @ ( set @ B ) @ ( set @ A ) @ ( image2 @ B @ A @ F2 ) @ ( pow2 @ B @ A4 ) ) @ ( pow2 @ A @ B3 ) ) ) ).
% image_Pow_mono
thf(fact_5469_comp__fun__commute__on_Ocomp__comp__fun__commute__on,axiom,
! [B: $tType,A: $tType,C: $tType,S3: set @ A,F2: A > B > B,G: C > A,R: set @ C] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image2 @ C @ A @ G @ ( top_top @ ( set @ C ) ) ) @ S3 )
=> ( finite4664212375090638736ute_on @ C @ B @ R @ ( comp @ A @ ( B > B ) @ C @ F2 @ G ) ) ) ) ).
% comp_fun_commute_on.comp_comp_fun_commute_on
thf(fact_5470_comp__fun__commute__on_Ofold__fun__left__comm,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,X: A,A4: set @ A,Z: B] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( F2 @ X @ ( finite_fold @ A @ B @ F2 @ Z @ A4 ) )
= ( finite_fold @ A @ B @ F2 @ ( F2 @ X @ Z ) @ A4 ) ) ) ) ) ).
% comp_fun_commute_on.fold_fun_left_comm
thf(fact_5471_comp__fun__commute__on_Ofold__insert2,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,X: A,A4: set @ A,Z: B] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ~ ( member2 @ A @ X @ A4 )
=> ( ( finite_fold @ A @ B @ F2 @ Z @ ( insert2 @ A @ X @ A4 ) )
= ( finite_fold @ A @ B @ F2 @ ( F2 @ X @ Z ) @ A4 ) ) ) ) ) ) ).
% comp_fun_commute_on.fold_insert2
thf(fact_5472_comp__fun__commute__on_Ofold__insert,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,X: A,A4: set @ A,Z: B] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ~ ( member2 @ A @ X @ A4 )
=> ( ( finite_fold @ A @ B @ F2 @ Z @ ( insert2 @ A @ X @ A4 ) )
= ( F2 @ X @ ( finite_fold @ A @ B @ F2 @ Z @ A4 ) ) ) ) ) ) ) ).
% comp_fun_commute_on.fold_insert
thf(fact_5473_binomial__def,axiom,
( binomial
= ( ^ [N: nat,K2: nat] :
( finite_card @ ( set @ nat )
@ ( collect @ ( set @ nat )
@ ^ [K6: set @ nat] :
( ( member2 @ ( set @ nat ) @ K6 @ ( pow2 @ nat @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ N ) ) )
& ( ( finite_card @ nat @ K6 )
= K2 ) ) ) ) ) ) ).
% binomial_def
thf(fact_5474_subseqs__powset,axiom,
! [A: $tType,Xs: list @ A] :
( ( image2 @ ( list @ A ) @ ( set @ A ) @ ( set2 @ A ) @ ( set2 @ ( list @ A ) @ ( subseqs @ A @ Xs ) ) )
= ( pow2 @ A @ ( set2 @ A @ Xs ) ) ) ).
% subseqs_powset
thf(fact_5475_Pow__set_I1_J,axiom,
! [A: $tType] :
( ( pow2 @ A @ ( set2 @ A @ ( nil @ A ) ) )
= ( insert2 @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) @ ( bot_bot @ ( set @ ( set @ A ) ) ) ) ) ).
% Pow_set(1)
thf(fact_5476_comp__fun__commute__on_Ofold__insert__remove,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,X: A,A4: set @ A,Z: B] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( finite_fold @ A @ B @ F2 @ Z @ ( insert2 @ A @ X @ A4 ) )
= ( F2 @ X @ ( finite_fold @ A @ B @ F2 @ Z @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ).
% comp_fun_commute_on.fold_insert_remove
thf(fact_5477_comp__fun__commute__on_Ofold__rec,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,A4: set @ A,X: A,Z: B] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( finite_fold @ A @ B @ F2 @ Z @ A4 )
= ( F2 @ X @ ( finite_fold @ A @ B @ F2 @ Z @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ).
% comp_fun_commute_on.fold_rec
thf(fact_5478_map__upds__fold__map__upd,axiom,
! [B: $tType,A: $tType] :
( ( map_upds @ A @ B )
= ( ^ [M2: A > ( option @ B ),Ks: list @ A,Vs: list @ B] :
( foldl @ ( A > ( option @ B ) ) @ ( product_prod @ A @ B )
@ ^ [N: A > ( option @ B )] :
( product_case_prod @ A @ B @ ( A > ( option @ B ) )
@ ^ [K2: A,V5: B] : ( fun_upd @ A @ ( option @ B ) @ N @ K2 @ ( some @ B @ V5 ) ) )
@ M2
@ ( zip @ A @ B @ Ks @ Vs ) ) ) ) ).
% map_upds_fold_map_upd
thf(fact_5479_isCont__If__ge,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo1944317154257567458pology @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [A3: A,G: A > B,F2: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ ( set_ord_lessThan @ A @ A3 ) ) @ G )
=> ( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( G @ A3 ) ) @ ( topolo174197925503356063within @ A @ A3 @ ( set_ord_greaterThan @ A @ A3 ) ) )
=> ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) )
@ ^ [X2: A] : ( if @ B @ ( ord_less_eq @ A @ X2 @ A3 ) @ ( G @ X2 ) @ ( F2 @ X2 ) ) ) ) ) ) ).
% isCont_If_ge
thf(fact_5480_finite__subsets__at__top__finite,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( finite5375528669736107172at_top @ A @ A4 )
= ( principal @ ( set @ A ) @ ( insert2 @ ( set @ A ) @ A4 @ ( bot_bot @ ( set @ ( set @ A ) ) ) ) ) ) ) ).
% finite_subsets_at_top_finite
thf(fact_5481_eventually__finite__subsets__at__top__weakI,axiom,
! [A: $tType,A4: set @ A,P2: ( set @ A ) > $o] :
( ! [X9: set @ A] :
( ( finite_finite @ A @ X9 )
=> ( ( ord_less_eq @ ( set @ A ) @ X9 @ A4 )
=> ( P2 @ X9 ) ) )
=> ( eventually @ ( set @ A ) @ P2 @ ( finite5375528669736107172at_top @ A @ A4 ) ) ) ).
% eventually_finite_subsets_at_top_weakI
thf(fact_5482_isCont__Pair,axiom,
! [C: $tType,B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( topolo4958980785337419405_space @ B )
& ( topolo4958980785337419405_space @ C ) )
=> ! [A3: A,F2: A > B,G: A > C] :
( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) @ F2 )
=> ( ( topolo3448309680560233919inuous @ A @ C @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) @ G )
=> ( topolo3448309680560233919inuous @ A @ ( product_prod @ B @ C ) @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) )
@ ^ [X2: A] : ( product_Pair @ B @ C @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ).
% isCont_Pair
thf(fact_5483_continuous__Pair,axiom,
! [C: $tType,B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( topolo4958980785337419405_space @ B )
& ( topolo4958980785337419405_space @ C ) )
=> ! [F5: filter @ A,F2: A > B,G: A > C] :
( ( topolo3448309680560233919inuous @ A @ B @ F5 @ F2 )
=> ( ( topolo3448309680560233919inuous @ A @ C @ F5 @ G )
=> ( topolo3448309680560233919inuous @ A @ ( product_prod @ B @ C ) @ F5
@ ^ [X2: A] : ( product_Pair @ B @ C @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ).
% continuous_Pair
thf(fact_5484_continuous__max,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( topolo1944317154257567458pology @ B ) )
=> ! [F5: filter @ A,F2: A > B,G: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ F5 @ F2 )
=> ( ( topolo3448309680560233919inuous @ A @ B @ F5 @ G )
=> ( topolo3448309680560233919inuous @ A @ B @ F5
@ ^ [X2: A] : ( ord_max @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ).
% continuous_max
thf(fact_5485_continuous__add,axiom,
! [B: $tType,D: $tType] :
( ( ( topological_t2_space @ D )
& ( topolo6943815403480290642id_add @ B ) )
=> ! [F5: filter @ D,F2: D > B,G: D > B] :
( ( topolo3448309680560233919inuous @ D @ B @ F5 @ F2 )
=> ( ( topolo3448309680560233919inuous @ D @ B @ F5 @ G )
=> ( topolo3448309680560233919inuous @ D @ B @ F5
@ ^ [X2: D] : ( plus_plus @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ).
% continuous_add
thf(fact_5486_foldl__Nil,axiom,
! [A: $tType,B: $tType,F2: B > A > B,A3: B] :
( ( foldl @ B @ A @ F2 @ A3 @ ( nil @ A ) )
= A3 ) ).
% foldl_Nil
thf(fact_5487_foldl__cong,axiom,
! [A: $tType,B: $tType,A3: A,B2: A,L: list @ B,K: list @ B,F2: A > B > A,G: A > B > A] :
( ( A3 = B2 )
=> ( ( L = K )
=> ( ! [A7: A,X5: B] :
( ( member2 @ B @ X5 @ ( set2 @ B @ L ) )
=> ( ( F2 @ A7 @ X5 )
= ( G @ A7 @ X5 ) ) )
=> ( ( foldl @ A @ B @ F2 @ A3 @ L )
= ( foldl @ A @ B @ G @ B2 @ K ) ) ) ) ) ).
% foldl_cong
thf(fact_5488_finite__subsets__at__top__neq__bot,axiom,
! [A: $tType,A4: set @ A] :
( ( finite5375528669736107172at_top @ A @ A4 )
!= ( bot_bot @ ( filter @ ( set @ A ) ) ) ) ).
% finite_subsets_at_top_neq_bot
thf(fact_5489_continuous__trivial__limit,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [Net: filter @ A,F2: A > B] :
( ( Net
= ( bot_bot @ ( filter @ A ) ) )
=> ( topolo3448309680560233919inuous @ A @ B @ Net @ F2 ) ) ) ).
% continuous_trivial_limit
thf(fact_5490_continuous__bot,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [F2: A > B] : ( topolo3448309680560233919inuous @ A @ B @ ( bot_bot @ ( filter @ A ) ) @ F2 ) ) ).
% continuous_bot
thf(fact_5491_IVT2,axiom,
! [A: $tType,B: $tType] :
( ( ( topolo1944317154257567458pology @ B )
& ( topolo8458572112393995274pology @ A ) )
=> ! [F2: A > B,B2: A,Y: B,A3: A] :
( ( ord_less_eq @ B @ ( F2 @ B2 ) @ Y )
=> ( ( ord_less_eq @ B @ Y @ ( F2 @ A3 ) )
=> ( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ! [X5: A] :
( ( ( ord_less_eq @ A @ A3 @ X5 )
& ( ord_less_eq @ A @ X5 @ B2 ) )
=> ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ X5 @ ( top_top @ ( set @ A ) ) ) @ F2 ) )
=> ? [X5: A] :
( ( ord_less_eq @ A @ A3 @ X5 )
& ( ord_less_eq @ A @ X5 @ B2 )
& ( ( F2 @ X5 )
= Y ) ) ) ) ) ) ) ).
% IVT2
thf(fact_5492_IVT,axiom,
! [A: $tType,B: $tType] :
( ( ( topolo1944317154257567458pology @ B )
& ( topolo8458572112393995274pology @ A ) )
=> ! [F2: A > B,A3: A,Y: B,B2: A] :
( ( ord_less_eq @ B @ ( F2 @ A3 ) @ Y )
=> ( ( ord_less_eq @ B @ Y @ ( F2 @ B2 ) )
=> ( ( ord_less_eq @ A @ A3 @ B2 )
=> ( ! [X5: A] :
( ( ( ord_less_eq @ A @ A3 @ X5 )
& ( ord_less_eq @ A @ X5 @ B2 ) )
=> ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ X5 @ ( top_top @ ( set @ A ) ) ) @ F2 ) )
=> ? [X5: A] :
( ( ord_less_eq @ A @ A3 @ X5 )
& ( ord_less_eq @ A @ X5 @ B2 )
& ( ( F2 @ X5 )
= Y ) ) ) ) ) ) ) ).
% IVT
thf(fact_5493_continuous__at__within__divide,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( real_V3459762299906320749_field @ B ) )
=> ! [A3: A,S: set @ A,F2: A > B,G: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ S ) @ F2 )
=> ( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ S ) @ G )
=> ( ( ( G @ A3 )
!= ( zero_zero @ B ) )
=> ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ S )
@ ^ [X2: A] : ( divide_divide @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ) ).
% continuous_at_within_divide
thf(fact_5494_isCont__add,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( topolo6943815403480290642id_add @ B ) )
=> ! [A3: A,F2: A > B,G: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) @ F2 )
=> ( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) @ G )
=> ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) )
@ ^ [X2: A] : ( plus_plus @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ).
% isCont_add
thf(fact_5495_continuous__at__within__inverse,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( real_V8999393235501362500lgebra @ B ) )
=> ! [A3: A,S: set @ A,F2: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ S ) @ F2 )
=> ( ( ( F2 @ A3 )
!= ( zero_zero @ B ) )
=> ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ S )
@ ^ [X2: A] : ( inverse_inverse @ B @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_at_within_inverse
thf(fact_5496_continuous__at__within__sgn,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [A3: A,S: set @ A,F2: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ S ) @ F2 )
=> ( ( ( F2 @ A3 )
!= ( zero_zero @ B ) )
=> ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ S )
@ ^ [X2: A] : ( sgn_sgn @ B @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_at_within_sgn
thf(fact_5497_continuous__at__within__power__int,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( real_V8999393235501362500lgebra @ B ) )
=> ! [A3: A,S: set @ A,F2: A > B,N2: int] :
( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ S ) @ F2 )
=> ( ( ( F2 @ A3 )
!= ( zero_zero @ B ) )
=> ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ S )
@ ^ [X2: A] : ( power_int @ B @ ( F2 @ X2 ) @ N2 ) ) ) ) ) ).
% continuous_at_within_power_int
thf(fact_5498_continuous__divide,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( real_V3459762299906320749_field @ B ) )
=> ! [F5: filter @ A,F2: A > B,G: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ F5 @ F2 )
=> ( ( topolo3448309680560233919inuous @ A @ B @ F5 @ G )
=> ( ( ( G
@ ( topolo3827282254853284352ce_Lim @ A @ A @ F5
@ ^ [X2: A] : X2 ) )
!= ( zero_zero @ B ) )
=> ( topolo3448309680560233919inuous @ A @ B @ F5
@ ^ [X2: A] : ( divide_divide @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ) ).
% continuous_divide
thf(fact_5499_continuous__inverse,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( real_V8999393235501362500lgebra @ B ) )
=> ! [F5: filter @ A,F2: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ F5 @ F2 )
=> ( ( ( F2
@ ( topolo3827282254853284352ce_Lim @ A @ A @ F5
@ ^ [X2: A] : X2 ) )
!= ( zero_zero @ B ) )
=> ( topolo3448309680560233919inuous @ A @ B @ F5
@ ^ [X2: A] : ( inverse_inverse @ B @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_inverse
thf(fact_5500_continuous__sgn,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F5: filter @ A,F2: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ F5 @ F2 )
=> ( ( ( F2
@ ( topolo3827282254853284352ce_Lim @ A @ A @ F5
@ ^ [X2: A] : X2 ) )
!= ( zero_zero @ B ) )
=> ( topolo3448309680560233919inuous @ A @ B @ F5
@ ^ [X2: A] : ( sgn_sgn @ B @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_sgn
thf(fact_5501_continuous__power__int,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( real_V8999393235501362500lgebra @ B ) )
=> ! [F5: filter @ A,F2: A > B,N2: int] :
( ( topolo3448309680560233919inuous @ A @ B @ F5 @ F2 )
=> ( ( ( F2
@ ( topolo3827282254853284352ce_Lim @ A @ A @ F5
@ ^ [X2: A] : X2 ) )
!= ( zero_zero @ B ) )
=> ( topolo3448309680560233919inuous @ A @ B @ F5
@ ^ [X2: A] : ( power_int @ B @ ( F2 @ X2 ) @ N2 ) ) ) ) ) ).
% continuous_power_int
thf(fact_5502_isCont__bounded,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [A3: real,B2: real,F2: real > A] :
( ( ord_less_eq @ real @ A3 @ B2 )
=> ( ! [X5: real] :
( ( ( ord_less_eq @ real @ A3 @ X5 )
& ( ord_less_eq @ real @ X5 @ B2 ) )
=> ( topolo3448309680560233919inuous @ real @ A @ ( topolo174197925503356063within @ real @ X5 @ ( top_top @ ( set @ real ) ) ) @ F2 ) )
=> ? [M8: A] :
! [X3: real] :
( ( ( ord_less_eq @ real @ A3 @ X3 )
& ( ord_less_eq @ real @ X3 @ B2 ) )
=> ( ord_less_eq @ A @ ( F2 @ X3 ) @ M8 ) ) ) ) ) ).
% isCont_bounded
thf(fact_5503_isCont__eq__Ub,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [A3: real,B2: real,F2: real > A] :
( ( ord_less_eq @ real @ A3 @ B2 )
=> ( ! [X5: real] :
( ( ( ord_less_eq @ real @ A3 @ X5 )
& ( ord_less_eq @ real @ X5 @ B2 ) )
=> ( topolo3448309680560233919inuous @ real @ A @ ( topolo174197925503356063within @ real @ X5 @ ( top_top @ ( set @ real ) ) ) @ F2 ) )
=> ? [M8: A] :
( ! [X3: real] :
( ( ( ord_less_eq @ real @ A3 @ X3 )
& ( ord_less_eq @ real @ X3 @ B2 ) )
=> ( ord_less_eq @ A @ ( F2 @ X3 ) @ M8 ) )
& ? [X5: real] :
( ( ord_less_eq @ real @ A3 @ X5 )
& ( ord_less_eq @ real @ X5 @ B2 )
& ( ( F2 @ X5 )
= M8 ) ) ) ) ) ) ).
% isCont_eq_Ub
thf(fact_5504_isCont__eq__Lb,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [A3: real,B2: real,F2: real > A] :
( ( ord_less_eq @ real @ A3 @ B2 )
=> ( ! [X5: real] :
( ( ( ord_less_eq @ real @ A3 @ X5 )
& ( ord_less_eq @ real @ X5 @ B2 ) )
=> ( topolo3448309680560233919inuous @ real @ A @ ( topolo174197925503356063within @ real @ X5 @ ( top_top @ ( set @ real ) ) ) @ F2 ) )
=> ? [M8: A] :
( ! [X3: real] :
( ( ( ord_less_eq @ real @ A3 @ X3 )
& ( ord_less_eq @ real @ X3 @ B2 ) )
=> ( ord_less_eq @ A @ M8 @ ( F2 @ X3 ) ) )
& ? [X5: real] :
( ( ord_less_eq @ real @ A3 @ X5 )
& ( ord_less_eq @ real @ X5 @ B2 )
& ( ( F2 @ X5 )
= M8 ) ) ) ) ) ) ).
% isCont_eq_Lb
thf(fact_5505_isCont__divide,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( real_V3459762299906320749_field @ B ) )
=> ! [A3: A,F2: A > B,G: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) @ F2 )
=> ( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) @ G )
=> ( ( ( G @ A3 )
!= ( zero_zero @ B ) )
=> ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) )
@ ^ [X2: A] : ( divide_divide @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ) ).
% isCont_divide
thf(fact_5506_eventually__finite__subsets__at__top,axiom,
! [A: $tType,P2: ( set @ A ) > $o,A4: set @ A] :
( ( eventually @ ( set @ A ) @ P2 @ ( finite5375528669736107172at_top @ A @ A4 ) )
= ( ? [X8: set @ A] :
( ( finite_finite @ A @ X8 )
& ( ord_less_eq @ ( set @ A ) @ X8 @ A4 )
& ! [Y9: set @ A] :
( ( ( finite_finite @ A @ Y9 )
& ( ord_less_eq @ ( set @ A ) @ X8 @ Y9 )
& ( ord_less_eq @ ( set @ A ) @ Y9 @ A4 ) )
=> ( P2 @ Y9 ) ) ) ) ) ).
% eventually_finite_subsets_at_top
thf(fact_5507_isCont__sgn,axiom,
! [B: $tType,A: $tType] :
( ( ( topological_t2_space @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [A3: A,F2: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) @ F2 )
=> ( ( ( F2 @ A3 )
!= ( zero_zero @ B ) )
=> ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) )
@ ^ [X2: A] : ( sgn_sgn @ B @ ( F2 @ X2 ) ) ) ) ) ) ).
% isCont_sgn
thf(fact_5508_continuous__within__tan,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,S: set @ A,F2: A > A] :
( ( topolo3448309680560233919inuous @ A @ A @ ( topolo174197925503356063within @ A @ X @ S ) @ F2 )
=> ( ( ( cos @ A @ ( F2 @ X ) )
!= ( zero_zero @ A ) )
=> ( topolo3448309680560233919inuous @ A @ A @ ( topolo174197925503356063within @ A @ X @ S )
@ ^ [X2: A] : ( tan @ A @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_within_tan
thf(fact_5509_continuous__within__cot,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A,S: set @ A,F2: A > A] :
( ( topolo3448309680560233919inuous @ A @ A @ ( topolo174197925503356063within @ A @ X @ S ) @ F2 )
=> ( ( ( sin @ A @ ( F2 @ X ) )
!= ( zero_zero @ A ) )
=> ( topolo3448309680560233919inuous @ A @ A @ ( topolo174197925503356063within @ A @ X @ S )
@ ^ [X2: A] : ( cot @ A @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_within_cot
thf(fact_5510_continuous__at__within__tanh,axiom,
! [A: $tType,C: $tType] :
( ( ( topological_t2_space @ C )
& ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: C,A4: set @ C,F2: C > A] :
( ( topolo3448309680560233919inuous @ C @ A @ ( topolo174197925503356063within @ C @ X @ A4 ) @ F2 )
=> ( ( ( cosh @ A @ ( F2 @ X ) )
!= ( zero_zero @ A ) )
=> ( topolo3448309680560233919inuous @ C @ A @ ( topolo174197925503356063within @ C @ X @ A4 )
@ ^ [X2: C] : ( tanh @ A @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_at_within_tanh
thf(fact_5511_continuous__tan,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [F5: filter @ A,F2: A > A] :
( ( topolo3448309680560233919inuous @ A @ A @ F5 @ F2 )
=> ( ( ( cos @ A
@ ( F2
@ ( topolo3827282254853284352ce_Lim @ A @ A @ F5
@ ^ [X2: A] : X2 ) ) )
!= ( zero_zero @ A ) )
=> ( topolo3448309680560233919inuous @ A @ A @ F5
@ ^ [X2: A] : ( tan @ A @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_tan
thf(fact_5512_continuous__cot,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [F5: filter @ A,F2: A > A] :
( ( topolo3448309680560233919inuous @ A @ A @ F5 @ F2 )
=> ( ( ( sin @ A
@ ( F2
@ ( topolo3827282254853284352ce_Lim @ A @ A @ F5
@ ^ [X2: A] : X2 ) ) )
!= ( zero_zero @ A ) )
=> ( topolo3448309680560233919inuous @ A @ A @ F5
@ ^ [X2: A] : ( cot @ A @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_cot
thf(fact_5513_continuous__tanh,axiom,
! [A: $tType,C: $tType] :
( ( ( topological_t2_space @ C )
& ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [F5: filter @ C,F2: C > A] :
( ( topolo3448309680560233919inuous @ C @ A @ F5 @ F2 )
=> ( ( ( cosh @ A
@ ( F2
@ ( topolo3827282254853284352ce_Lim @ C @ C @ F5
@ ^ [X2: C] : X2 ) ) )
!= ( zero_zero @ A ) )
=> ( topolo3448309680560233919inuous @ C @ A @ F5
@ ^ [X2: C] : ( tanh @ A @ ( F2 @ X2 ) ) ) ) ) ) ).
% continuous_tanh
thf(fact_5514_isCont__has__Ub,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [A3: real,B2: real,F2: real > A] :
( ( ord_less_eq @ real @ A3 @ B2 )
=> ( ! [X5: real] :
( ( ( ord_less_eq @ real @ A3 @ X5 )
& ( ord_less_eq @ real @ X5 @ B2 ) )
=> ( topolo3448309680560233919inuous @ real @ A @ ( topolo174197925503356063within @ real @ X5 @ ( top_top @ ( set @ real ) ) ) @ F2 ) )
=> ? [M8: A] :
( ! [X3: real] :
( ( ( ord_less_eq @ real @ A3 @ X3 )
& ( ord_less_eq @ real @ X3 @ B2 ) )
=> ( ord_less_eq @ A @ ( F2 @ X3 ) @ M8 ) )
& ! [N8: A] :
( ( ord_less @ A @ N8 @ M8 )
=> ? [X5: real] :
( ( ord_less_eq @ real @ A3 @ X5 )
& ( ord_less_eq @ real @ X5 @ B2 )
& ( ord_less @ A @ N8 @ ( F2 @ X5 ) ) ) ) ) ) ) ) ).
% isCont_has_Ub
thf(fact_5515_isCont__tan,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ( cos @ A @ X )
!= ( zero_zero @ A ) )
=> ( topolo3448309680560233919inuous @ A @ A @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) @ ( tan @ A ) ) ) ) ).
% isCont_tan
thf(fact_5516_finite__subsets__at__top__def,axiom,
! [A: $tType] :
( ( finite5375528669736107172at_top @ A )
= ( ^ [A6: set @ A] :
( complete_Inf_Inf @ ( filter @ ( set @ A ) )
@ ( image2 @ ( set @ A ) @ ( filter @ ( set @ A ) )
@ ^ [X8: set @ A] :
( principal @ ( set @ A )
@ ( collect @ ( set @ A )
@ ^ [Y9: set @ A] :
( ( finite_finite @ A @ Y9 )
& ( ord_less_eq @ ( set @ A ) @ X8 @ Y9 )
& ( ord_less_eq @ ( set @ A ) @ Y9 @ A6 ) ) ) )
@ ( collect @ ( set @ A )
@ ^ [X8: set @ A] :
( ( finite_finite @ A @ X8 )
& ( ord_less_eq @ ( set @ A ) @ X8 @ A6 ) ) ) ) ) ) ) ).
% finite_subsets_at_top_def
thf(fact_5517_isCont__cot,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ( sin @ A @ X )
!= ( zero_zero @ A ) )
=> ( topolo3448309680560233919inuous @ A @ A @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) @ ( cot @ A ) ) ) ) ).
% isCont_cot
thf(fact_5518_isCont__tanh,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [X: A] :
( ( ( cosh @ A @ X )
!= ( zero_zero @ A ) )
=> ( topolo3448309680560233919inuous @ A @ A @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) @ ( tanh @ A ) ) ) ) ).
% isCont_tanh
thf(fact_5519_isCont__tan_H,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [A3: A,F2: A > A] :
( ( topolo3448309680560233919inuous @ A @ A @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) @ F2 )
=> ( ( ( cos @ A @ ( F2 @ A3 ) )
!= ( zero_zero @ A ) )
=> ( topolo3448309680560233919inuous @ A @ A @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) )
@ ^ [X2: A] : ( tan @ A @ ( F2 @ X2 ) ) ) ) ) ) ).
% isCont_tan'
thf(fact_5520_isCont__cot_H,axiom,
! [A: $tType] :
( ( ( real_Vector_banach @ A )
& ( real_V3459762299906320749_field @ A ) )
=> ! [A3: A,F2: A > A] :
( ( topolo3448309680560233919inuous @ A @ A @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) ) @ F2 )
=> ( ( ( sin @ A @ ( F2 @ A3 ) )
!= ( zero_zero @ A ) )
=> ( topolo3448309680560233919inuous @ A @ A @ ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) )
@ ^ [X2: A] : ( cot @ A @ ( F2 @ X2 ) ) ) ) ) ) ).
% isCont_cot'
thf(fact_5521_isCont__iff,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( topolo4958980785337419405_space @ B ) )
=> ! [X: A,F2: A > B] :
( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ X @ ( top_top @ ( set @ A ) ) ) @ F2 )
= ( filterlim @ A @ B
@ ^ [H: A] : ( F2 @ ( plus_plus @ A @ X @ H ) )
@ ( topolo7230453075368039082e_nhds @ B @ ( F2 @ X ) )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% isCont_iff
thf(fact_5522_filterlim__finite__subsets__at__top,axiom,
! [A: $tType,B: $tType,F2: A > ( set @ B ),A4: set @ B,F5: filter @ A] :
( ( filterlim @ A @ ( set @ B ) @ F2 @ ( finite5375528669736107172at_top @ B @ A4 ) @ F5 )
= ( ! [X8: set @ B] :
( ( ( finite_finite @ B @ X8 )
& ( ord_less_eq @ ( set @ B ) @ X8 @ A4 ) )
=> ( eventually @ A
@ ^ [Y2: A] :
( ( finite_finite @ B @ ( F2 @ Y2 ) )
& ( ord_less_eq @ ( set @ B ) @ X8 @ ( F2 @ Y2 ) )
& ( ord_less_eq @ ( set @ B ) @ ( F2 @ Y2 ) @ A4 ) )
@ F5 ) ) ) ) ).
% filterlim_finite_subsets_at_top
thf(fact_5523_insert__relcomp__union__fold,axiom,
! [C: $tType,B: $tType,A: $tType,S3: set @ ( product_prod @ A @ B ),X: product_prod @ C @ A,X7: set @ ( product_prod @ C @ B )] :
( ( finite_finite @ ( product_prod @ A @ B ) @ S3 )
=> ( ( sup_sup @ ( set @ ( product_prod @ C @ B ) ) @ ( relcomp @ C @ A @ B @ ( insert2 @ ( product_prod @ C @ A ) @ X @ ( bot_bot @ ( set @ ( product_prod @ C @ A ) ) ) ) @ S3 ) @ X7 )
= ( finite_fold @ ( product_prod @ A @ B ) @ ( set @ ( product_prod @ C @ B ) )
@ ( product_case_prod @ A @ B @ ( ( set @ ( product_prod @ C @ B ) ) > ( set @ ( product_prod @ C @ B ) ) )
@ ^ [W3: A,Z6: B,A19: set @ ( product_prod @ C @ B )] :
( if @ ( set @ ( product_prod @ C @ B ) )
@ ( ( product_snd @ C @ A @ X )
= W3 )
@ ( insert2 @ ( product_prod @ C @ B ) @ ( product_Pair @ C @ B @ ( product_fst @ C @ A @ X ) @ Z6 ) @ A19 )
@ A19 ) )
@ X7
@ S3 ) ) ) ).
% insert_relcomp_union_fold
thf(fact_5524_continuous__at__Sup__antimono,axiom,
! [B: $tType,A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( topolo1944317154257567458pology @ A )
& ( condit6923001295902523014norder @ B )
& ( topolo1944317154257567458pology @ B ) )
=> ! [F2: A > B,S3: set @ A] :
( ( order_antimono @ A @ B @ F2 )
=> ( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ ( complete_Sup_Sup @ A @ S3 ) @ ( set_ord_lessThan @ A @ ( complete_Sup_Sup @ A @ S3 ) ) ) @ F2 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit941137186595557371_above @ A @ S3 )
=> ( ( F2 @ ( complete_Sup_Sup @ A @ S3 ) )
= ( complete_Inf_Inf @ B @ ( image2 @ A @ B @ F2 @ S3 ) ) ) ) ) ) ) ) ).
% continuous_at_Sup_antimono
thf(fact_5525_continuous__at__Inf__antimono,axiom,
! [B: $tType,A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( topolo1944317154257567458pology @ A )
& ( condit6923001295902523014norder @ B )
& ( topolo1944317154257567458pology @ B ) )
=> ! [F2: A > B,S3: set @ A] :
( ( order_antimono @ A @ B @ F2 )
=> ( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ ( complete_Inf_Inf @ A @ S3 ) @ ( set_ord_greaterThan @ A @ ( complete_Inf_Inf @ A @ S3 ) ) ) @ F2 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit1013018076250108175_below @ A @ S3 )
=> ( ( F2 @ ( complete_Inf_Inf @ A @ S3 ) )
= ( complete_Sup_Sup @ B @ ( image2 @ A @ B @ F2 @ S3 ) ) ) ) ) ) ) ) ).
% continuous_at_Inf_antimono
thf(fact_5526_bdd__belowI,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A4: set @ A,M: A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ A @ M @ X5 ) )
=> ( condit1013018076250108175_below @ A @ A4 ) ) ) ).
% bdd_belowI
thf(fact_5527_bdd__below_OI,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A4: set @ A,M7: A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ A @ M7 @ X5 ) )
=> ( condit1013018076250108175_below @ A @ A4 ) ) ) ).
% bdd_below.I
thf(fact_5528_bdd__above_OI,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A4: set @ A,M7: A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ A @ X5 @ M7 ) )
=> ( condit941137186595557371_above @ A @ A4 ) ) ) ).
% bdd_above.I
thf(fact_5529_bdd__below__empty,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( condit1013018076250108175_below @ A @ ( bot_bot @ ( set @ A ) ) ) ) ).
% bdd_below_empty
thf(fact_5530_bdd__above__empty,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( condit941137186595557371_above @ A @ ( bot_bot @ ( set @ A ) ) ) ) ).
% bdd_above_empty
thf(fact_5531_relcomp__empty1,axiom,
! [C: $tType,B: $tType,A: $tType,R: set @ ( product_prod @ C @ B )] :
( ( relcomp @ A @ C @ B @ ( bot_bot @ ( set @ ( product_prod @ A @ C ) ) ) @ R )
= ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) ) ).
% relcomp_empty1
thf(fact_5532_relcomp__empty2,axiom,
! [C: $tType,B: $tType,A: $tType,R: set @ ( product_prod @ A @ C )] :
( ( relcomp @ A @ C @ B @ R @ ( bot_bot @ ( set @ ( product_prod @ C @ B ) ) ) )
= ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) ) ).
% relcomp_empty2
thf(fact_5533_cInf__lower,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X: A,X7: set @ A] :
( ( member2 @ A @ X @ X7 )
=> ( ( condit1013018076250108175_below @ A @ X7 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ X7 ) @ X ) ) ) ) ).
% cInf_lower
thf(fact_5534_cInf__lower2,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X: A,X7: set @ A,Y: A] :
( ( member2 @ A @ X @ X7 )
=> ( ( ord_less_eq @ A @ X @ Y )
=> ( ( condit1013018076250108175_below @ A @ X7 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ X7 ) @ Y ) ) ) ) ) ).
% cInf_lower2
thf(fact_5535_bdd__above_OI2,axiom,
! [A: $tType,B: $tType] :
( ( preorder @ A )
=> ! [A4: set @ B,F2: B > A,M7: A] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ M7 ) )
=> ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ).
% bdd_above.I2
thf(fact_5536_cInf__le__cSup,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit941137186595557371_above @ A @ A4 )
=> ( ( condit1013018076250108175_below @ A @ A4 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ) ).
% cInf_le_cSup
thf(fact_5537_relcomp_Ocases,axiom,
! [A: $tType,C: $tType,B: $tType,A12: A,A23: C,R2: set @ ( product_prod @ A @ B ),S: set @ ( product_prod @ B @ C )] :
( ( member2 @ ( product_prod @ A @ C ) @ ( product_Pair @ A @ C @ A12 @ A23 ) @ ( relcomp @ A @ B @ C @ R2 @ S ) )
=> ~ ! [B5: B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A12 @ B5 ) @ R2 )
=> ~ ( member2 @ ( product_prod @ B @ C ) @ ( product_Pair @ B @ C @ B5 @ A23 ) @ S ) ) ) ).
% relcomp.cases
thf(fact_5538_relcomp_Osimps,axiom,
! [B: $tType,C: $tType,A: $tType,A12: A,A23: C,R2: set @ ( product_prod @ A @ B ),S: set @ ( product_prod @ B @ C )] :
( ( member2 @ ( product_prod @ A @ C ) @ ( product_Pair @ A @ C @ A12 @ A23 ) @ ( relcomp @ A @ B @ C @ R2 @ S ) )
= ( ? [A5: A,B4: B,C3: C] :
( ( A12 = A5 )
& ( A23 = C3 )
& ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A5 @ B4 ) @ R2 )
& ( member2 @ ( product_prod @ B @ C ) @ ( product_Pair @ B @ C @ B4 @ C3 ) @ S ) ) ) ) ).
% relcomp.simps
thf(fact_5539_relcomp_OrelcompI,axiom,
! [A: $tType,C: $tType,B: $tType,A3: A,B2: B,R2: set @ ( product_prod @ A @ B ),C2: C,S: set @ ( product_prod @ B @ C )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ R2 )
=> ( ( member2 @ ( product_prod @ B @ C ) @ ( product_Pair @ B @ C @ B2 @ C2 ) @ S )
=> ( member2 @ ( product_prod @ A @ C ) @ ( product_Pair @ A @ C @ A3 @ C2 ) @ ( relcomp @ A @ B @ C @ R2 @ S ) ) ) ) ).
% relcomp.relcompI
thf(fact_5540_relcompE,axiom,
! [A: $tType,B: $tType,C: $tType,Xz: product_prod @ A @ B,R2: set @ ( product_prod @ A @ C ),S: set @ ( product_prod @ C @ B )] :
( ( member2 @ ( product_prod @ A @ B ) @ Xz @ ( relcomp @ A @ C @ B @ R2 @ S ) )
=> ~ ! [X5: A,Y4: C,Z2: B] :
( ( Xz
= ( product_Pair @ A @ B @ X5 @ Z2 ) )
=> ( ( member2 @ ( product_prod @ A @ C ) @ ( product_Pair @ A @ C @ X5 @ Y4 ) @ R2 )
=> ~ ( member2 @ ( product_prod @ C @ B ) @ ( product_Pair @ C @ B @ Y4 @ Z2 ) @ S ) ) ) ) ).
% relcompE
thf(fact_5541_relcompEpair,axiom,
! [A: $tType,B: $tType,C: $tType,A3: A,C2: B,R2: set @ ( product_prod @ A @ C ),S: set @ ( product_prod @ C @ B )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ C2 ) @ ( relcomp @ A @ C @ B @ R2 @ S ) )
=> ~ ! [B5: C] :
( ( member2 @ ( product_prod @ A @ C ) @ ( product_Pair @ A @ C @ A3 @ B5 ) @ R2 )
=> ~ ( member2 @ ( product_prod @ C @ B ) @ ( product_Pair @ C @ B @ B5 @ C2 ) @ S ) ) ) ).
% relcompEpair
thf(fact_5542_bdd__below__mono,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ( condit1013018076250108175_below @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( condit1013018076250108175_below @ A @ A4 ) ) ) ) ).
% bdd_below_mono
thf(fact_5543_bdd__above__mono,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ( condit941137186595557371_above @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( condit941137186595557371_above @ A @ A4 ) ) ) ) ).
% bdd_above_mono
thf(fact_5544_bdd__below_OE,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A4: set @ A] :
( ( condit1013018076250108175_below @ A @ A4 )
=> ~ ! [M8: A] :
~ ! [X3: A] :
( ( member2 @ A @ X3 @ A4 )
=> ( ord_less_eq @ A @ M8 @ X3 ) ) ) ) ).
% bdd_below.E
thf(fact_5545_bdd__below_Ounfold,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( ( condit1013018076250108175_below @ A )
= ( ^ [A6: set @ A] :
? [M9: A] :
! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( ord_less_eq @ A @ M9 @ X2 ) ) ) ) ) ).
% bdd_below.unfold
thf(fact_5546_bdd__above_OE,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ! [A4: set @ A] :
( ( condit941137186595557371_above @ A @ A4 )
=> ~ ! [M8: A] :
~ ! [X3: A] :
( ( member2 @ A @ X3 @ A4 )
=> ( ord_less_eq @ A @ X3 @ M8 ) ) ) ) ).
% bdd_above.E
thf(fact_5547_bdd__above_Ounfold,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( ( condit941137186595557371_above @ A )
= ( ^ [A6: set @ A] :
? [M9: A] :
! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( ord_less_eq @ A @ X2 @ M9 ) ) ) ) ) ).
% bdd_above.unfold
thf(fact_5548_bdd__below_OI2,axiom,
! [A: $tType,B: $tType] :
( ( preorder @ A )
=> ! [A4: set @ B,M7: A,F2: B > A] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ M7 @ ( F2 @ X5 ) ) )
=> ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ).
% bdd_below.I2
thf(fact_5549_bdd__belowI2,axiom,
! [A: $tType,B: $tType] :
( ( preorder @ A )
=> ! [A4: set @ B,M: A,F2: B > A] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ M @ ( F2 @ X5 ) ) )
=> ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ).
% bdd_belowI2
thf(fact_5550_cSup__upper,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X: A,X7: set @ A] :
( ( member2 @ A @ X @ X7 )
=> ( ( condit941137186595557371_above @ A @ X7 )
=> ( ord_less_eq @ A @ X @ ( complete_Sup_Sup @ A @ X7 ) ) ) ) ) ).
% cSup_upper
thf(fact_5551_cSup__upper2,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X: A,X7: set @ A,Y: A] :
( ( member2 @ A @ X @ X7 )
=> ( ( ord_less_eq @ A @ Y @ X )
=> ( ( condit941137186595557371_above @ A @ X7 )
=> ( ord_less_eq @ A @ Y @ ( complete_Sup_Sup @ A @ X7 ) ) ) ) ) ) ).
% cSup_upper2
thf(fact_5552_union__comp__emptyL,axiom,
! [A: $tType,A4: set @ ( product_prod @ A @ A ),C5: set @ ( product_prod @ A @ A ),B3: set @ ( product_prod @ A @ A )] :
( ( ( relcomp @ A @ A @ A @ A4 @ C5 )
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
=> ( ( ( relcomp @ A @ A @ A @ B3 @ C5 )
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
=> ( ( relcomp @ A @ A @ A @ ( sup_sup @ ( set @ ( product_prod @ A @ A ) ) @ A4 @ B3 ) @ C5 )
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ) ) ).
% union_comp_emptyL
thf(fact_5553_union__comp__emptyR,axiom,
! [A: $tType,A4: set @ ( product_prod @ A @ A ),B3: set @ ( product_prod @ A @ A ),C5: set @ ( product_prod @ A @ A )] :
( ( ( relcomp @ A @ A @ A @ A4 @ B3 )
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
=> ( ( ( relcomp @ A @ A @ A @ A4 @ C5 )
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
=> ( ( relcomp @ A @ A @ A @ A4 @ ( sup_sup @ ( set @ ( product_prod @ A @ A ) ) @ B3 @ C5 ) )
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ) ) ).
% union_comp_emptyR
thf(fact_5554_cINF__lower2,axiom,
! [B: $tType,A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [F2: B > A,A4: set @ B,X: B,U: A] :
( ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( member2 @ B @ X @ A4 )
=> ( ( ord_less_eq @ A @ ( F2 @ X ) @ U )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ U ) ) ) ) ) ).
% cINF_lower2
thf(fact_5555_cINF__lower,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [F2: B > A,A4: set @ B,X: B] :
( ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( member2 @ B @ X @ A4 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( F2 @ X ) ) ) ) ) ).
% cINF_lower
thf(fact_5556_cInf__mono,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit1013018076250108175_below @ A @ A4 )
=> ( ! [B5: A] :
( ( member2 @ A @ B5 @ B3 )
=> ? [X3: A] :
( ( member2 @ A @ X3 @ A4 )
& ( ord_less_eq @ A @ X3 @ B5 ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ ( complete_Inf_Inf @ A @ B3 ) ) ) ) ) ) ).
% cInf_mono
thf(fact_5557_le__cInf__iff,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [S3: set @ A,A3: A] :
( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit1013018076250108175_below @ A @ S3 )
=> ( ( ord_less_eq @ A @ A3 @ ( complete_Inf_Inf @ A @ S3 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ S3 )
=> ( ord_less_eq @ A @ A3 @ X2 ) ) ) ) ) ) ) ).
% le_cInf_iff
thf(fact_5558_cSUP__upper2,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [F2: B > A,A4: set @ B,X: B,U: A] :
( ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( member2 @ B @ X @ A4 )
=> ( ( ord_less_eq @ A @ U @ ( F2 @ X ) )
=> ( ord_less_eq @ A @ U @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ) ) ).
% cSUP_upper2
thf(fact_5559_cSUP__upper,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X: B,A4: set @ B,F2: B > A] :
( ( member2 @ B @ X @ A4 )
=> ( ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ord_less_eq @ A @ ( F2 @ X ) @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ) ).
% cSUP_upper
thf(fact_5560_cInf__less__iff,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [X7: set @ A,Y: A] :
( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit1013018076250108175_below @ A @ X7 )
=> ( ( ord_less @ A @ ( complete_Inf_Inf @ A @ X7 ) @ Y )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ X7 )
& ( ord_less @ A @ X2 @ Y ) ) ) ) ) ) ) ).
% cInf_less_iff
thf(fact_5561_cSup__le__iff,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [S3: set @ A,A3: A] :
( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit941137186595557371_above @ A @ S3 )
=> ( ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ S3 ) @ A3 )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ S3 )
=> ( ord_less_eq @ A @ X2 @ A3 ) ) ) ) ) ) ) ).
% cSup_le_iff
thf(fact_5562_cSup__mono,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit941137186595557371_above @ A @ A4 )
=> ( ! [B5: A] :
( ( member2 @ A @ B5 @ B3 )
=> ? [X3: A] :
( ( member2 @ A @ X3 @ A4 )
& ( ord_less_eq @ A @ B5 @ X3 ) ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ B3 ) @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ) ).
% cSup_mono
thf(fact_5563_less__cSup__iff,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [X7: set @ A,Y: A] :
( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit941137186595557371_above @ A @ X7 )
=> ( ( ord_less @ A @ Y @ ( complete_Sup_Sup @ A @ X7 ) )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ X7 )
& ( ord_less @ A @ Y @ X2 ) ) ) ) ) ) ) ).
% less_cSup_iff
thf(fact_5564_relcomp__unfold,axiom,
! [B: $tType,C: $tType,A: $tType] :
( ( relcomp @ A @ C @ B )
= ( ^ [R4: set @ ( product_prod @ A @ C ),S7: set @ ( product_prod @ C @ B )] :
( collect @ ( product_prod @ A @ B )
@ ( product_case_prod @ A @ B @ $o
@ ^ [X2: A,Z6: B] :
? [Y2: C] :
( ( member2 @ ( product_prod @ A @ C ) @ ( product_Pair @ A @ C @ X2 @ Y2 ) @ R4 )
& ( member2 @ ( product_prod @ C @ B ) @ ( product_Pair @ C @ B @ Y2 @ Z6 ) @ S7 ) ) ) ) ) ) ).
% relcomp_unfold
thf(fact_5565_less__cINF__D,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [F2: B > A,A4: set @ B,Y: A,I: B] :
( ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( ord_less @ A @ Y @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) )
=> ( ( member2 @ B @ I @ A4 )
=> ( ord_less @ A @ Y @ ( F2 @ I ) ) ) ) ) ) ).
% less_cINF_D
thf(fact_5566_cSUP__lessD,axiom,
! [B: $tType,A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [F2: B > A,A4: set @ B,Y: A,I: B] :
( ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( ord_less @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ Y )
=> ( ( member2 @ B @ I @ A4 )
=> ( ord_less @ A @ ( F2 @ I ) @ Y ) ) ) ) ) ).
% cSUP_lessD
thf(fact_5567_le__cINF__iff,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,F2: B > A,U: A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( ord_less_eq @ A @ U @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( ord_less_eq @ A @ U @ ( F2 @ X2 ) ) ) ) ) ) ) ) ).
% le_cINF_iff
thf(fact_5568_cINF__mono,axiom,
! [C: $tType,A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [B3: set @ B,F2: C > A,A4: set @ C,G: B > A] :
( ( B3
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit1013018076250108175_below @ A @ ( image2 @ C @ A @ F2 @ A4 ) )
=> ( ! [M3: B] :
( ( member2 @ B @ M3 @ B3 )
=> ? [X3: C] :
( ( member2 @ C @ X3 @ A4 )
& ( ord_less_eq @ A @ ( F2 @ X3 ) @ ( G @ M3 ) ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ C @ A @ F2 @ A4 ) ) @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ G @ B3 ) ) ) ) ) ) ) ).
% cINF_mono
thf(fact_5569_cInf__superset__mono,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit1013018076250108175_below @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ B3 ) @ ( complete_Inf_Inf @ A @ A4 ) ) ) ) ) ) ).
% cInf_superset_mono
thf(fact_5570_cSUP__le__iff,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,F2: B > A,U: A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ U )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ X2 ) @ U ) ) ) ) ) ) ) ).
% cSUP_le_iff
thf(fact_5571_cSUP__mono,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,G: C > A,B3: set @ C,F2: B > A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit941137186595557371_above @ A @ ( image2 @ C @ A @ G @ B3 ) )
=> ( ! [N3: B] :
( ( member2 @ B @ N3 @ A4 )
=> ? [X3: C] :
( ( member2 @ C @ X3 @ B3 )
& ( ord_less_eq @ A @ ( F2 @ N3 ) @ ( G @ X3 ) ) ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Sup_Sup @ A @ ( image2 @ C @ A @ G @ B3 ) ) ) ) ) ) ) ).
% cSUP_mono
thf(fact_5572_cSup__subset__mono,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit941137186595557371_above @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ A4 ) @ ( complete_Sup_Sup @ A @ B3 ) ) ) ) ) ) ).
% cSup_subset_mono
thf(fact_5573_cInf__insert__If,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A,A3: A] :
( ( condit1013018076250108175_below @ A @ X7 )
=> ( ( ( X7
= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Inf_Inf @ A @ ( insert2 @ A @ A3 @ X7 ) )
= A3 ) )
& ( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Inf_Inf @ A @ ( insert2 @ A @ A3 @ X7 ) )
= ( inf_inf @ A @ A3 @ ( complete_Inf_Inf @ A @ X7 ) ) ) ) ) ) ) ).
% cInf_insert_If
thf(fact_5574_cInf__insert,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A,A3: A] :
( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit1013018076250108175_below @ A @ X7 )
=> ( ( complete_Inf_Inf @ A @ ( insert2 @ A @ A3 @ X7 ) )
= ( inf_inf @ A @ A3 @ ( complete_Inf_Inf @ A @ X7 ) ) ) ) ) ) ).
% cInf_insert
thf(fact_5575_cSup__insert__If,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A,A3: A] :
( ( condit941137186595557371_above @ A @ X7 )
=> ( ( ( X7
= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Sup_Sup @ A @ ( insert2 @ A @ A3 @ X7 ) )
= A3 ) )
& ( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Sup_Sup @ A @ ( insert2 @ A @ A3 @ X7 ) )
= ( sup_sup @ A @ A3 @ ( complete_Sup_Sup @ A @ X7 ) ) ) ) ) ) ) ).
% cSup_insert_If
thf(fact_5576_cSup__insert,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A,A3: A] :
( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit941137186595557371_above @ A @ X7 )
=> ( ( complete_Sup_Sup @ A @ ( insert2 @ A @ A3 @ X7 ) )
= ( sup_sup @ A @ A3 @ ( complete_Sup_Sup @ A @ X7 ) ) ) ) ) ) ).
% cSup_insert
thf(fact_5577_cInf__union__distrib,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit1013018076250108175_below @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit1013018076250108175_below @ A @ B3 )
=> ( ( complete_Inf_Inf @ A @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( inf_inf @ A @ ( complete_Inf_Inf @ A @ A4 ) @ ( complete_Inf_Inf @ A @ B3 ) ) ) ) ) ) ) ) ).
% cInf_union_distrib
thf(fact_5578_cSup__union__distrib,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit941137186595557371_above @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit941137186595557371_above @ A @ B3 )
=> ( ( complete_Sup_Sup @ A @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( sup_sup @ A @ ( complete_Sup_Sup @ A @ A4 ) @ ( complete_Sup_Sup @ A @ B3 ) ) ) ) ) ) ) ) ).
% cSup_union_distrib
thf(fact_5579_cINF__less__iff,axiom,
! [A: $tType,B: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [A4: set @ B,F2: B > A,A3: A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( ord_less @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ A3 )
= ( ? [X2: B] :
( ( member2 @ B @ X2 @ A4 )
& ( ord_less @ A @ ( F2 @ X2 ) @ A3 ) ) ) ) ) ) ) ).
% cINF_less_iff
thf(fact_5580_less__cSUP__iff,axiom,
! [A: $tType,B: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [A4: set @ B,F2: B > A,A3: A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( ord_less @ A @ A3 @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) )
= ( ? [X2: B] :
( ( member2 @ B @ X2 @ A4 )
& ( ord_less @ A @ A3 @ ( F2 @ X2 ) ) ) ) ) ) ) ) ).
% less_cSUP_iff
thf(fact_5581_cINF__inf__distrib,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,F2: B > A,G: B > A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ G @ A4 ) )
=> ( ( inf_inf @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ G @ A4 ) ) )
= ( complete_Inf_Inf @ A
@ ( image2 @ B @ A
@ ^ [A5: B] : ( inf_inf @ A @ ( F2 @ A5 ) @ ( G @ A5 ) )
@ A4 ) ) ) ) ) ) ) ).
% cINF_inf_distrib
thf(fact_5582_conditionally__complete__lattice__class_OSUP__sup__distrib,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,F2: B > A,G: B > A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ G @ A4 ) )
=> ( ( sup_sup @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ G @ A4 ) ) )
= ( complete_Sup_Sup @ A
@ ( image2 @ B @ A
@ ^ [A5: B] : ( sup_sup @ A @ ( F2 @ A5 ) @ ( G @ A5 ) )
@ A4 ) ) ) ) ) ) ) ).
% conditionally_complete_lattice_class.SUP_sup_distrib
thf(fact_5583_cINF__superset__mono,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,G: B > A,B3: set @ B,F2: B > A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ G @ B3 ) )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ B3 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ B3 )
=> ( ord_less_eq @ A @ ( G @ X5 ) @ ( F2 @ X5 ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ G @ B3 ) ) @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ) ) ) ).
% cINF_superset_mono
thf(fact_5584_cSUP__subset__mono,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,G: B > A,B3: set @ B,F2: B > A] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ G @ B3 ) )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ B3 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ G @ B3 ) ) ) ) ) ) ) ) ).
% cSUP_subset_mono
thf(fact_5585_less__eq__cInf__inter,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( condit1013018076250108175_below @ A @ A4 )
=> ( ( condit1013018076250108175_below @ A @ B3 )
=> ( ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ord_less_eq @ A @ ( inf_inf @ A @ ( complete_Inf_Inf @ A @ A4 ) @ ( complete_Inf_Inf @ A @ B3 ) ) @ ( complete_Inf_Inf @ A @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) ) ) ) ) ) ).
% less_eq_cInf_inter
thf(fact_5586_cINF__insert,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,F2: B > A,A3: B] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ ( insert2 @ B @ A3 @ A4 ) ) )
= ( inf_inf @ A @ ( F2 @ A3 ) @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ) ) ).
% cINF_insert
thf(fact_5587_cSup__inter__less__eq,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( condit941137186595557371_above @ A @ A4 )
=> ( ( condit941137186595557371_above @ A @ B3 )
=> ( ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) @ ( sup_sup @ A @ ( complete_Sup_Sup @ A @ A4 ) @ ( complete_Sup_Sup @ A @ B3 ) ) ) ) ) ) ) ).
% cSup_inter_less_eq
thf(fact_5588_cSUP__insert,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,F2: B > A,A3: B] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ ( insert2 @ B @ A3 @ A4 ) ) )
= ( sup_sup @ A @ ( F2 @ A3 ) @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ) ) ).
% cSUP_insert
thf(fact_5589_cINF__union,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,F2: B > A,B3: set @ B] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( B3
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit1013018076250108175_below @ A @ ( image2 @ B @ A @ F2 @ B3 ) )
=> ( ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ ( sup_sup @ ( set @ B ) @ A4 @ B3 ) ) )
= ( inf_inf @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ B3 ) ) ) ) ) ) ) ) ) ).
% cINF_union
thf(fact_5590_cSUP__union,axiom,
! [A: $tType,B: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [A4: set @ B,F2: B > A,B3: set @ B] :
( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ( B3
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( condit941137186595557371_above @ A @ ( image2 @ B @ A @ F2 @ B3 ) )
=> ( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ ( sup_sup @ ( set @ B ) @ A4 @ B3 ) ) )
= ( sup_sup @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ B3 ) ) ) ) ) ) ) ) ) ).
% cSUP_union
thf(fact_5591_cInf__cSup,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [S3: set @ A] :
( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit1013018076250108175_below @ A @ S3 )
=> ( ( complete_Inf_Inf @ A @ S3 )
= ( complete_Sup_Sup @ A
@ ( collect @ A
@ ^ [X2: A] :
! [Y2: A] :
( ( member2 @ A @ Y2 @ S3 )
=> ( ord_less_eq @ A @ X2 @ Y2 ) ) ) ) ) ) ) ) ).
% cInf_cSup
thf(fact_5592_cSup__cInf,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [S3: set @ A] :
( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit941137186595557371_above @ A @ S3 )
=> ( ( complete_Sup_Sup @ A @ S3 )
= ( complete_Inf_Inf @ A
@ ( collect @ A
@ ^ [X2: A] :
! [Y2: A] :
( ( member2 @ A @ Y2 @ S3 )
=> ( ord_less_eq @ A @ Y2 @ X2 ) ) ) ) ) ) ) ) ).
% cSup_cInf
thf(fact_5593_mono__cInf,axiom,
! [B: $tType,A: $tType] :
( ( ( condit1219197933456340205attice @ A )
& ( condit1219197933456340205attice @ B ) )
=> ! [F2: A > B,A4: set @ A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( condit1013018076250108175_below @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ord_less_eq @ B @ ( F2 @ ( complete_Inf_Inf @ A @ A4 ) ) @ ( complete_Inf_Inf @ B @ ( image2 @ A @ B @ F2 @ A4 ) ) ) ) ) ) ) ).
% mono_cInf
thf(fact_5594_mono__cINF,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( ( condit1219197933456340205attice @ A )
& ( condit1219197933456340205attice @ B ) )
=> ! [F2: A > B,A4: C > A,I6: set @ C] :
( ( order_mono @ A @ B @ F2 )
=> ( ( condit1013018076250108175_below @ A @ ( image2 @ C @ A @ A4 @ I6 ) )
=> ( ( I6
!= ( bot_bot @ ( set @ C ) ) )
=> ( ord_less_eq @ B @ ( F2 @ ( complete_Inf_Inf @ A @ ( image2 @ C @ A @ A4 @ I6 ) ) )
@ ( complete_Inf_Inf @ B
@ ( image2 @ C @ B
@ ^ [X2: C] : ( F2 @ ( A4 @ X2 ) )
@ I6 ) ) ) ) ) ) ) ).
% mono_cINF
thf(fact_5595_cINF__UNION,axiom,
! [B: $tType,D: $tType,C: $tType] :
( ( condit1219197933456340205attice @ B )
=> ! [A4: set @ C,B3: C > ( set @ D ),F2: D > B] :
( ( A4
!= ( bot_bot @ ( set @ C ) ) )
=> ( ! [X5: C] :
( ( member2 @ C @ X5 @ A4 )
=> ( ( B3 @ X5 )
!= ( bot_bot @ ( set @ D ) ) ) )
=> ( ( condit1013018076250108175_below @ B
@ ( complete_Sup_Sup @ ( set @ B )
@ ( image2 @ C @ ( set @ B )
@ ^ [X2: C] : ( image2 @ D @ B @ F2 @ ( B3 @ X2 ) )
@ A4 ) ) )
=> ( ( complete_Inf_Inf @ B @ ( image2 @ D @ B @ F2 @ ( complete_Sup_Sup @ ( set @ D ) @ ( image2 @ C @ ( set @ D ) @ B3 @ A4 ) ) ) )
= ( complete_Inf_Inf @ B
@ ( image2 @ C @ B
@ ^ [X2: C] : ( complete_Inf_Inf @ B @ ( image2 @ D @ B @ F2 @ ( B3 @ X2 ) ) )
@ A4 ) ) ) ) ) ) ) ).
% cINF_UNION
thf(fact_5596_mono__cSup,axiom,
! [B: $tType,A: $tType] :
( ( ( condit1219197933456340205attice @ A )
& ( condit1219197933456340205attice @ B ) )
=> ! [F2: A > B,A4: set @ A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( condit941137186595557371_above @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ord_less_eq @ B @ ( complete_Sup_Sup @ B @ ( image2 @ A @ B @ F2 @ A4 ) ) @ ( F2 @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ) ) ).
% mono_cSup
thf(fact_5597_mono__cSUP,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( ( condit1219197933456340205attice @ A )
& ( condit1219197933456340205attice @ B ) )
=> ! [F2: A > B,A4: C > A,I6: set @ C] :
( ( order_mono @ A @ B @ F2 )
=> ( ( condit941137186595557371_above @ A @ ( image2 @ C @ A @ A4 @ I6 ) )
=> ( ( I6
!= ( bot_bot @ ( set @ C ) ) )
=> ( ord_less_eq @ B
@ ( complete_Sup_Sup @ B
@ ( image2 @ C @ B
@ ^ [X2: C] : ( F2 @ ( A4 @ X2 ) )
@ I6 ) )
@ ( F2 @ ( complete_Sup_Sup @ A @ ( image2 @ C @ A @ A4 @ I6 ) ) ) ) ) ) ) ) ).
% mono_cSUP
thf(fact_5598_cSUP__UNION,axiom,
! [B: $tType,D: $tType,C: $tType] :
( ( condit1219197933456340205attice @ B )
=> ! [A4: set @ C,B3: C > ( set @ D ),F2: D > B] :
( ( A4
!= ( bot_bot @ ( set @ C ) ) )
=> ( ! [X5: C] :
( ( member2 @ C @ X5 @ A4 )
=> ( ( B3 @ X5 )
!= ( bot_bot @ ( set @ D ) ) ) )
=> ( ( condit941137186595557371_above @ B
@ ( complete_Sup_Sup @ ( set @ B )
@ ( image2 @ C @ ( set @ B )
@ ^ [X2: C] : ( image2 @ D @ B @ F2 @ ( B3 @ X2 ) )
@ A4 ) ) )
=> ( ( complete_Sup_Sup @ B @ ( image2 @ D @ B @ F2 @ ( complete_Sup_Sup @ ( set @ D ) @ ( image2 @ C @ ( set @ D ) @ B3 @ A4 ) ) ) )
= ( complete_Sup_Sup @ B
@ ( image2 @ C @ B
@ ^ [X2: C] : ( complete_Sup_Sup @ B @ ( image2 @ D @ B @ F2 @ ( B3 @ X2 ) ) )
@ A4 ) ) ) ) ) ) ) ).
% cSUP_UNION
thf(fact_5599_continuous__at__Inf__mono,axiom,
! [B: $tType,A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( topolo1944317154257567458pology @ A )
& ( condit6923001295902523014norder @ B )
& ( topolo1944317154257567458pology @ B ) )
=> ! [F2: A > B,S3: set @ A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ ( complete_Inf_Inf @ A @ S3 ) @ ( set_ord_greaterThan @ A @ ( complete_Inf_Inf @ A @ S3 ) ) ) @ F2 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit1013018076250108175_below @ A @ S3 )
=> ( ( F2 @ ( complete_Inf_Inf @ A @ S3 ) )
= ( complete_Inf_Inf @ B @ ( image2 @ A @ B @ F2 @ S3 ) ) ) ) ) ) ) ) ).
% continuous_at_Inf_mono
thf(fact_5600_continuous__at__Sup__mono,axiom,
! [B: $tType,A: $tType] :
( ( ( condit6923001295902523014norder @ A )
& ( topolo1944317154257567458pology @ A )
& ( condit6923001295902523014norder @ B )
& ( topolo1944317154257567458pology @ B ) )
=> ! [F2: A > B,S3: set @ A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( topolo3448309680560233919inuous @ A @ B @ ( topolo174197925503356063within @ A @ ( complete_Sup_Sup @ A @ S3 ) @ ( set_ord_lessThan @ A @ ( complete_Sup_Sup @ A @ S3 ) ) ) @ F2 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( condit941137186595557371_above @ A @ S3 )
=> ( ( F2 @ ( complete_Sup_Sup @ A @ S3 ) )
= ( complete_Sup_Sup @ B @ ( image2 @ A @ B @ F2 @ S3 ) ) ) ) ) ) ) ) ).
% continuous_at_Sup_mono
thf(fact_5601_relcomp__fold,axiom,
! [C: $tType,B: $tType,A: $tType,R: set @ ( product_prod @ A @ B ),S3: set @ ( product_prod @ B @ C )] :
( ( finite_finite @ ( product_prod @ A @ B ) @ R )
=> ( ( finite_finite @ ( product_prod @ B @ C ) @ S3 )
=> ( ( relcomp @ A @ B @ C @ R @ S3 )
= ( finite_fold @ ( product_prod @ A @ B ) @ ( set @ ( product_prod @ A @ C ) )
@ ( product_case_prod @ A @ B @ ( ( set @ ( product_prod @ A @ C ) ) > ( set @ ( product_prod @ A @ C ) ) )
@ ^ [X2: A,Y2: B,A6: set @ ( product_prod @ A @ C )] :
( finite_fold @ ( product_prod @ B @ C ) @ ( set @ ( product_prod @ A @ C ) )
@ ( product_case_prod @ B @ C @ ( ( set @ ( product_prod @ A @ C ) ) > ( set @ ( product_prod @ A @ C ) ) )
@ ^ [W3: B,Z6: C,A19: set @ ( product_prod @ A @ C )] : ( if @ ( set @ ( product_prod @ A @ C ) ) @ ( Y2 = W3 ) @ ( insert2 @ ( product_prod @ A @ C ) @ ( product_Pair @ A @ C @ X2 @ Z6 ) @ A19 ) @ A19 ) )
@ A6
@ S3 ) )
@ ( bot_bot @ ( set @ ( product_prod @ A @ C ) ) )
@ R ) ) ) ) ).
% relcomp_fold
thf(fact_5602_insert__relcomp__fold,axiom,
! [C: $tType,B: $tType,A: $tType,S3: set @ ( product_prod @ A @ B ),X: product_prod @ C @ A,R: set @ ( product_prod @ C @ A )] :
( ( finite_finite @ ( product_prod @ A @ B ) @ S3 )
=> ( ( relcomp @ C @ A @ B @ ( insert2 @ ( product_prod @ C @ A ) @ X @ R ) @ S3 )
= ( finite_fold @ ( product_prod @ A @ B ) @ ( set @ ( product_prod @ C @ B ) )
@ ( product_case_prod @ A @ B @ ( ( set @ ( product_prod @ C @ B ) ) > ( set @ ( product_prod @ C @ B ) ) )
@ ^ [W3: A,Z6: B,A19: set @ ( product_prod @ C @ B )] :
( if @ ( set @ ( product_prod @ C @ B ) )
@ ( ( product_snd @ C @ A @ X )
= W3 )
@ ( insert2 @ ( product_prod @ C @ B ) @ ( product_Pair @ C @ B @ ( product_fst @ C @ A @ X ) @ Z6 ) @ A19 )
@ A19 ) )
@ ( relcomp @ C @ A @ B @ R @ S3 )
@ S3 ) ) ) ).
% insert_relcomp_fold
thf(fact_5603_min__ext__compat,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A ),S3: set @ ( product_prod @ A @ A )] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ ( relcomp @ A @ A @ A @ R @ S3 ) @ R )
=> ( ord_less_eq @ ( set @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) ) @ ( relcomp @ ( set @ A ) @ ( set @ A ) @ ( set @ A ) @ ( min_ext @ A @ R ) @ ( sup_sup @ ( set @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) ) @ ( min_ext @ A @ S3 ) @ ( insert2 @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) @ ( product_Pair @ ( set @ A ) @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) @ ( bot_bot @ ( set @ A ) ) ) @ ( bot_bot @ ( set @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) ) ) ) ) ) @ ( min_ext @ A @ R ) ) ) ).
% min_ext_compat
thf(fact_5604_relpow__finite__bounded1,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A ),K: nat] :
( ( finite_finite @ ( product_prod @ A @ A ) @ R )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ K )
=> ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ K @ R )
@ ( complete_Sup_Sup @ ( set @ ( product_prod @ A @ A ) )
@ ( image2 @ nat @ ( set @ ( product_prod @ A @ A ) )
@ ^ [N: nat] : ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N @ R )
@ ( collect @ nat
@ ^ [N: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N )
& ( ord_less_eq @ nat @ N @ ( finite_card @ ( product_prod @ A @ A ) @ R ) ) ) ) ) ) ) ) ) ).
% relpow_finite_bounded1
thf(fact_5605_listrel__def,axiom,
! [B: $tType,A: $tType] :
( ( listrel @ A @ B )
= ( ^ [R4: set @ ( product_prod @ A @ B )] :
( collect @ ( product_prod @ ( list @ A ) @ ( list @ B ) )
@ ( product_case_prod @ ( list @ A ) @ ( list @ B ) @ $o
@ ( listrelp @ A @ B
@ ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R4 ) ) ) ) ) ) ).
% listrel_def
thf(fact_5606_finite__relpow,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A ),N2: nat] :
( ( finite_finite @ ( product_prod @ A @ A ) @ R )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( finite_finite @ ( product_prod @ A @ A ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) ) ) ) ).
% finite_relpow
thf(fact_5607_listrelp_ONil,axiom,
! [A: $tType,B: $tType,R2: A > B > $o] : ( listrelp @ A @ B @ R2 @ ( nil @ A ) @ ( nil @ B ) ) ).
% listrelp.Nil
thf(fact_5608_relpow__Suc__D2_H,axiom,
! [A: $tType,N2: nat,R: set @ ( product_prod @ A @ A ),X3: A,Y3: A,Z4: A] :
( ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X3 @ Y3 ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y3 @ Z4 ) @ R ) )
=> ? [W: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X3 @ W ) @ R )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ W @ Z4 ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) ) ) ) ).
% relpow_Suc_D2'
thf(fact_5609_relpow__Suc__E,axiom,
! [A: $tType,X: A,Z: A,N2: nat,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ ( suc @ N2 ) @ R ) )
=> ~ ! [Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y4 ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z ) @ R ) ) ) ).
% relpow_Suc_E
thf(fact_5610_relpow__Suc__I,axiom,
! [A: $tType,X: A,Y: A,N2: nat,R: set @ ( product_prod @ A @ A ),Z: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ Z ) @ R )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ ( suc @ N2 ) @ R ) ) ) ) ).
% relpow_Suc_I
thf(fact_5611_relpow__Suc__D2,axiom,
! [A: $tType,X: A,Z: A,N2: nat,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ ( suc @ N2 ) @ R ) )
=> ? [Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y4 ) @ R )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) ) ) ) ).
% relpow_Suc_D2
thf(fact_5612_relpow__Suc__E2,axiom,
! [A: $tType,X: A,Z: A,N2: nat,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ ( suc @ N2 ) @ R ) )
=> ~ ! [Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y4 ) @ R )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) ) ) ) ).
% relpow_Suc_E2
thf(fact_5613_relpow__Suc__I2,axiom,
! [A: $tType,X: A,Y: A,R: set @ ( product_prod @ A @ A ),Z: A,N2: nat] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ Z ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ ( suc @ N2 ) @ R ) ) ) ) ).
% relpow_Suc_I2
thf(fact_5614_relpow__0__I,axiom,
! [A: $tType,X: A,R: set @ ( product_prod @ A @ A )] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ X ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ ( zero_zero @ nat ) @ R ) ) ).
% relpow_0_I
thf(fact_5615_relpow__0__E,axiom,
! [A: $tType,X: A,Y: A,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ ( zero_zero @ nat ) @ R ) )
=> ( X = Y ) ) ).
% relpow_0_E
thf(fact_5616_relpow_Osimps_I2_J,axiom,
! [A: $tType,N2: nat,R: set @ ( product_prod @ A @ A )] :
( ( compow @ ( set @ ( product_prod @ A @ A ) ) @ ( suc @ N2 ) @ R )
= ( relcomp @ A @ A @ A @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) @ R ) ) ).
% relpow.simps(2)
thf(fact_5617_relpow__add,axiom,
! [A: $tType,M: nat,N2: nat,R: set @ ( product_prod @ A @ A )] :
( ( compow @ ( set @ ( product_prod @ A @ A ) ) @ ( plus_plus @ nat @ M @ N2 ) @ R )
= ( relcomp @ A @ A @ A @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ M @ R ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) ) ) ).
% relpow_add
thf(fact_5618_relpowp__relpow__eq,axiom,
! [A: $tType,N2: nat,R: set @ ( product_prod @ A @ A )] :
( ( compow @ ( A > A > $o ) @ N2
@ ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R ) )
= ( ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) ) ) ) ).
% relpowp_relpow_eq
thf(fact_5619_relpow__E2,axiom,
! [A: $tType,X: A,Z: A,N2: nat,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) )
=> ( ( ( N2
= ( zero_zero @ nat ) )
=> ( X != Z ) )
=> ~ ! [Y4: A,M3: nat] :
( ( N2
= ( suc @ M3 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y4 ) @ R )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ M3 @ R ) ) ) ) ) ) ).
% relpow_E2
thf(fact_5620_relpow__E,axiom,
! [A: $tType,X: A,Z: A,N2: nat,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) )
=> ( ( ( N2
= ( zero_zero @ nat ) )
=> ( X != Z ) )
=> ~ ! [Y4: A,M3: nat] :
( ( N2
= ( suc @ M3 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y4 ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ M3 @ R ) )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z ) @ R ) ) ) ) ) ).
% relpow_E
thf(fact_5621_relpow__empty,axiom,
! [A: $tType,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ) ).
% relpow_empty
thf(fact_5622_relpow__fun__conv,axiom,
! [A: $tType,A3: A,B2: A,N2: nat,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N2 @ R ) )
= ( ? [F3: nat > A] :
( ( ( F3 @ ( zero_zero @ nat ) )
= A3 )
& ( ( F3 @ N2 )
= B2 )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ N2 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ ( F3 @ I5 ) @ ( F3 @ ( suc @ I5 ) ) ) @ R ) ) ) ) ) ).
% relpow_fun_conv
thf(fact_5623_relpow__finite__bounded,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A ),K: nat] :
( ( finite_finite @ ( product_prod @ A @ A ) @ R )
=> ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ K @ R )
@ ( complete_Sup_Sup @ ( set @ ( product_prod @ A @ A ) )
@ ( image2 @ nat @ ( set @ ( product_prod @ A @ A ) )
@ ^ [N: nat] : ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N @ R )
@ ( collect @ nat
@ ^ [N: nat] : ( ord_less_eq @ nat @ N @ ( finite_card @ ( product_prod @ A @ A ) @ R ) ) ) ) ) ) ) ).
% relpow_finite_bounded
thf(fact_5624_listrelp__listrel__eq,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ B )] :
( ( listrelp @ A @ B
@ ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R2 ) )
= ( ^ [X2: list @ A,Y2: list @ B] : ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ X2 @ Y2 ) @ ( listrel @ A @ B @ R2 ) ) ) ) ).
% listrelp_listrel_eq
thf(fact_5625_max__ext__compat,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A ),S3: set @ ( product_prod @ A @ A )] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ ( relcomp @ A @ A @ A @ R @ S3 ) @ R )
=> ( ord_less_eq @ ( set @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) ) @ ( relcomp @ ( set @ A ) @ ( set @ A ) @ ( set @ A ) @ ( max_ext @ A @ R ) @ ( sup_sup @ ( set @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) ) @ ( max_ext @ A @ S3 ) @ ( insert2 @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) @ ( product_Pair @ ( set @ A ) @ ( set @ A ) @ ( bot_bot @ ( set @ A ) ) @ ( bot_bot @ ( set @ A ) ) ) @ ( bot_bot @ ( set @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) ) ) ) ) ) @ ( max_ext @ A @ R ) ) ) ).
% max_ext_compat
thf(fact_5626_ntrancl__def,axiom,
! [A: $tType] :
( ( transitive_ntrancl @ A )
= ( ^ [N: nat,R5: set @ ( product_prod @ A @ A )] :
( complete_Sup_Sup @ ( set @ ( product_prod @ A @ A ) )
@ ( image2 @ nat @ ( set @ ( product_prod @ A @ A ) )
@ ^ [I5: nat] : ( compow @ ( set @ ( product_prod @ A @ A ) ) @ I5 @ R5 )
@ ( collect @ nat
@ ^ [I5: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ I5 )
& ( ord_less_eq @ nat @ I5 @ ( suc @ N ) ) ) ) ) ) ) ) ).
% ntrancl_def
thf(fact_5627_trancl__finite__eq__relpow,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A )] :
( ( finite_finite @ ( product_prod @ A @ A ) @ R )
=> ( ( transitive_trancl @ A @ R )
= ( complete_Sup_Sup @ ( set @ ( product_prod @ A @ A ) )
@ ( image2 @ nat @ ( set @ ( product_prod @ A @ A ) )
@ ^ [N: nat] : ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N @ R )
@ ( collect @ nat
@ ^ [N: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N )
& ( ord_less_eq @ nat @ N @ ( finite_card @ ( product_prod @ A @ A ) @ R ) ) ) ) ) ) ) ) ).
% trancl_finite_eq_relpow
thf(fact_5628_trancl__empty,axiom,
! [A: $tType] :
( ( transitive_trancl @ A @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ).
% trancl_empty
thf(fact_5629_ntrancl__Zero,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A )] :
( ( transitive_ntrancl @ A @ ( zero_zero @ nat ) @ R )
= R ) ).
% ntrancl_Zero
thf(fact_5630_trancl_Ocases,axiom,
! [A: $tType,A12: A,A23: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A12 @ A23 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A12 @ A23 ) @ R2 )
=> ~ ! [B5: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A12 @ B5 ) @ ( transitive_trancl @ A @ R2 ) )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B5 @ A23 ) @ R2 ) ) ) ) ).
% trancl.cases
thf(fact_5631_trancl_Osimps,axiom,
! [A: $tType,A12: A,A23: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A12 @ A23 ) @ ( transitive_trancl @ A @ R2 ) )
= ( ? [A5: A,B4: A] :
( ( A12 = A5 )
& ( A23 = B4 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A5 @ B4 ) @ R2 ) )
| ? [A5: A,B4: A,C3: A] :
( ( A12 = A5 )
& ( A23 = C3 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A5 @ B4 ) @ ( transitive_trancl @ A @ R2 ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B4 @ C3 ) @ R2 ) ) ) ) ).
% trancl.simps
thf(fact_5632_trancl_Or__into__trancl,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_trancl @ A @ R2 ) ) ) ).
% trancl.r_into_trancl
thf(fact_5633_tranclE,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ~ ! [C4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ C4 ) @ ( transitive_trancl @ A @ R2 ) )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ C4 @ B2 ) @ R2 ) ) ) ) ).
% tranclE
thf(fact_5634_trancl__trans,axiom,
! [A: $tType,X: A,Y: A,R2: set @ ( product_prod @ A @ A ),Z: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ Z ) @ ( transitive_trancl @ A @ R2 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( transitive_trancl @ A @ R2 ) ) ) ) ).
% trancl_trans
thf(fact_5635_trancl__induct,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),P2: A > $o] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ! [Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ Y4 ) @ R2 )
=> ( P2 @ Y4 ) )
=> ( ! [Y4: A,Z2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ Y4 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z2 ) @ R2 )
=> ( ( P2 @ Y4 )
=> ( P2 @ Z2 ) ) ) )
=> ( P2 @ B2 ) ) ) ) ).
% trancl_induct
thf(fact_5636_r__r__into__trancl,axiom,
! [A: $tType,A3: A,B2: A,R: set @ ( product_prod @ A @ A ),C2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ C2 ) @ R )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ C2 ) @ ( transitive_trancl @ A @ R ) ) ) ) ).
% r_r_into_trancl
thf(fact_5637_converse__tranclE,axiom,
! [A: $tType,X: A,Z: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ R2 )
=> ~ ! [Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y4 ) @ R2 )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z ) @ ( transitive_trancl @ A @ R2 ) ) ) ) ) ).
% converse_tranclE
thf(fact_5638_irrefl__trancl__rD,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),X: A,Y: A] :
( ! [X5: A] :
~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ X5 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
=> ( X != Y ) ) ) ).
% irrefl_trancl_rD
thf(fact_5639_Transitive__Closure_Otrancl__into__trancl,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),C2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ C2 ) @ R2 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ C2 ) @ ( transitive_trancl @ A @ R2 ) ) ) ) ).
% Transitive_Closure.trancl_into_trancl
thf(fact_5640_trancl__into__trancl2,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),C2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ C2 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ C2 ) @ ( transitive_trancl @ A @ R2 ) ) ) ) ).
% trancl_into_trancl2
thf(fact_5641_trancl__trans__induct,axiom,
! [A: $tType,X: A,Y: A,R2: set @ ( product_prod @ A @ A ),P2: A > A > $o] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Y4 ) @ R2 )
=> ( P2 @ X5 @ Y4 ) )
=> ( ! [X5: A,Y4: A,Z2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Y4 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ( P2 @ X5 @ Y4 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z2 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ( P2 @ Y4 @ Z2 )
=> ( P2 @ X5 @ Z2 ) ) ) ) )
=> ( P2 @ X @ Y ) ) ) ) ).
% trancl_trans_induct
thf(fact_5642_converse__trancl__induct,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),P2: A > $o] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ! [Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ B2 ) @ R2 )
=> ( P2 @ Y4 ) )
=> ( ! [Y4: A,Z2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z2 ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Z2 @ B2 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ( P2 @ Z2 )
=> ( P2 @ Y4 ) ) ) )
=> ( P2 @ A3 ) ) ) ) ).
% converse_trancl_induct
thf(fact_5643_trancl__induct2,axiom,
! [A: $tType,B: $tType,Ax: A,Ay: B,Bx: A,By: B,R2: set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ),P2: A > B > $o] :
( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Ax @ Ay ) @ ( product_Pair @ A @ B @ Bx @ By ) ) @ ( transitive_trancl @ ( product_prod @ A @ B ) @ R2 ) )
=> ( ! [A7: A,B5: B] :
( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Ax @ Ay ) @ ( product_Pair @ A @ B @ A7 @ B5 ) ) @ R2 )
=> ( P2 @ A7 @ B5 ) )
=> ( ! [A7: A,B5: B,Aa2: A,Ba: B] :
( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Ax @ Ay ) @ ( product_Pair @ A @ B @ A7 @ B5 ) ) @ ( transitive_trancl @ ( product_prod @ A @ B ) @ R2 ) )
=> ( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A7 @ B5 ) @ ( product_Pair @ A @ B @ Aa2 @ Ba ) ) @ R2 )
=> ( ( P2 @ A7 @ B5 )
=> ( P2 @ Aa2 @ Ba ) ) ) )
=> ( P2 @ Bx @ By ) ) ) ) ).
% trancl_induct2
thf(fact_5644_trancl__set__ntrancl,axiom,
! [A: $tType,Xs: list @ ( product_prod @ A @ A )] :
( ( transitive_trancl @ A @ ( set2 @ ( product_prod @ A @ A ) @ Xs ) )
= ( transitive_ntrancl @ A @ ( minus_minus @ nat @ ( finite_card @ ( product_prod @ A @ A ) @ ( set2 @ ( product_prod @ A @ A ) @ Xs ) ) @ ( one_one @ nat ) ) @ ( set2 @ ( product_prod @ A @ A ) @ Xs ) ) ) ).
% trancl_set_ntrancl
thf(fact_5645_trancl__power,axiom,
! [A: $tType,P4: product_prod @ A @ A,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ P4 @ ( transitive_trancl @ A @ R ) )
= ( ? [N: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N )
& ( member2 @ ( product_prod @ A @ A ) @ P4 @ ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N @ R ) ) ) ) ) ).
% trancl_power
thf(fact_5646_less__eq,axiom,
! [M: nat,N2: nat] :
( ( member2 @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ M @ N2 ) @ ( transitive_trancl @ nat @ pred_nat ) )
= ( ord_less @ nat @ M @ N2 ) ) ).
% less_eq
thf(fact_5647_trancl__insert2,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A )] :
( ( transitive_trancl @ A @ ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 ) )
= ( sup_sup @ ( set @ ( product_prod @ A @ A ) ) @ ( transitive_trancl @ A @ R2 )
@ ( collect @ ( product_prod @ A @ A )
@ ( product_case_prod @ A @ A @ $o
@ ^ [X2: A,Y2: A] :
( ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ A3 ) @ ( transitive_trancl @ A @ R2 ) )
| ( X2 = A3 ) )
& ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ Y2 ) @ ( transitive_trancl @ A @ R2 ) )
| ( Y2 = B2 ) ) ) ) ) ) ) ).
% trancl_insert2
thf(fact_5648_max__ext_Omax__extI,axiom,
! [A: $tType,X7: set @ A,Y6: set @ A,R: set @ ( product_prod @ A @ A )] :
( ( finite_finite @ A @ X7 )
=> ( ( finite_finite @ A @ Y6 )
=> ( ( Y6
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ? [Xa: A] :
( ( member2 @ A @ Xa @ Y6 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Xa ) @ R ) ) )
=> ( member2 @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) @ ( product_Pair @ ( set @ A ) @ ( set @ A ) @ X7 @ Y6 ) @ ( max_ext @ A @ R ) ) ) ) ) ) ).
% max_ext.max_extI
thf(fact_5649_max__ext_Osimps,axiom,
! [A: $tType,A12: set @ A,A23: set @ A,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) @ ( product_Pair @ ( set @ A ) @ ( set @ A ) @ A12 @ A23 ) @ ( max_ext @ A @ R ) )
= ( ( finite_finite @ A @ A12 )
& ( finite_finite @ A @ A23 )
& ( A23
!= ( bot_bot @ ( set @ A ) ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A12 )
=> ? [Y2: A] :
( ( member2 @ A @ Y2 @ A23 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R ) ) ) ) ) ).
% max_ext.simps
thf(fact_5650_max__ext_Ocases,axiom,
! [A: $tType,A12: set @ A,A23: set @ A,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) @ ( product_Pair @ ( set @ A ) @ ( set @ A ) @ A12 @ A23 ) @ ( max_ext @ A @ R ) )
=> ~ ( ( finite_finite @ A @ A12 )
=> ( ( finite_finite @ A @ A23 )
=> ( ( A23
!= ( bot_bot @ ( set @ A ) ) )
=> ~ ! [X3: A] :
( ( member2 @ A @ X3 @ A12 )
=> ? [Xa4: A] :
( ( member2 @ A @ Xa4 @ A23 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X3 @ Xa4 ) @ R ) ) ) ) ) ) ) ).
% max_ext.cases
thf(fact_5651_max__extp__max__ext__eq,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A )] :
( ( max_extp @ A
@ ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R ) )
= ( ^ [X2: set @ A,Y2: set @ A] : ( member2 @ ( product_prod @ ( set @ A ) @ ( set @ A ) ) @ ( product_Pair @ ( set @ A ) @ ( set @ A ) @ X2 @ Y2 ) @ ( max_ext @ A @ R ) ) ) ) ).
% max_extp_max_ext_eq
thf(fact_5652_rtrancl__finite__eq__relpow,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A )] :
( ( finite_finite @ ( product_prod @ A @ A ) @ R )
=> ( ( transitive_rtrancl @ A @ R )
= ( complete_Sup_Sup @ ( set @ ( product_prod @ A @ A ) )
@ ( image2 @ nat @ ( set @ ( product_prod @ A @ A ) )
@ ^ [N: nat] : ( compow @ ( set @ ( product_prod @ A @ A ) ) @ N @ R )
@ ( collect @ nat
@ ^ [N: nat] : ( ord_less_eq @ nat @ N @ ( finite_card @ ( product_prod @ A @ A ) @ R ) ) ) ) ) ) ) ).
% rtrancl_finite_eq_relpow
thf(fact_5653_Max_Oeq__fold_H,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( lattic643756798349783984er_Max @ A )
= ( ^ [A6: set @ A] :
( the2 @ A
@ ( finite_fold @ A @ ( option @ A )
@ ^ [X2: A,Y2: option @ A] : ( some @ A @ ( case_option @ A @ A @ X2 @ ( ord_max @ A @ X2 ) @ Y2 ) )
@ ( none @ A )
@ A6 ) ) ) ) ) ).
% Max.eq_fold'
thf(fact_5654_option_Ocollapse,axiom,
! [A: $tType,Option: option @ A] :
( ( Option
!= ( none @ A ) )
=> ( ( some @ A @ ( the2 @ A @ Option ) )
= Option ) ) ).
% option.collapse
thf(fact_5655_comp__the__Some,axiom,
! [A: $tType] :
( ( comp @ ( option @ A ) @ A @ A @ ( the2 @ A ) @ ( some @ A ) )
= ( id @ A ) ) ).
% comp_the_Some
thf(fact_5656_listrel__rtrancl__refl,axiom,
! [A: $tType,Xs: list @ A,R2: set @ ( product_prod @ A @ A )] : ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Xs ) @ ( listrel @ A @ A @ ( transitive_rtrancl @ A @ R2 ) ) ) ).
% listrel_rtrancl_refl
thf(fact_5657_tranclD,axiom,
! [A: $tType,X: A,Y: A,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_trancl @ A @ R ) )
=> ? [Z2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z2 ) @ R )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Z2 @ Y ) @ ( transitive_rtrancl @ A @ R ) ) ) ) ).
% tranclD
thf(fact_5658_rtranclD,axiom,
! [A: $tType,A3: A,B2: A,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ R ) )
=> ( ( A3 = B2 )
| ( ( A3 != B2 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_trancl @ A @ R ) ) ) ) ) ).
% rtranclD
thf(fact_5659_tranclD2,axiom,
! [A: $tType,X: A,Y: A,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_trancl @ A @ R ) )
=> ? [Z2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z2 ) @ ( transitive_rtrancl @ A @ R ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Z2 @ Y ) @ R ) ) ) ).
% tranclD2
thf(fact_5660_trancl__into__rtrancl,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ).
% trancl_into_rtrancl
thf(fact_5661_rtrancl__eq__or__trancl,axiom,
! [A: $tType,X: A,Y: A,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_rtrancl @ A @ R ) )
= ( ( X = Y )
| ( ( X != Y )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_trancl @ A @ R ) ) ) ) ) ).
% rtrancl_eq_or_trancl
thf(fact_5662_rtrancl__into__trancl1,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),C2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ C2 ) @ R2 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ C2 ) @ ( transitive_trancl @ A @ R2 ) ) ) ) ).
% rtrancl_into_trancl1
thf(fact_5663_rtrancl__into__trancl2,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),C2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ C2 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ C2 ) @ ( transitive_trancl @ A @ R2 ) ) ) ) ).
% rtrancl_into_trancl2
thf(fact_5664_rtrancl__trancl__trancl,axiom,
! [A: $tType,X: A,Y: A,R2: set @ ( product_prod @ A @ A ),Z: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ Z ) @ ( transitive_trancl @ A @ R2 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( transitive_trancl @ A @ R2 ) ) ) ) ).
% rtrancl_trancl_trancl
thf(fact_5665_trancl__rtrancl__trancl,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),C2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ C2 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ C2 ) @ ( transitive_trancl @ A @ R2 ) ) ) ) ).
% trancl_rtrancl_trancl
thf(fact_5666_option_Osel,axiom,
! [A: $tType,X22: A] :
( ( the2 @ A @ ( some @ A @ X22 ) )
= X22 ) ).
% option.sel
thf(fact_5667_listrel__rtrancl__eq__rtrancl__listrel1,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( listrel @ A @ A @ ( transitive_rtrancl @ A @ R2 ) )
= ( transitive_rtrancl @ ( list @ A ) @ ( listrel1 @ A @ R2 ) ) ) ).
% listrel_rtrancl_eq_rtrancl_listrel1
thf(fact_5668_rtrancl__Un__separator__converseE,axiom,
! [A: $tType,A3: A,B2: A,P2: set @ ( product_prod @ A @ A ),Q: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ ( sup_sup @ ( set @ ( product_prod @ A @ A ) ) @ P2 @ Q ) ) )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ B2 ) @ ( transitive_rtrancl @ A @ P2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ X5 ) @ Q )
=> ( Y4 = X5 ) ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ P2 ) ) ) ) ).
% rtrancl_Un_separator_converseE
thf(fact_5669_rtrancl__Un__separatorE,axiom,
! [A: $tType,A3: A,B2: A,P2: set @ ( product_prod @ A @ A ),Q: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ ( sup_sup @ ( set @ ( product_prod @ A @ A ) ) @ P2 @ Q ) ) )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ X5 ) @ ( transitive_rtrancl @ A @ P2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Y4 ) @ Q )
=> ( X5 = Y4 ) ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ P2 ) ) ) ) ).
% rtrancl_Un_separatorE
thf(fact_5670_converse__rtrancl__into__rtrancl,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),C2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ C2 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ C2 ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ).
% converse_rtrancl_into_rtrancl
thf(fact_5671_converse__rtrancl__induct,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),P2: A > $o] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( P2 @ B2 )
=> ( ! [Y4: A,Z2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z2 ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Z2 @ B2 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( P2 @ Z2 )
=> ( P2 @ Y4 ) ) ) )
=> ( P2 @ A3 ) ) ) ) ).
% converse_rtrancl_induct
thf(fact_5672_converse__rtranclE,axiom,
! [A: $tType,X: A,Z: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( X != Z )
=> ~ ! [Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y4 ) @ R2 )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ) ).
% converse_rtranclE
thf(fact_5673_rtrancl__induct,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),P2: A > $o] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( P2 @ A3 )
=> ( ! [Y4: A,Z2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ Y4 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z2 ) @ R2 )
=> ( ( P2 @ Y4 )
=> ( P2 @ Z2 ) ) ) )
=> ( P2 @ B2 ) ) ) ) ).
% rtrancl_induct
thf(fact_5674_rtrancl__trans,axiom,
! [A: $tType,X: A,Y: A,R2: set @ ( product_prod @ A @ A ),Z: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ Z ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ).
% rtrancl_trans
thf(fact_5675_rtranclE,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( A3 != B2 )
=> ~ ! [Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ Y4 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ B2 ) @ R2 ) ) ) ) ).
% rtranclE
thf(fact_5676_rtrancl_Ortrancl__into__rtrancl,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),C2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ C2 ) @ R2 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ C2 ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ).
% rtrancl.rtrancl_into_rtrancl
thf(fact_5677_rtrancl_Ortrancl__refl,axiom,
! [A: $tType,A3: A,R2: set @ ( product_prod @ A @ A )] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ A3 ) @ ( transitive_rtrancl @ A @ R2 ) ) ).
% rtrancl.rtrancl_refl
thf(fact_5678_rtrancl_Osimps,axiom,
! [A: $tType,A12: A,A23: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A12 @ A23 ) @ ( transitive_rtrancl @ A @ R2 ) )
= ( ? [A5: A] :
( ( A12 = A5 )
& ( A23 = A5 ) )
| ? [A5: A,B4: A,C3: A] :
( ( A12 = A5 )
& ( A23 = C3 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A5 @ B4 ) @ ( transitive_rtrancl @ A @ R2 ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B4 @ C3 ) @ R2 ) ) ) ) ).
% rtrancl.simps
thf(fact_5679_rtrancl_Ocases,axiom,
! [A: $tType,A12: A,A23: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A12 @ A23 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( A23 != A12 )
=> ~ ! [B5: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A12 @ B5 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B5 @ A23 ) @ R2 ) ) ) ) ).
% rtrancl.cases
thf(fact_5680_listrel1__rtrancl__subset__rtrancl__listrel1,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] : ( ord_less_eq @ ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) @ ( listrel1 @ A @ ( transitive_rtrancl @ A @ R2 ) ) @ ( transitive_rtrancl @ ( list @ A ) @ ( listrel1 @ A @ R2 ) ) ) ).
% listrel1_rtrancl_subset_rtrancl_listrel1
thf(fact_5681_converse__rtrancl__induct2,axiom,
! [A: $tType,B: $tType,Ax: A,Ay: B,Bx: A,By: B,R2: set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ),P2: A > B > $o] :
( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Ax @ Ay ) @ ( product_Pair @ A @ B @ Bx @ By ) ) @ ( transitive_rtrancl @ ( product_prod @ A @ B ) @ R2 ) )
=> ( ( P2 @ Bx @ By )
=> ( ! [A7: A,B5: B,Aa2: A,Ba: B] :
( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A7 @ B5 ) @ ( product_Pair @ A @ B @ Aa2 @ Ba ) ) @ R2 )
=> ( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Aa2 @ Ba ) @ ( product_Pair @ A @ B @ Bx @ By ) ) @ ( transitive_rtrancl @ ( product_prod @ A @ B ) @ R2 ) )
=> ( ( P2 @ Aa2 @ Ba )
=> ( P2 @ A7 @ B5 ) ) ) )
=> ( P2 @ Ax @ Ay ) ) ) ) ).
% converse_rtrancl_induct2
thf(fact_5682_converse__rtranclE2,axiom,
! [B: $tType,A: $tType,Xa2: A,Xb: B,Za: A,Zb: B,R2: set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) )] :
( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Xa2 @ Xb ) @ ( product_Pair @ A @ B @ Za @ Zb ) ) @ ( transitive_rtrancl @ ( product_prod @ A @ B ) @ R2 ) )
=> ( ( ( product_Pair @ A @ B @ Xa2 @ Xb )
!= ( product_Pair @ A @ B @ Za @ Zb ) )
=> ~ ! [A7: A,B5: B] :
( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Xa2 @ Xb ) @ ( product_Pair @ A @ B @ A7 @ B5 ) ) @ R2 )
=> ~ ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A7 @ B5 ) @ ( product_Pair @ A @ B @ Za @ Zb ) ) @ ( transitive_rtrancl @ ( product_prod @ A @ B ) @ R2 ) ) ) ) ) ).
% converse_rtranclE2
thf(fact_5683_rtrancl__induct2,axiom,
! [A: $tType,B: $tType,Ax: A,Ay: B,Bx: A,By: B,R2: set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ),P2: A > B > $o] :
( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Ax @ Ay ) @ ( product_Pair @ A @ B @ Bx @ By ) ) @ ( transitive_rtrancl @ ( product_prod @ A @ B ) @ R2 ) )
=> ( ( P2 @ Ax @ Ay )
=> ( ! [A7: A,B5: B,Aa2: A,Ba: B] :
( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Ax @ Ay ) @ ( product_Pair @ A @ B @ A7 @ B5 ) ) @ ( transitive_rtrancl @ ( product_prod @ A @ B ) @ R2 ) )
=> ( ( member2 @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) @ ( product_Pair @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A7 @ B5 ) @ ( product_Pair @ A @ B @ Aa2 @ Ba ) ) @ R2 )
=> ( ( P2 @ A7 @ B5 )
=> ( P2 @ Aa2 @ Ba ) ) ) )
=> ( P2 @ Bx @ By ) ) ) ) ).
% rtrancl_induct2
thf(fact_5684_listrel__rtrancl__trans,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A ),Zs: list @ A] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel @ A @ A @ ( transitive_rtrancl @ A @ R2 ) ) )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Ys @ Zs ) @ ( listrel @ A @ A @ ( transitive_rtrancl @ A @ R2 ) ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Zs ) @ ( listrel @ A @ A @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ) ).
% listrel_rtrancl_trans
thf(fact_5685_option_Oexhaust__sel,axiom,
! [A: $tType,Option: option @ A] :
( ( Option
!= ( none @ A ) )
=> ( Option
= ( some @ A @ ( the2 @ A @ Option ) ) ) ) ).
% option.exhaust_sel
thf(fact_5686_rtrancl__listrel1__eq__len,axiom,
! [A: $tType,X: list @ A,Y: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Y ) @ ( transitive_rtrancl @ ( list @ A ) @ ( listrel1 @ A @ R2 ) ) )
=> ( ( size_size @ ( list @ A ) @ X )
= ( size_size @ ( list @ A ) @ Y ) ) ) ).
% rtrancl_listrel1_eq_len
thf(fact_5687_listrel__reflcl__if__listrel1,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel1 @ A @ R2 ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel @ A @ A @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ).
% listrel_reflcl_if_listrel1
thf(fact_5688_rtrancl__listrel1__if__listrel,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel @ A @ A @ R2 ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( transitive_rtrancl @ ( list @ A ) @ ( listrel1 @ A @ R2 ) ) ) ) ).
% rtrancl_listrel1_if_listrel
thf(fact_5689_pred__nat__trancl__eq__le,axiom,
! [M: nat,N2: nat] :
( ( member2 @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ M @ N2 ) @ ( transitive_rtrancl @ nat @ pred_nat ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ).
% pred_nat_trancl_eq_le
thf(fact_5690_listrel__subset__rtrancl__listrel1,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] : ( ord_less_eq @ ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) @ ( listrel @ A @ A @ R2 ) @ ( transitive_rtrancl @ ( list @ A ) @ ( listrel1 @ A @ R2 ) ) ) ).
% listrel_subset_rtrancl_listrel1
thf(fact_5691_Max_Oinfinite,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ~ ( finite_finite @ A @ A4 )
=> ( ( lattic643756798349783984er_Max @ A @ A4 )
= ( the2 @ A @ ( none @ A ) ) ) ) ) ).
% Max.infinite
thf(fact_5692_option_Osplit__sel,axiom,
! [B: $tType,A: $tType,P2: B > $o,F1: B,F22: A > B,Option: option @ A] :
( ( P2 @ ( case_option @ B @ A @ F1 @ F22 @ Option ) )
= ( ( ( Option
= ( none @ A ) )
=> ( P2 @ F1 ) )
& ( ( Option
= ( some @ A @ ( the2 @ A @ Option ) ) )
=> ( P2 @ ( F22 @ ( the2 @ A @ Option ) ) ) ) ) ) ).
% option.split_sel
thf(fact_5693_option_Osplit__sel__asm,axiom,
! [B: $tType,A: $tType,P2: B > $o,F1: B,F22: A > B,Option: option @ A] :
( ( P2 @ ( case_option @ B @ A @ F1 @ F22 @ Option ) )
= ( ~ ( ( ( Option
= ( none @ A ) )
& ~ ( P2 @ F1 ) )
| ( ( Option
= ( some @ A @ ( the2 @ A @ Option ) ) )
& ~ ( P2 @ ( F22 @ ( the2 @ A @ Option ) ) ) ) ) ) ) ).
% option.split_sel_asm
thf(fact_5694_graph__eq__to__snd__dom,axiom,
! [B: $tType,A: $tType] :
( ( graph @ A @ B )
= ( ^ [M2: A > ( option @ B )] :
( image2 @ A @ ( product_prod @ A @ B )
@ ^ [X2: A] : ( product_Pair @ A @ B @ X2 @ ( the2 @ B @ ( M2 @ X2 ) ) )
@ ( dom @ A @ B @ M2 ) ) ) ) ).
% graph_eq_to_snd_dom
thf(fact_5695_rtrancl__insert,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A )] :
( ( transitive_rtrancl @ A @ ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 ) )
= ( sup_sup @ ( set @ ( product_prod @ A @ A ) ) @ ( transitive_rtrancl @ A @ R2 )
@ ( collect @ ( product_prod @ A @ A )
@ ( product_case_prod @ A @ A @ $o
@ ^ [X2: A,Y2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ A3 ) @ ( transitive_rtrancl @ A @ R2 ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ Y2 ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ) ) ) ).
% rtrancl_insert
thf(fact_5696_trancl__insert,axiom,
! [A: $tType,Y: A,X: A,R2: set @ ( product_prod @ A @ A )] :
( ( transitive_trancl @ A @ ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ X ) @ R2 ) )
= ( sup_sup @ ( set @ ( product_prod @ A @ A ) ) @ ( transitive_trancl @ A @ R2 )
@ ( collect @ ( product_prod @ A @ A )
@ ( product_case_prod @ A @ A @ $o
@ ^ [A5: A,B4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A5 @ Y ) @ ( transitive_rtrancl @ A @ R2 ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ B4 ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ) ) ) ).
% trancl_insert
thf(fact_5697_max__ext__def,axiom,
! [A: $tType] :
( ( max_ext @ A )
= ( ^ [R5: set @ ( product_prod @ A @ A )] :
( collect @ ( product_prod @ ( set @ A ) @ ( set @ A ) )
@ ( product_case_prod @ ( set @ A ) @ ( set @ A ) @ $o
@ ( max_extp @ A
@ ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R5 ) ) ) ) ) ) ).
% max_ext_def
thf(fact_5698_Sup__fin_Oeq__fold_H,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ( ( lattic5882676163264333800up_fin @ A )
= ( ^ [A6: set @ A] :
( the2 @ A
@ ( finite_fold @ A @ ( option @ A )
@ ^ [X2: A,Y2: option @ A] : ( some @ A @ ( case_option @ A @ A @ X2 @ ( sup_sup @ A @ X2 ) @ Y2 ) )
@ ( none @ A )
@ A6 ) ) ) ) ) ).
% Sup_fin.eq_fold'
thf(fact_5699_Inf__fin_Oeq__fold_H,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ( ( lattic7752659483105999362nf_fin @ A )
= ( ^ [A6: set @ A] :
( the2 @ A
@ ( finite_fold @ A @ ( option @ A )
@ ^ [X2: A,Y2: option @ A] : ( some @ A @ ( case_option @ A @ A @ X2 @ ( inf_inf @ A @ X2 ) @ Y2 ) )
@ ( none @ A )
@ A6 ) ) ) ) ) ).
% Inf_fin.eq_fold'
thf(fact_5700_Min_Oeq__fold_H,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( lattic643756798350308766er_Min @ A )
= ( ^ [A6: set @ A] :
( the2 @ A
@ ( finite_fold @ A @ ( option @ A )
@ ^ [X2: A,Y2: option @ A] : ( some @ A @ ( case_option @ A @ A @ X2 @ ( ord_min @ A @ X2 ) @ Y2 ) )
@ ( none @ A )
@ A6 ) ) ) ) ) ).
% Min.eq_fold'
thf(fact_5701_Min__singleton,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A] :
( ( lattic643756798350308766er_Min @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= X ) ) ).
% Min_singleton
thf(fact_5702_inf__Sup__absorb,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [A4: set @ A,A3: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( ( inf_inf @ A @ A3 @ ( lattic5882676163264333800up_fin @ A @ A4 ) )
= A3 ) ) ) ) ).
% inf_Sup_absorb
thf(fact_5703_Inf__fin_Osingleton,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A] :
( ( lattic7752659483105999362nf_fin @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= X ) ) ).
% Inf_fin.singleton
thf(fact_5704_Sup__fin_Osingleton,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A] :
( ( lattic5882676163264333800up_fin @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= X ) ) ).
% Sup_fin.singleton
thf(fact_5705_sup__Inf__absorb,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [A4: set @ A,A3: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( ( sup_sup @ A @ ( lattic7752659483105999362nf_fin @ A @ A4 ) @ A3 )
= A3 ) ) ) ) ).
% sup_Inf_absorb
thf(fact_5706_Min_Obounded__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ A @ X @ ( lattic643756798350308766er_Min @ A @ A4 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ X @ X2 ) ) ) ) ) ) ) ).
% Min.bounded_iff
thf(fact_5707_Min__gr__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less @ A @ X @ ( lattic643756798350308766er_Min @ A @ A4 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less @ A @ X @ X2 ) ) ) ) ) ) ) ).
% Min_gr_iff
thf(fact_5708_Min__const,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ B,C2: A] :
( ( finite_finite @ B @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( lattic643756798350308766er_Min @ A
@ ( image2 @ B @ A
@ ^ [Uu3: B] : C2
@ A4 ) )
= C2 ) ) ) ) ).
% Min_const
thf(fact_5709_Inf__fin_Oinsert,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic7752659483105999362nf_fin @ A @ ( insert2 @ A @ X @ A4 ) )
= ( inf_inf @ A @ X @ ( lattic7752659483105999362nf_fin @ A @ A4 ) ) ) ) ) ) ).
% Inf_fin.insert
thf(fact_5710_Sup__fin_Oinsert,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic5882676163264333800up_fin @ A @ ( insert2 @ A @ X @ A4 ) )
= ( sup_sup @ A @ X @ ( lattic5882676163264333800up_fin @ A @ A4 ) ) ) ) ) ) ).
% Sup_fin.insert
thf(fact_5711_Min__insert,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798350308766er_Min @ A @ ( insert2 @ A @ X @ A4 ) )
= ( ord_min @ A @ X @ ( lattic643756798350308766er_Min @ A @ A4 ) ) ) ) ) ) ).
% Min_insert
thf(fact_5712_minus__Min__eq__Max,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [S3: set @ A] :
( ( finite_finite @ A @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( uminus_uminus @ A @ ( lattic643756798350308766er_Min @ A @ S3 ) )
= ( lattic643756798349783984er_Max @ A @ ( image2 @ A @ A @ ( uminus_uminus @ A ) @ S3 ) ) ) ) ) ) ).
% minus_Min_eq_Max
thf(fact_5713_minus__Max__eq__Min,axiom,
! [A: $tType] :
( ( linord5086331880401160121up_add @ A )
=> ! [S3: set @ A] :
( ( finite_finite @ A @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( uminus_uminus @ A @ ( lattic643756798349783984er_Max @ A @ S3 ) )
= ( lattic643756798350308766er_Min @ A @ ( image2 @ A @ A @ ( uminus_uminus @ A ) @ S3 ) ) ) ) ) ) ).
% minus_Max_eq_Min
thf(fact_5714_Inf__fin__le__Sup__fin,axiom,
! [A: $tType] :
( ( lattice @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ord_less_eq @ A @ ( lattic7752659483105999362nf_fin @ A @ A4 ) @ ( lattic5882676163264333800up_fin @ A @ A4 ) ) ) ) ) ).
% Inf_fin_le_Sup_fin
thf(fact_5715_Inf__fin__Min,axiom,
! [A: $tType] :
( ( ( semilattice_inf @ A )
& ( linorder @ A ) )
=> ( ( lattic7752659483105999362nf_fin @ A )
= ( lattic643756798350308766er_Min @ A ) ) ) ).
% Inf_fin_Min
thf(fact_5716_Sup__fin__Max,axiom,
! [A: $tType] :
( ( ( semilattice_sup @ A )
& ( linorder @ A ) )
=> ( ( lattic5882676163264333800up_fin @ A )
= ( lattic643756798349783984er_Max @ A ) ) ) ).
% Sup_fin_Max
thf(fact_5717_Min__le,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ A @ ( lattic643756798350308766er_Min @ A @ A4 ) @ X ) ) ) ) ).
% Min_le
thf(fact_5718_Min__eqI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ! [Y4: A] :
( ( member2 @ A @ Y4 @ A4 )
=> ( ord_less_eq @ A @ X @ Y4 ) )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( lattic643756798350308766er_Min @ A @ A4 )
= X ) ) ) ) ) ).
% Min_eqI
thf(fact_5719_Min_OcoboundedI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,A3: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( ord_less_eq @ A @ ( lattic643756798350308766er_Min @ A @ A4 ) @ A3 ) ) ) ) ).
% Min.coboundedI
thf(fact_5720_Min__in,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ A @ ( lattic643756798350308766er_Min @ A @ A4 ) @ A4 ) ) ) ) ).
% Min_in
thf(fact_5721_Min_Oin__idem,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( ord_min @ A @ X @ ( lattic643756798350308766er_Min @ A @ A4 ) )
= ( lattic643756798350308766er_Min @ A @ A4 ) ) ) ) ) ).
% Min.in_idem
thf(fact_5722_Sup__fin_OcoboundedI,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,A3: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( ord_less_eq @ A @ A3 @ ( lattic5882676163264333800up_fin @ A @ A4 ) ) ) ) ) ).
% Sup_fin.coboundedI
thf(fact_5723_Inf__fin_OcoboundedI,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,A3: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( ord_less_eq @ A @ ( lattic7752659483105999362nf_fin @ A @ A4 ) @ A3 ) ) ) ) ).
% Inf_fin.coboundedI
thf(fact_5724_Inf__fin_Oin__idem,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( inf_inf @ A @ X @ ( lattic7752659483105999362nf_fin @ A @ A4 ) )
= ( lattic7752659483105999362nf_fin @ A @ A4 ) ) ) ) ) ).
% Inf_fin.in_idem
thf(fact_5725_Sup__fin_Oin__idem,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( sup_sup @ A @ X @ ( lattic5882676163264333800up_fin @ A @ A4 ) )
= ( lattic5882676163264333800up_fin @ A @ A4 ) ) ) ) ) ).
% Sup_fin.in_idem
thf(fact_5726_Min_OboundedI,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [A7: A] :
( ( member2 @ A @ A7 @ A4 )
=> ( ord_less_eq @ A @ X @ A7 ) )
=> ( ord_less_eq @ A @ X @ ( lattic643756798350308766er_Min @ A @ A4 ) ) ) ) ) ) ).
% Min.boundedI
thf(fact_5727_Min_OboundedE,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ A @ X @ ( lattic643756798350308766er_Min @ A @ A4 ) )
=> ! [A15: A] :
( ( member2 @ A @ A15 @ A4 )
=> ( ord_less_eq @ A @ X @ A15 ) ) ) ) ) ) ).
% Min.boundedE
thf(fact_5728_eq__Min__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,M: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( M
= ( lattic643756798350308766er_Min @ A @ A4 ) )
= ( ( member2 @ A @ M @ A4 )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ M @ X2 ) ) ) ) ) ) ) ).
% eq_Min_iff
thf(fact_5729_Min__le__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ A @ ( lattic643756798350308766er_Min @ A @ A4 ) @ X )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( ord_less_eq @ A @ X2 @ X ) ) ) ) ) ) ) ).
% Min_le_iff
thf(fact_5730_Min__eq__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,M: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ( lattic643756798350308766er_Min @ A @ A4 )
= M )
= ( ( member2 @ A @ M @ A4 )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ M @ X2 ) ) ) ) ) ) ) ).
% Min_eq_iff
thf(fact_5731_Min__less__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less @ A @ ( lattic643756798350308766er_Min @ A @ A4 ) @ X )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( ord_less @ A @ X2 @ X ) ) ) ) ) ) ) ).
% Min_less_iff
thf(fact_5732_Min__insert2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,A3: A] :
( ( finite_finite @ A @ A4 )
=> ( ! [B5: A] :
( ( member2 @ A @ B5 @ A4 )
=> ( ord_less_eq @ A @ A3 @ B5 ) )
=> ( ( lattic643756798350308766er_Min @ A @ ( insert2 @ A @ A3 @ A4 ) )
= A3 ) ) ) ) ).
% Min_insert2
thf(fact_5733_cInf__eq__Min,axiom,
! [A: $tType] :
( ( condit6923001295902523014norder @ A )
=> ! [X7: set @ A] :
( ( finite_finite @ A @ X7 )
=> ( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Inf_Inf @ A @ X7 )
= ( lattic643756798350308766er_Min @ A @ X7 ) ) ) ) ) ).
% cInf_eq_Min
thf(fact_5734_Min__Inf,axiom,
! [A: $tType] :
( ( comple5582772986160207858norder @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798350308766er_Min @ A @ A4 )
= ( complete_Inf_Inf @ A @ A4 ) ) ) ) ) ).
% Min_Inf
thf(fact_5735_Min_Oinfinite,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ~ ( finite_finite @ A @ A4 )
=> ( ( lattic643756798350308766er_Min @ A @ A4 )
= ( the2 @ A @ ( none @ A ) ) ) ) ) ).
% Min.infinite
thf(fact_5736_Sup__fin_Obounded__iff,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ A @ ( lattic5882676163264333800up_fin @ A @ A4 ) @ X )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ X2 @ X ) ) ) ) ) ) ) ).
% Sup_fin.bounded_iff
thf(fact_5737_Inf__fin_Obounded__iff,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ A @ X @ ( lattic7752659483105999362nf_fin @ A @ A4 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ X @ X2 ) ) ) ) ) ) ) ).
% Inf_fin.bounded_iff
thf(fact_5738_Sup__fin_OboundedI,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [A7: A] :
( ( member2 @ A @ A7 @ A4 )
=> ( ord_less_eq @ A @ A7 @ X ) )
=> ( ord_less_eq @ A @ ( lattic5882676163264333800up_fin @ A @ A4 ) @ X ) ) ) ) ) ).
% Sup_fin.boundedI
thf(fact_5739_Sup__fin_OboundedE,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ A @ ( lattic5882676163264333800up_fin @ A @ A4 ) @ X )
=> ! [A15: A] :
( ( member2 @ A @ A15 @ A4 )
=> ( ord_less_eq @ A @ A15 @ X ) ) ) ) ) ) ).
% Sup_fin.boundedE
thf(fact_5740_Inf__fin_OboundedI,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [A7: A] :
( ( member2 @ A @ A7 @ A4 )
=> ( ord_less_eq @ A @ X @ A7 ) )
=> ( ord_less_eq @ A @ X @ ( lattic7752659483105999362nf_fin @ A @ A4 ) ) ) ) ) ) ).
% Inf_fin.boundedI
thf(fact_5741_Inf__fin_OboundedE,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ A @ X @ ( lattic7752659483105999362nf_fin @ A @ A4 ) )
=> ! [A15: A] :
( ( member2 @ A @ A15 @ A4 )
=> ( ord_less_eq @ A @ X @ A15 ) ) ) ) ) ) ).
% Inf_fin.boundedE
thf(fact_5742_Sup__fin__Sup,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic5882676163264333800up_fin @ A @ A4 )
= ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ).
% Sup_fin_Sup
thf(fact_5743_cSup__eq__Sup__fin,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A] :
( ( finite_finite @ A @ X7 )
=> ( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Sup_Sup @ A @ X7 )
= ( lattic5882676163264333800up_fin @ A @ X7 ) ) ) ) ) ).
% cSup_eq_Sup_fin
thf(fact_5744_cInf__eq__Inf__fin,axiom,
! [A: $tType] :
( ( condit1219197933456340205attice @ A )
=> ! [X7: set @ A] :
( ( finite_finite @ A @ X7 )
=> ( ( X7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( complete_Inf_Inf @ A @ X7 )
= ( lattic7752659483105999362nf_fin @ A @ X7 ) ) ) ) ) ).
% cInf_eq_Inf_fin
thf(fact_5745_Inf__fin__Inf,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic7752659483105999362nf_fin @ A @ A4 )
= ( complete_Inf_Inf @ A @ A4 ) ) ) ) ) ).
% Inf_fin_Inf
thf(fact_5746_Inf__fin_Oinfinite,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A] :
( ~ ( finite_finite @ A @ A4 )
=> ( ( lattic7752659483105999362nf_fin @ A @ A4 )
= ( the2 @ A @ ( none @ A ) ) ) ) ) ).
% Inf_fin.infinite
thf(fact_5747_Sup__fin_Oinfinite,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A] :
( ~ ( finite_finite @ A @ A4 )
=> ( ( lattic5882676163264333800up_fin @ A @ A4 )
= ( the2 @ A @ ( none @ A ) ) ) ) ) ).
% Sup_fin.infinite
thf(fact_5748_Min__antimono,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [M7: set @ A,N7: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ M7 @ N7 )
=> ( ( M7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ N7 )
=> ( ord_less_eq @ A @ ( lattic643756798350308766er_Min @ A @ N7 ) @ ( lattic643756798350308766er_Min @ A @ M7 ) ) ) ) ) ) ).
% Min_antimono
thf(fact_5749_Min_Osubset__imp,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ord_less_eq @ A @ ( lattic643756798350308766er_Min @ A @ B3 ) @ ( lattic643756798350308766er_Min @ A @ A4 ) ) ) ) ) ) ).
% Min.subset_imp
thf(fact_5750_hom__Min__commute,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [H2: A > A,N7: set @ A] :
( ! [X5: A,Y4: A] :
( ( H2 @ ( ord_min @ A @ X5 @ Y4 ) )
= ( ord_min @ A @ ( H2 @ X5 ) @ ( H2 @ Y4 ) ) )
=> ( ( finite_finite @ A @ N7 )
=> ( ( N7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( H2 @ ( lattic643756798350308766er_Min @ A @ N7 ) )
= ( lattic643756798350308766er_Min @ A @ ( image2 @ A @ A @ H2 @ N7 ) ) ) ) ) ) ) ).
% hom_Min_commute
thf(fact_5751_Min_Osubset,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( ord_min @ A @ ( lattic643756798350308766er_Min @ A @ B3 ) @ ( lattic643756798350308766er_Min @ A @ A4 ) )
= ( lattic643756798350308766er_Min @ A @ A4 ) ) ) ) ) ) ).
% Min.subset
thf(fact_5752_Min_Oinsert__not__elem,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ~ ( member2 @ A @ X @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798350308766er_Min @ A @ ( insert2 @ A @ X @ A4 ) )
= ( ord_min @ A @ X @ ( lattic643756798350308766er_Min @ A @ A4 ) ) ) ) ) ) ) ).
% Min.insert_not_elem
thf(fact_5753_Min_Oclosed,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A,Y4: A] : ( member2 @ A @ ( ord_min @ A @ X5 @ Y4 ) @ ( insert2 @ A @ X5 @ ( insert2 @ A @ Y4 @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( member2 @ A @ ( lattic643756798350308766er_Min @ A @ A4 ) @ A4 ) ) ) ) ) ).
% Min.closed
thf(fact_5754_mono__Min__commute,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( linorder @ B ) )
=> ! [F2: A > B,A4: set @ A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( F2 @ ( lattic643756798350308766er_Min @ A @ A4 ) )
= ( lattic643756798350308766er_Min @ B @ ( image2 @ A @ B @ F2 @ A4 ) ) ) ) ) ) ) ).
% mono_Min_commute
thf(fact_5755_Min_Ounion,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798350308766er_Min @ A @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( ord_min @ A @ ( lattic643756798350308766er_Min @ A @ A4 ) @ ( lattic643756798350308766er_Min @ A @ B3 ) ) ) ) ) ) ) ) ).
% Min.union
thf(fact_5756_Min_Oeq__fold,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( lattic643756798350308766er_Min @ A @ ( insert2 @ A @ X @ A4 ) )
= ( finite_fold @ A @ A @ ( ord_min @ A ) @ X @ A4 ) ) ) ) ).
% Min.eq_fold
thf(fact_5757_Min__add__commute,axiom,
! [B: $tType,A: $tType] :
( ( linord4140545234300271783up_add @ A )
=> ! [S3: set @ B,F2: B > A,K: A] :
( ( finite_finite @ B @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( lattic643756798350308766er_Min @ A
@ ( image2 @ B @ A
@ ^ [X2: B] : ( plus_plus @ A @ ( F2 @ X2 ) @ K )
@ S3 ) )
= ( plus_plus @ A @ ( lattic643756798350308766er_Min @ A @ ( image2 @ B @ A @ F2 @ S3 ) ) @ K ) ) ) ) ) ).
% Min_add_commute
thf(fact_5758_Inf__fin_Osubset__imp,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ord_less_eq @ A @ ( lattic7752659483105999362nf_fin @ A @ B3 ) @ ( lattic7752659483105999362nf_fin @ A @ A4 ) ) ) ) ) ) ).
% Inf_fin.subset_imp
thf(fact_5759_Sup__fin_Osubset__imp,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ord_less_eq @ A @ ( lattic5882676163264333800up_fin @ A @ A4 ) @ ( lattic5882676163264333800up_fin @ A @ B3 ) ) ) ) ) ) ).
% Sup_fin.subset_imp
thf(fact_5760_Inf__fin_Ohom__commute,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [H2: A > A,N7: set @ A] :
( ! [X5: A,Y4: A] :
( ( H2 @ ( inf_inf @ A @ X5 @ Y4 ) )
= ( inf_inf @ A @ ( H2 @ X5 ) @ ( H2 @ Y4 ) ) )
=> ( ( finite_finite @ A @ N7 )
=> ( ( N7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( H2 @ ( lattic7752659483105999362nf_fin @ A @ N7 ) )
= ( lattic7752659483105999362nf_fin @ A @ ( image2 @ A @ A @ H2 @ N7 ) ) ) ) ) ) ) ).
% Inf_fin.hom_commute
thf(fact_5761_Sup__fin_Ohom__commute,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [H2: A > A,N7: set @ A] :
( ! [X5: A,Y4: A] :
( ( H2 @ ( sup_sup @ A @ X5 @ Y4 ) )
= ( sup_sup @ A @ ( H2 @ X5 ) @ ( H2 @ Y4 ) ) )
=> ( ( finite_finite @ A @ N7 )
=> ( ( N7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( H2 @ ( lattic5882676163264333800up_fin @ A @ N7 ) )
= ( lattic5882676163264333800up_fin @ A @ ( image2 @ A @ A @ H2 @ N7 ) ) ) ) ) ) ) ).
% Sup_fin.hom_commute
thf(fact_5762_Inf__fin_Osubset,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( inf_inf @ A @ ( lattic7752659483105999362nf_fin @ A @ B3 ) @ ( lattic7752659483105999362nf_fin @ A @ A4 ) )
= ( lattic7752659483105999362nf_fin @ A @ A4 ) ) ) ) ) ) ).
% Inf_fin.subset
thf(fact_5763_Sup__fin_Osubset,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( sup_sup @ A @ ( lattic5882676163264333800up_fin @ A @ B3 ) @ ( lattic5882676163264333800up_fin @ A @ A4 ) )
= ( lattic5882676163264333800up_fin @ A @ A4 ) ) ) ) ) ) ).
% Sup_fin.subset
thf(fact_5764_Inf__fin_Oinsert__not__elem,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ~ ( member2 @ A @ X @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic7752659483105999362nf_fin @ A @ ( insert2 @ A @ X @ A4 ) )
= ( inf_inf @ A @ X @ ( lattic7752659483105999362nf_fin @ A @ A4 ) ) ) ) ) ) ) ).
% Inf_fin.insert_not_elem
thf(fact_5765_Inf__fin_Oclosed,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A,Y4: A] : ( member2 @ A @ ( inf_inf @ A @ X5 @ Y4 ) @ ( insert2 @ A @ X5 @ ( insert2 @ A @ Y4 @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( member2 @ A @ ( lattic7752659483105999362nf_fin @ A @ A4 ) @ A4 ) ) ) ) ) ).
% Inf_fin.closed
thf(fact_5766_Sup__fin_Oinsert__not__elem,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ~ ( member2 @ A @ X @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic5882676163264333800up_fin @ A @ ( insert2 @ A @ X @ A4 ) )
= ( sup_sup @ A @ X @ ( lattic5882676163264333800up_fin @ A @ A4 ) ) ) ) ) ) ) ).
% Sup_fin.insert_not_elem
thf(fact_5767_Sup__fin_Oclosed,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A,Y4: A] : ( member2 @ A @ ( sup_sup @ A @ X5 @ Y4 ) @ ( insert2 @ A @ X5 @ ( insert2 @ A @ Y4 @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( member2 @ A @ ( lattic5882676163264333800up_fin @ A @ A4 ) @ A4 ) ) ) ) ) ).
% Sup_fin.closed
thf(fact_5768_Inf__fin_Ounion,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic7752659483105999362nf_fin @ A @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( inf_inf @ A @ ( lattic7752659483105999362nf_fin @ A @ A4 ) @ ( lattic7752659483105999362nf_fin @ A @ B3 ) ) ) ) ) ) ) ) ).
% Inf_fin.union
thf(fact_5769_Sup__fin_Ounion,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic5882676163264333800up_fin @ A @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( sup_sup @ A @ ( lattic5882676163264333800up_fin @ A @ A4 ) @ ( lattic5882676163264333800up_fin @ A @ B3 ) ) ) ) ) ) ) ) ).
% Sup_fin.union
thf(fact_5770_Inf__fin_Oeq__fold,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( lattic7752659483105999362nf_fin @ A @ ( insert2 @ A @ X @ A4 ) )
= ( finite_fold @ A @ A @ ( inf_inf @ A ) @ X @ A4 ) ) ) ) ).
% Inf_fin.eq_fold
thf(fact_5771_Sup__fin_Oeq__fold,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( lattic5882676163264333800up_fin @ A @ ( insert2 @ A @ X @ A4 ) )
= ( finite_fold @ A @ A @ ( sup_sup @ A ) @ X @ A4 ) ) ) ) ).
% Sup_fin.eq_fold
thf(fact_5772_inf__Sup2__distrib,axiom,
! [A: $tType] :
( ( distrib_lattice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( inf_inf @ A @ ( lattic5882676163264333800up_fin @ A @ A4 ) @ ( lattic5882676163264333800up_fin @ A @ B3 ) )
= ( lattic5882676163264333800up_fin @ A
@ ( collect @ A
@ ^ [Uu3: A] :
? [A5: A,B4: A] :
( ( Uu3
= ( inf_inf @ A @ A5 @ B4 ) )
& ( member2 @ A @ A5 @ A4 )
& ( member2 @ A @ B4 @ B3 ) ) ) ) ) ) ) ) ) ) ).
% inf_Sup2_distrib
thf(fact_5773_inf__Sup1__distrib,axiom,
! [A: $tType] :
( ( distrib_lattice @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( inf_inf @ A @ X @ ( lattic5882676163264333800up_fin @ A @ A4 ) )
= ( lattic5882676163264333800up_fin @ A
@ ( collect @ A
@ ^ [Uu3: A] :
? [A5: A] :
( ( Uu3
= ( inf_inf @ A @ X @ A5 ) )
& ( member2 @ A @ A5 @ A4 ) ) ) ) ) ) ) ) ).
% inf_Sup1_distrib
thf(fact_5774_sup__Inf1__distrib,axiom,
! [A: $tType] :
( ( distrib_lattice @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( sup_sup @ A @ X @ ( lattic7752659483105999362nf_fin @ A @ A4 ) )
= ( lattic7752659483105999362nf_fin @ A
@ ( collect @ A
@ ^ [Uu3: A] :
? [A5: A] :
( ( Uu3
= ( sup_sup @ A @ X @ A5 ) )
& ( member2 @ A @ A5 @ A4 ) ) ) ) ) ) ) ) ).
% sup_Inf1_distrib
thf(fact_5775_sup__Inf2__distrib,axiom,
! [A: $tType] :
( ( distrib_lattice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( sup_sup @ A @ ( lattic7752659483105999362nf_fin @ A @ A4 ) @ ( lattic7752659483105999362nf_fin @ A @ B3 ) )
= ( lattic7752659483105999362nf_fin @ A
@ ( collect @ A
@ ^ [Uu3: A] :
? [A5: A,B4: A] :
( ( Uu3
= ( sup_sup @ A @ A5 @ B4 ) )
& ( member2 @ A @ A5 @ A4 )
& ( member2 @ A @ B4 @ B3 ) ) ) ) ) ) ) ) ) ) ).
% sup_Inf2_distrib
thf(fact_5776_Min_Oremove,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798350308766er_Min @ A @ A4 )
= X ) )
& ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798350308766er_Min @ A @ A4 )
= ( ord_min @ A @ X @ ( lattic643756798350308766er_Min @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ) ).
% Min.remove
thf(fact_5777_Min_Oinsert__remove,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798350308766er_Min @ A @ ( insert2 @ A @ X @ A4 ) )
= X ) )
& ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic643756798350308766er_Min @ A @ ( insert2 @ A @ X @ A4 ) )
= ( ord_min @ A @ X @ ( lattic643756798350308766er_Min @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ).
% Min.insert_remove
thf(fact_5778_Inf__fin_Oinsert__remove,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic7752659483105999362nf_fin @ A @ ( insert2 @ A @ X @ A4 ) )
= X ) )
& ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic7752659483105999362nf_fin @ A @ ( insert2 @ A @ X @ A4 ) )
= ( inf_inf @ A @ X @ ( lattic7752659483105999362nf_fin @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ).
% Inf_fin.insert_remove
thf(fact_5779_Inf__fin_Oremove,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic7752659483105999362nf_fin @ A @ A4 )
= X ) )
& ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic7752659483105999362nf_fin @ A @ A4 )
= ( inf_inf @ A @ X @ ( lattic7752659483105999362nf_fin @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ) ).
% Inf_fin.remove
thf(fact_5780_Sup__fin_Oinsert__remove,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic5882676163264333800up_fin @ A @ ( insert2 @ A @ X @ A4 ) )
= X ) )
& ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic5882676163264333800up_fin @ A @ ( insert2 @ A @ X @ A4 ) )
= ( sup_sup @ A @ X @ ( lattic5882676163264333800up_fin @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ).
% Sup_fin.insert_remove
thf(fact_5781_Sup__fin_Oremove,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [A4: set @ A,X: A] :
( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic5882676163264333800up_fin @ A @ A4 )
= X ) )
& ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic5882676163264333800up_fin @ A @ A4 )
= ( sup_sup @ A @ X @ ( lattic5882676163264333800up_fin @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ) ).
% Sup_fin.remove
thf(fact_5782_card__Min__le__sum,axiom,
! [A: $tType,A4: set @ A,F2: A > nat] :
( ( finite_finite @ A @ A4 )
=> ( ord_less_eq @ nat @ ( times_times @ nat @ ( finite_card @ A @ A4 ) @ ( lattic643756798350308766er_Min @ nat @ ( image2 @ A @ nat @ F2 @ A4 ) ) ) @ ( groups7311177749621191930dd_sum @ A @ nat @ F2 @ A4 ) ) ) ).
% card_Min_le_sum
thf(fact_5783_dual__Max,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( lattices_Max @ A
@ ^ [X2: A,Y2: A] : ( ord_less_eq @ A @ Y2 @ X2 ) )
= ( lattic643756798350308766er_Min @ A ) ) ) ).
% dual_Max
thf(fact_5784_f__arg__min__list__f,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ! [Xs: list @ A,F2: A > B] :
( ( Xs
!= ( nil @ A ) )
=> ( ( F2 @ ( arg_min_list @ A @ B @ F2 @ Xs ) )
= ( lattic643756798350308766er_Min @ B @ ( image2 @ A @ B @ F2 @ ( set2 @ A @ Xs ) ) ) ) ) ) ).
% f_arg_min_list_f
thf(fact_5785_min__list__Min,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( min_list @ A @ Xs )
= ( lattic643756798350308766er_Min @ A @ ( set2 @ A @ Xs ) ) ) ) ) ).
% min_list_Min
thf(fact_5786_linorder_OMax_Ocong,axiom,
! [A: $tType] :
( ( lattices_Max @ A )
= ( lattices_Max @ A ) ) ).
% linorder.Max.cong
thf(fact_5787_arg__min__list__in,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ! [Xs: list @ A,F2: A > B] :
( ( Xs
!= ( nil @ A ) )
=> ( member2 @ A @ ( arg_min_list @ A @ B @ F2 @ Xs ) @ ( set2 @ A @ Xs ) ) ) ) ).
% arg_min_list_in
thf(fact_5788_sorted__key__list__of__set__def,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ( ( linord144544945434240204of_set @ B @ A )
= ( ^ [F3: B > A] : ( finite_folding_F @ B @ ( list @ B ) @ ( linorder_insort_key @ B @ A @ F3 ) @ ( nil @ B ) ) ) ) ) ).
% sorted_key_list_of_set_def
thf(fact_5789_comp__fun__idem__on_Ofold__insert__idem2,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,X: A,A4: set @ A,Z: B] :
( ( finite673082921795544331dem_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( finite_fold @ A @ B @ F2 @ Z @ ( insert2 @ A @ X @ A4 ) )
= ( finite_fold @ A @ B @ F2 @ ( F2 @ X @ Z ) @ A4 ) ) ) ) ) ).
% comp_fun_idem_on.fold_insert_idem2
thf(fact_5790_comp__fun__idem__on_Ofold__insert__idem,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,X: A,A4: set @ A,Z: B] :
( ( finite673082921795544331dem_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( finite_fold @ A @ B @ F2 @ Z @ ( insert2 @ A @ X @ A4 ) )
= ( F2 @ X @ ( finite_fold @ A @ B @ F2 @ Z @ A4 ) ) ) ) ) ) ).
% comp_fun_idem_on.fold_insert_idem
thf(fact_5791_comp__fun__idem__on_Ocomp__comp__fun__idem__on,axiom,
! [B: $tType,A: $tType,C: $tType,S3: set @ A,F2: A > B > B,G: C > A,R: set @ C] :
( ( finite673082921795544331dem_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image2 @ C @ A @ G @ ( top_top @ ( set @ C ) ) ) @ S3 )
=> ( finite673082921795544331dem_on @ C @ B @ R @ ( comp @ A @ ( B > B ) @ C @ F2 @ G ) ) ) ) ).
% comp_fun_idem_on.comp_comp_fun_idem_on
thf(fact_5792_folding__on_Oinsert__remove,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,X: A,A4: set @ A,Z: B] :
( ( finite_folding_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( finite_folding_F @ A @ B @ F2 @ Z @ ( insert2 @ A @ X @ A4 ) )
= ( F2 @ X @ ( finite_folding_F @ A @ B @ F2 @ Z @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ).
% folding_on.insert_remove
thf(fact_5793_folding__on_Oremove,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,A4: set @ A,X: A,Z: B] :
( ( finite_folding_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( finite_folding_F @ A @ B @ F2 @ Z @ A4 )
= ( F2 @ X @ ( finite_folding_F @ A @ B @ F2 @ Z @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ).
% folding_on.remove
thf(fact_5794_folding__idem__on_Oinsert__idem,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,X: A,A4: set @ A,Z: B] :
( ( finite1890593828518410140dem_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( finite_folding_F @ A @ B @ F2 @ Z @ ( insert2 @ A @ X @ A4 ) )
= ( F2 @ X @ ( finite_folding_F @ A @ B @ F2 @ Z @ A4 ) ) ) ) ) ) ).
% folding_idem_on.insert_idem
thf(fact_5795_card_Ofolding__on__axioms,axiom,
! [A: $tType] :
( finite_folding_on @ A @ nat @ ( top_top @ ( set @ A ) )
@ ^ [Uu3: A] : suc ) ).
% card.folding_on_axioms
thf(fact_5796_folding__on_Oempty,axiom,
! [A: $tType,B: $tType,S3: set @ A,F2: A > B > B,Z: B] :
( ( finite_folding_on @ A @ B @ S3 @ F2 )
=> ( ( finite_folding_F @ A @ B @ F2 @ Z @ ( bot_bot @ ( set @ A ) ) )
= Z ) ) ).
% folding_on.empty
thf(fact_5797_sorted__list__of__set_Ofold__insort__key_Ofolding__on__axioms,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( finite_folding_on @ A @ ( list @ A ) @ ( top_top @ ( set @ A ) )
@ ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2 ) ) ) ).
% sorted_list_of_set.fold_insort_key.folding_on_axioms
thf(fact_5798_card__def,axiom,
! [B: $tType] :
( ( finite_card @ B )
= ( finite_folding_F @ B @ nat
@ ^ [Uu3: B] : suc
@ ( zero_zero @ nat ) ) ) ).
% card_def
thf(fact_5799_folding__on_Oinsert,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,X: A,A4: set @ A,Z: B] :
( ( finite_folding_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( ~ ( member2 @ A @ X @ A4 )
=> ( ( finite_folding_F @ A @ B @ F2 @ Z @ ( insert2 @ A @ X @ A4 ) )
= ( F2 @ X @ ( finite_folding_F @ A @ B @ F2 @ Z @ A4 ) ) ) ) ) ) ) ).
% folding_on.insert
thf(fact_5800_ntrancl__Suc,axiom,
! [A: $tType,N2: nat,R: set @ ( product_prod @ A @ A )] :
( ( transitive_ntrancl @ A @ ( suc @ N2 ) @ R )
= ( relcomp @ A @ A @ A @ ( transitive_ntrancl @ A @ N2 @ R ) @ ( sup_sup @ ( set @ ( product_prod @ A @ A ) ) @ ( id2 @ A ) @ R ) ) ) ).
% ntrancl_Suc
thf(fact_5801_map__of__zip__nth,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,I: nat] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( distinct @ A @ Xs )
=> ( ( ord_less @ nat @ I @ ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( map_of @ A @ B @ ( zip @ A @ B @ Xs @ Ys ) @ ( nth @ A @ Xs @ I ) )
= ( some @ B @ ( nth @ B @ Ys @ I ) ) ) ) ) ) ).
% map_of_zip_nth
thf(fact_5802_dual__max,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( max @ A
@ ^ [X2: A,Y2: A] : ( ord_less_eq @ A @ Y2 @ X2 ) )
= ( ord_min @ A ) ) ) ).
% dual_max
thf(fact_5803_pair__in__Id__conv,axiom,
! [A: $tType,A3: A,B2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( id2 @ A ) )
= ( A3 = B2 ) ) ).
% pair_in_Id_conv
thf(fact_5804_IdI,axiom,
! [A: $tType,A3: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ A3 ) @ ( id2 @ A ) ) ).
% IdI
thf(fact_5805_rtrancl__empty,axiom,
! [A: $tType] :
( ( transitive_rtrancl @ A @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
= ( id2 @ A ) ) ).
% rtrancl_empty
thf(fact_5806_map__of__zip__is__None,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ B,X: A] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( ( map_of @ A @ B @ ( zip @ A @ B @ Xs @ Ys ) @ X )
= ( none @ B ) )
= ( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) ) ) ) ) ).
% map_of_zip_is_None
thf(fact_5807_dom__map__of__zip,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ B] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( dom @ A @ B @ ( map_of @ A @ B @ ( zip @ A @ B @ Xs @ Ys ) ) )
= ( set2 @ A @ Xs ) ) ) ).
% dom_map_of_zip
thf(fact_5808_IdD,axiom,
! [A: $tType,A3: A,B2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( id2 @ A ) )
=> ( A3 = B2 ) ) ).
% IdD
thf(fact_5809_IdE,axiom,
! [A: $tType,P4: product_prod @ A @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ P4 @ ( id2 @ A ) )
=> ~ ! [X5: A] :
( P4
!= ( product_Pair @ A @ A @ X5 @ X5 ) ) ) ).
% IdE
thf(fact_5810_relpow_Osimps_I1_J,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A )] :
( ( compow @ ( set @ ( product_prod @ A @ A ) ) @ ( zero_zero @ nat ) @ R )
= ( id2 @ A ) ) ).
% relpow.simps(1)
thf(fact_5811_Id__def,axiom,
! [A: $tType] :
( ( id2 @ A )
= ( collect @ ( product_prod @ A @ A )
@ ^ [P6: product_prod @ A @ A] :
? [X2: A] :
( P6
= ( product_Pair @ A @ A @ X2 @ X2 ) ) ) ) ).
% Id_def
thf(fact_5812_weak__map__of__SomeI,axiom,
! [A: $tType,B: $tType,K: A,X: B,L: list @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ K @ X ) @ ( set2 @ ( product_prod @ A @ B ) @ L ) )
=> ? [X5: B] :
( ( map_of @ A @ B @ L @ K )
= ( some @ B @ X5 ) ) ) ).
% weak_map_of_SomeI
thf(fact_5813_map__of__SomeD,axiom,
! [A: $tType,B: $tType,Xs: list @ ( product_prod @ B @ A ),K: B,Y: A] :
( ( ( map_of @ B @ A @ Xs @ K )
= ( some @ A @ Y ) )
=> ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ K @ Y ) @ ( set2 @ ( product_prod @ B @ A ) @ Xs ) ) ) ).
% map_of_SomeD
thf(fact_5814_reflcl__set__eq,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( sup_sup @ ( A > A > $o )
@ ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R2 )
@ ^ [Y5: A,Z3: A] : ( Y5 = Z3 ) )
= ( ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ ( sup_sup @ ( set @ ( product_prod @ A @ A ) ) @ R2 @ ( id2 @ A ) ) ) ) ) ).
% reflcl_set_eq
thf(fact_5815_map__of__zip__is__Some,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,X: A] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
= ( ? [Y2: B] :
( ( map_of @ A @ B @ ( zip @ A @ B @ Xs @ Ys ) @ X )
= ( some @ B @ Y2 ) ) ) ) ) ).
% map_of_zip_is_Some
thf(fact_5816_map__of__zip__upd,axiom,
! [A: $tType,B: $tType,Ys: list @ B,Xs: list @ A,Zs: list @ B,X: A,Y: B,Z: B] :
( ( ( size_size @ ( list @ B ) @ Ys )
= ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ( size_size @ ( list @ B ) @ Zs )
= ( size_size @ ( list @ A ) @ Xs ) )
=> ( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( ( fun_upd @ A @ ( option @ B ) @ ( map_of @ A @ B @ ( zip @ A @ B @ Xs @ Ys ) ) @ X @ ( some @ B @ Y ) )
= ( fun_upd @ A @ ( option @ B ) @ ( map_of @ A @ B @ ( zip @ A @ B @ Xs @ Zs ) ) @ X @ ( some @ B @ Z ) ) )
=> ( ( map_of @ A @ B @ ( zip @ A @ B @ Xs @ Ys ) )
= ( map_of @ A @ B @ ( zip @ A @ B @ Xs @ Zs ) ) ) ) ) ) ) ).
% map_of_zip_upd
thf(fact_5817_ran__map__of__zip,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( distinct @ A @ Xs )
=> ( ( ran @ A @ B @ ( map_of @ A @ B @ ( zip @ A @ B @ Xs @ Ys ) ) )
= ( set2 @ B @ Ys ) ) ) ) ).
% ran_map_of_zip
thf(fact_5818_map__of__is__SomeI,axiom,
! [A: $tType,B: $tType,Xys: list @ ( product_prod @ A @ B ),X: A,Y: B] :
( ( distinct @ A @ ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Xys ) )
=> ( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y ) @ ( set2 @ ( product_prod @ A @ B ) @ Xys ) )
=> ( ( map_of @ A @ B @ Xys @ X )
= ( some @ B @ Y ) ) ) ) ).
% map_of_is_SomeI
thf(fact_5819_Some__eq__map__of__iff,axiom,
! [B: $tType,A: $tType,Xys: list @ ( product_prod @ A @ B ),Y: B,X: A] :
( ( distinct @ A @ ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Xys ) )
=> ( ( ( some @ B @ Y )
= ( map_of @ A @ B @ Xys @ X ) )
= ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y ) @ ( set2 @ ( product_prod @ A @ B ) @ Xys ) ) ) ) ).
% Some_eq_map_of_iff
thf(fact_5820_map__of__eq__Some__iff,axiom,
! [B: $tType,A: $tType,Xys: list @ ( product_prod @ A @ B ),X: A,Y: B] :
( ( distinct @ A @ ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Xys ) )
=> ( ( ( map_of @ A @ B @ Xys @ X )
= ( some @ B @ Y ) )
= ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y ) @ ( set2 @ ( product_prod @ A @ B ) @ Xys ) ) ) ) ).
% map_of_eq_Some_iff
thf(fact_5821_map__ident,axiom,
! [A: $tType] :
( ( map @ A @ A
@ ^ [X2: A] : X2 )
= ( ^ [Xs2: list @ A] : Xs2 ) ) ).
% map_ident
thf(fact_5822_map__is__Nil__conv,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( ( map @ B @ A @ F2 @ Xs )
= ( nil @ A ) )
= ( Xs
= ( nil @ B ) ) ) ).
% map_is_Nil_conv
thf(fact_5823_Nil__is__map__conv,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( ( nil @ A )
= ( map @ B @ A @ F2 @ Xs ) )
= ( Xs
= ( nil @ B ) ) ) ).
% Nil_is_map_conv
thf(fact_5824_list_Omap__disc__iff,axiom,
! [B: $tType,A: $tType,F2: A > B,A3: list @ A] :
( ( ( map @ A @ B @ F2 @ A3 )
= ( nil @ B ) )
= ( A3
= ( nil @ A ) ) ) ).
% list.map_disc_iff
thf(fact_5825_map__map,axiom,
! [B: $tType,A: $tType,C: $tType,F2: B > A,G: C > B,Xs: list @ C] :
( ( map @ B @ A @ F2 @ ( map @ C @ B @ G @ Xs ) )
= ( map @ C @ A @ ( comp @ B @ A @ C @ F2 @ G ) @ Xs ) ) ).
% map_map
thf(fact_5826_List_Omap_Ocompositionality,axiom,
! [B: $tType,C: $tType,A: $tType,F2: B > C,G: A > B,List: list @ A] :
( ( map @ B @ C @ F2 @ ( map @ A @ B @ G @ List ) )
= ( map @ A @ C @ ( comp @ B @ C @ A @ F2 @ G ) @ List ) ) ).
% List.map.compositionality
thf(fact_5827_list_Omap__comp,axiom,
! [B: $tType,C: $tType,A: $tType,G: B > C,F2: A > B,V2: list @ A] :
( ( map @ B @ C @ G @ ( map @ A @ B @ F2 @ V2 ) )
= ( map @ A @ C @ ( comp @ B @ C @ A @ G @ F2 ) @ V2 ) ) ).
% list.map_comp
thf(fact_5828_map__eq__conv,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B,G: B > A] :
( ( ( map @ B @ A @ F2 @ Xs )
= ( map @ B @ A @ G @ Xs ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ ( set2 @ B @ Xs ) )
=> ( ( F2 @ X2 )
= ( G @ X2 ) ) ) ) ) ).
% map_eq_conv
thf(fact_5829_length__map,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( size_size @ ( list @ A ) @ ( map @ B @ A @ F2 @ Xs ) )
= ( size_size @ ( list @ B ) @ Xs ) ) ).
% length_map
thf(fact_5830_list_Omap__id0,axiom,
! [A: $tType] :
( ( map @ A @ A @ ( id @ A ) )
= ( id @ ( list @ A ) ) ) ).
% list.map_id0
thf(fact_5831_map__replicate,axiom,
! [A: $tType,B: $tType,F2: B > A,N2: nat,X: B] :
( ( map @ B @ A @ F2 @ ( replicate @ B @ N2 @ X ) )
= ( replicate @ A @ N2 @ ( F2 @ X ) ) ) ).
% map_replicate
thf(fact_5832_list_Oset__map,axiom,
! [B: $tType,A: $tType,F2: A > B,V2: list @ A] :
( ( set2 @ B @ ( map @ A @ B @ F2 @ V2 ) )
= ( image2 @ A @ B @ F2 @ ( set2 @ A @ V2 ) ) ) ).
% list.set_map
thf(fact_5833_map__snd__enumerate,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( map @ ( product_prod @ nat @ A ) @ A @ ( product_snd @ nat @ A ) @ ( enumerate @ A @ N2 @ Xs ) )
= Xs ) ).
% map_snd_enumerate
thf(fact_5834_inj__map__eq__map,axiom,
! [B: $tType,A: $tType,F2: A > B,Xs: list @ A,Ys: list @ A] :
( ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
=> ( ( ( map @ A @ B @ F2 @ Xs )
= ( map @ A @ B @ F2 @ Ys ) )
= ( Xs = Ys ) ) ) ).
% inj_map_eq_map
thf(fact_5835_map__fun__upd,axiom,
! [B: $tType,A: $tType,Y: A,Xs: list @ A,F2: A > B,V2: B] :
( ~ ( member2 @ A @ Y @ ( set2 @ A @ Xs ) )
=> ( ( map @ A @ B @ ( fun_upd @ A @ B @ F2 @ Y @ V2 ) @ Xs )
= ( map @ A @ B @ F2 @ Xs ) ) ) ).
% map_fun_upd
thf(fact_5836_List_Omap_Ocomp,axiom,
! [C: $tType,B: $tType,A: $tType,F2: B > C,G: A > B] :
( ( comp @ ( list @ B ) @ ( list @ C ) @ ( list @ A ) @ ( map @ B @ C @ F2 ) @ ( map @ A @ B @ G ) )
= ( map @ A @ C @ ( comp @ B @ C @ A @ F2 @ G ) ) ) ).
% List.map.comp
thf(fact_5837_map__comp__map,axiom,
! [B: $tType,C: $tType,A: $tType,F2: C > B,G: A > C] :
( ( comp @ ( list @ C ) @ ( list @ B ) @ ( list @ A ) @ ( map @ C @ B @ F2 ) @ ( map @ A @ C @ G ) )
= ( map @ A @ B @ ( comp @ C @ B @ A @ F2 @ G ) ) ) ).
% map_comp_map
thf(fact_5838_size__list__map,axiom,
! [A: $tType,B: $tType,F2: A > nat,G: B > A,Xs: list @ B] :
( ( size_list @ A @ F2 @ ( map @ B @ A @ G @ Xs ) )
= ( size_list @ B @ ( comp @ A @ nat @ B @ F2 @ G ) @ Xs ) ) ).
% size_list_map
thf(fact_5839_nth__map,axiom,
! [B: $tType,A: $tType,N2: nat,Xs: list @ A,F2: A > B] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ B @ ( map @ A @ B @ F2 @ Xs ) @ N2 )
= ( F2 @ ( nth @ A @ Xs @ N2 ) ) ) ) ).
% nth_map
thf(fact_5840_map__fst__zip,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ B] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) )
= Xs ) ) ).
% map_fst_zip
thf(fact_5841_map__snd__zip,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( map @ ( product_prod @ A @ B ) @ B @ ( product_snd @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) )
= Ys ) ) ).
% map_snd_zip
thf(fact_5842_inj__mapI,axiom,
! [B: $tType,A: $tType,F2: A > B] :
( ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
=> ( inj_on @ ( list @ A ) @ ( list @ B ) @ ( map @ A @ B @ F2 ) @ ( top_top @ ( set @ ( list @ A ) ) ) ) ) ).
% inj_mapI
thf(fact_5843_inj__map,axiom,
! [B: $tType,A: $tType,F2: A > B] :
( ( inj_on @ ( list @ A ) @ ( list @ B ) @ ( map @ A @ B @ F2 ) @ ( top_top @ ( set @ ( list @ A ) ) ) )
= ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) ) ) ).
% inj_map
thf(fact_5844_image__set,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( image2 @ B @ A @ F2 @ ( set2 @ B @ Xs ) )
= ( set2 @ A @ ( map @ B @ A @ F2 @ Xs ) ) ) ).
% image_set
thf(fact_5845_zip__map1,axiom,
! [A: $tType,C: $tType,B: $tType,F2: C > A,Xs: list @ C,Ys: list @ B] :
( ( zip @ A @ B @ ( map @ C @ A @ F2 @ Xs ) @ Ys )
= ( map @ ( product_prod @ C @ B ) @ ( product_prod @ A @ B )
@ ( product_case_prod @ C @ B @ ( product_prod @ A @ B )
@ ^ [X2: C] : ( product_Pair @ A @ B @ ( F2 @ X2 ) ) )
@ ( zip @ C @ B @ Xs @ Ys ) ) ) ).
% zip_map1
thf(fact_5846_zip__map2,axiom,
! [B: $tType,A: $tType,C: $tType,Xs: list @ A,F2: C > B,Ys: list @ C] :
( ( zip @ A @ B @ Xs @ ( map @ C @ B @ F2 @ Ys ) )
= ( map @ ( product_prod @ A @ C ) @ ( product_prod @ A @ B )
@ ( product_case_prod @ A @ C @ ( product_prod @ A @ B )
@ ^ [X2: A,Y2: C] : ( product_Pair @ A @ B @ X2 @ ( F2 @ Y2 ) ) )
@ ( zip @ A @ C @ Xs @ Ys ) ) ) ).
% zip_map2
thf(fact_5847_zip__map__map,axiom,
! [B: $tType,A: $tType,C: $tType,D: $tType,F2: C > A,Xs: list @ C,G: D > B,Ys: list @ D] :
( ( zip @ A @ B @ ( map @ C @ A @ F2 @ Xs ) @ ( map @ D @ B @ G @ Ys ) )
= ( map @ ( product_prod @ C @ D ) @ ( product_prod @ A @ B )
@ ( product_case_prod @ C @ D @ ( product_prod @ A @ B )
@ ^ [X2: C,Y2: D] : ( product_Pair @ A @ B @ ( F2 @ X2 ) @ ( G @ Y2 ) ) )
@ ( zip @ C @ D @ Xs @ Ys ) ) ) ).
% zip_map_map
thf(fact_5848_map__zip__map2,axiom,
! [C: $tType,A: $tType,B: $tType,D: $tType,F2: ( product_prod @ B @ C ) > A,Xs: list @ B,G: D > C,Ys: list @ D] :
( ( map @ ( product_prod @ B @ C ) @ A @ F2 @ ( zip @ B @ C @ Xs @ ( map @ D @ C @ G @ Ys ) ) )
= ( map @ ( product_prod @ B @ D ) @ A
@ ( product_case_prod @ B @ D @ A
@ ^ [X2: B,Y2: D] : ( F2 @ ( product_Pair @ B @ C @ X2 @ ( G @ Y2 ) ) ) )
@ ( zip @ B @ D @ Xs @ Ys ) ) ) ).
% map_zip_map2
thf(fact_5849_map__zip__map,axiom,
! [B: $tType,A: $tType,D: $tType,C: $tType,F2: ( product_prod @ B @ C ) > A,G: D > B,Xs: list @ D,Ys: list @ C] :
( ( map @ ( product_prod @ B @ C ) @ A @ F2 @ ( zip @ B @ C @ ( map @ D @ B @ G @ Xs ) @ Ys ) )
= ( map @ ( product_prod @ D @ C ) @ A
@ ( product_case_prod @ D @ C @ A
@ ^ [X2: D,Y2: C] : ( F2 @ ( product_Pair @ B @ C @ ( G @ X2 ) @ Y2 ) ) )
@ ( zip @ D @ C @ Xs @ Ys ) ) ) ).
% map_zip_map
thf(fact_5850_map2__map__map,axiom,
! [B: $tType,A: $tType,C: $tType,D: $tType,H2: B > C > A,F2: D > B,Xs: list @ D,G: D > C] :
( ( map @ ( product_prod @ B @ C ) @ A @ ( product_case_prod @ B @ C @ A @ H2 ) @ ( zip @ B @ C @ ( map @ D @ B @ F2 @ Xs ) @ ( map @ D @ C @ G @ Xs ) ) )
= ( map @ D @ A
@ ^ [X2: D] : ( H2 @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ Xs ) ) ).
% map2_map_map
thf(fact_5851_foldl__map,axiom,
! [A: $tType,B: $tType,C: $tType,G: A > B > A,A3: A,F2: C > B,Xs: list @ C] :
( ( foldl @ A @ B @ G @ A3 @ ( map @ C @ B @ F2 @ Xs ) )
= ( foldl @ A @ C
@ ^ [A5: A,X2: C] : ( G @ A5 @ ( F2 @ X2 ) )
@ A3
@ Xs ) ) ).
% foldl_map
thf(fact_5852_pair__list__eqI,axiom,
! [B: $tType,A: $tType,Xs: list @ ( product_prod @ A @ B ),Ys: list @ ( product_prod @ A @ B )] :
( ( ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Xs )
= ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Ys ) )
=> ( ( ( map @ ( product_prod @ A @ B ) @ B @ ( product_snd @ A @ B ) @ Xs )
= ( map @ ( product_prod @ A @ B ) @ B @ ( product_snd @ A @ B ) @ Ys ) )
=> ( Xs = Ys ) ) ) ).
% pair_list_eqI
thf(fact_5853_map__injective,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B,Ys: list @ B] :
( ( ( map @ B @ A @ F2 @ Xs )
= ( map @ B @ A @ F2 @ Ys ) )
=> ( ( inj_on @ B @ A @ F2 @ ( top_top @ ( set @ B ) ) )
=> ( Xs = Ys ) ) ) ).
% map_injective
thf(fact_5854_list_Omap__ident,axiom,
! [A: $tType,T2: list @ A] :
( ( map @ A @ A
@ ^ [X2: A] : X2
@ T2 )
= T2 ) ).
% list.map_ident
thf(fact_5855_List_Omap_Oidentity,axiom,
! [A: $tType] :
( ( map @ A @ A
@ ^ [X2: A] : X2 )
= ( id @ ( list @ A ) ) ) ).
% List.map.identity
thf(fact_5856_remdups__map__remdups,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( remdups @ A @ ( map @ B @ A @ F2 @ ( remdups @ B @ Xs ) ) )
= ( remdups @ A @ ( map @ B @ A @ F2 @ Xs ) ) ) ).
% remdups_map_remdups
thf(fact_5857_list_Omap__id,axiom,
! [A: $tType,T2: list @ A] :
( ( map @ A @ A @ ( id @ A ) @ T2 )
= T2 ) ).
% list.map_id
thf(fact_5858_rotate1__map,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( rotate1 @ A @ ( map @ B @ A @ F2 @ Xs ) )
= ( map @ B @ A @ F2 @ ( rotate1 @ B @ Xs ) ) ) ).
% rotate1_map
thf(fact_5859_map__update,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B,K: nat,Y: B] :
( ( map @ B @ A @ F2 @ ( list_update @ B @ Xs @ K @ Y ) )
= ( list_update @ A @ ( map @ B @ A @ F2 @ Xs ) @ K @ ( F2 @ Y ) ) ) ).
% map_update
thf(fact_5860_map__concat,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ ( list @ B )] :
( ( map @ B @ A @ F2 @ ( concat @ B @ Xs ) )
= ( concat @ A @ ( map @ ( list @ B ) @ ( list @ A ) @ ( map @ B @ A @ F2 ) @ Xs ) ) ) ).
% map_concat
thf(fact_5861_map__eq__imp__length__eq,axiom,
! [A: $tType,B: $tType,C: $tType,F2: B > A,Xs: list @ B,G: C > A,Ys: list @ C] :
( ( ( map @ B @ A @ F2 @ Xs )
= ( map @ C @ A @ G @ Ys ) )
=> ( ( size_size @ ( list @ B ) @ Xs )
= ( size_size @ ( list @ C ) @ Ys ) ) ) ).
% map_eq_imp_length_eq
thf(fact_5862_take__map,axiom,
! [A: $tType,B: $tType,N2: nat,F2: B > A,Xs: list @ B] :
( ( take @ A @ N2 @ ( map @ B @ A @ F2 @ Xs ) )
= ( map @ B @ A @ F2 @ ( take @ B @ N2 @ Xs ) ) ) ).
% take_map
thf(fact_5863_list_Osimps_I8_J,axiom,
! [A: $tType,B: $tType,F2: A > B] :
( ( map @ A @ B @ F2 @ ( nil @ A ) )
= ( nil @ B ) ) ).
% list.simps(8)
thf(fact_5864_ex__map__conv,axiom,
! [A: $tType,B: $tType,Ys: list @ B,F2: A > B] :
( ( ? [Xs2: list @ A] :
( Ys
= ( map @ A @ B @ F2 @ Xs2 ) ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ ( set2 @ B @ Ys ) )
=> ? [Y2: A] :
( X2
= ( F2 @ Y2 ) ) ) ) ) ).
% ex_map_conv
thf(fact_5865_map__cong,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ A,F2: A > B,G: A > B] :
( ( Xs = Ys )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Ys ) )
=> ( ( F2 @ X5 )
= ( G @ X5 ) ) )
=> ( ( map @ A @ B @ F2 @ Xs )
= ( map @ A @ B @ G @ Ys ) ) ) ) ).
% map_cong
thf(fact_5866_map__idI,axiom,
! [A: $tType,Xs: list @ A,F2: A > A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( F2 @ X5 )
= X5 ) )
=> ( ( map @ A @ A @ F2 @ Xs )
= Xs ) ) ).
% map_idI
thf(fact_5867_map__ext,axiom,
! [B: $tType,A: $tType,Xs: list @ A,F2: A > B,G: A > B] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( F2 @ X5 )
= ( G @ X5 ) ) )
=> ( ( map @ A @ B @ F2 @ Xs )
= ( map @ A @ B @ G @ Xs ) ) ) ).
% map_ext
thf(fact_5868_list_Oinj__map__strong,axiom,
! [B: $tType,A: $tType,X: list @ A,Xa2: list @ A,F2: A > B,Fa: A > B] :
( ! [Z2: A,Za2: A] :
( ( member2 @ A @ Z2 @ ( set2 @ A @ X ) )
=> ( ( member2 @ A @ Za2 @ ( set2 @ A @ Xa2 ) )
=> ( ( ( F2 @ Z2 )
= ( Fa @ Za2 ) )
=> ( Z2 = Za2 ) ) ) )
=> ( ( ( map @ A @ B @ F2 @ X )
= ( map @ A @ B @ Fa @ Xa2 ) )
=> ( X = Xa2 ) ) ) ).
% list.inj_map_strong
thf(fact_5869_list_Omap__cong0,axiom,
! [B: $tType,A: $tType,X: list @ A,F2: A > B,G: A > B] :
( ! [Z2: A] :
( ( member2 @ A @ Z2 @ ( set2 @ A @ X ) )
=> ( ( F2 @ Z2 )
= ( G @ Z2 ) ) )
=> ( ( map @ A @ B @ F2 @ X )
= ( map @ A @ B @ G @ X ) ) ) ).
% list.map_cong0
thf(fact_5870_list_Omap__cong,axiom,
! [B: $tType,A: $tType,X: list @ A,Ya: list @ A,F2: A > B,G: A > B] :
( ( X = Ya )
=> ( ! [Z2: A] :
( ( member2 @ A @ Z2 @ ( set2 @ A @ Ya ) )
=> ( ( F2 @ Z2 )
= ( G @ Z2 ) ) )
=> ( ( map @ A @ B @ F2 @ X )
= ( map @ A @ B @ G @ Ya ) ) ) ) ).
% list.map_cong
thf(fact_5871_nths__map,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B,I6: set @ nat] :
( ( nths @ A @ ( map @ B @ A @ F2 @ Xs ) @ I6 )
= ( map @ B @ A @ F2 @ ( nths @ B @ Xs @ I6 ) ) ) ).
% nths_map
thf(fact_5872_map__replicate__const,axiom,
! [B: $tType,A: $tType,K: A,Lst: list @ B] :
( ( map @ B @ A
@ ^ [X2: B] : K
@ Lst )
= ( replicate @ A @ ( size_size @ ( list @ B ) @ Lst ) @ K ) ) ).
% map_replicate_const
thf(fact_5873_list_Osize__gen__o__map,axiom,
! [B: $tType,A: $tType,F2: B > nat,G: A > B] :
( ( comp @ ( list @ B ) @ nat @ ( list @ A ) @ ( size_list @ B @ F2 ) @ ( map @ A @ B @ G ) )
= ( size_list @ A @ ( comp @ B @ nat @ A @ F2 @ G ) ) ) ).
% list.size_gen_o_map
thf(fact_5874_map__inj__on,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B,Ys: list @ B] :
( ( ( map @ B @ A @ F2 @ Xs )
= ( map @ B @ A @ F2 @ Ys ) )
=> ( ( inj_on @ B @ A @ F2 @ ( sup_sup @ ( set @ B ) @ ( set2 @ B @ Xs ) @ ( set2 @ B @ Ys ) ) )
=> ( Xs = Ys ) ) ) ).
% map_inj_on
thf(fact_5875_inj__on__map__eq__map,axiom,
! [B: $tType,A: $tType,F2: A > B,Xs: list @ A,Ys: list @ A] :
( ( inj_on @ A @ B @ F2 @ ( sup_sup @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ Ys ) ) )
=> ( ( ( map @ A @ B @ F2 @ Xs )
= ( map @ A @ B @ F2 @ Ys ) )
= ( Xs = Ys ) ) ) ).
% inj_on_map_eq_map
thf(fact_5876_distinct__map,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( distinct @ A @ ( map @ B @ A @ F2 @ Xs ) )
= ( ( distinct @ B @ Xs )
& ( inj_on @ B @ A @ F2 @ ( set2 @ B @ Xs ) ) ) ) ).
% distinct_map
thf(fact_5877_remdups__adj__map__injective,axiom,
! [B: $tType,A: $tType,F2: A > B,Xs: list @ A] :
( ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
=> ( ( remdups_adj @ B @ ( map @ A @ B @ F2 @ Xs ) )
= ( map @ A @ B @ F2 @ ( remdups_adj @ A @ Xs ) ) ) ) ).
% remdups_adj_map_injective
thf(fact_5878_zip__map__fst__snd,axiom,
! [B: $tType,A: $tType,Zs: list @ ( product_prod @ A @ B )] :
( ( zip @ A @ B @ ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Zs ) @ ( map @ ( product_prod @ A @ B ) @ B @ ( product_snd @ A @ B ) @ Zs ) )
= Zs ) ).
% zip_map_fst_snd
thf(fact_5879_map__of__eqI,axiom,
! [B: $tType,A: $tType,Xs: list @ ( product_prod @ A @ B ),Ys: list @ ( product_prod @ A @ B )] :
( ( ( set2 @ A @ ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Xs ) )
= ( set2 @ A @ ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Ys ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Xs ) ) )
=> ( ( map_of @ A @ B @ Xs @ X5 )
= ( map_of @ A @ B @ Ys @ X5 ) ) )
=> ( ( map_of @ A @ B @ Xs )
= ( map_of @ A @ B @ Ys ) ) ) ) ).
% map_of_eqI
thf(fact_5880_map__removeAll__inj,axiom,
! [B: $tType,A: $tType,F2: A > B,X: A,Xs: list @ A] :
( ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
=> ( ( map @ A @ B @ F2 @ ( removeAll @ A @ X @ Xs ) )
= ( removeAll @ B @ ( F2 @ X ) @ ( map @ A @ B @ F2 @ Xs ) ) ) ) ).
% map_removeAll_inj
thf(fact_5881_inj__mapD,axiom,
! [B: $tType,A: $tType,F2: A > B] :
( ( inj_on @ ( list @ A ) @ ( list @ B ) @ ( map @ A @ B @ F2 ) @ ( top_top @ ( set @ ( list @ A ) ) ) )
=> ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) ) ) ).
% inj_mapD
thf(fact_5882_zip__left__commute,axiom,
! [B: $tType,A: $tType,C: $tType,Xs: list @ A,Ys: list @ B,Zs: list @ C] :
( ( zip @ A @ ( product_prod @ B @ C ) @ Xs @ ( zip @ B @ C @ Ys @ Zs ) )
= ( map @ ( product_prod @ B @ ( product_prod @ A @ C ) ) @ ( product_prod @ A @ ( product_prod @ B @ C ) )
@ ( product_case_prod @ B @ ( product_prod @ A @ C ) @ ( product_prod @ A @ ( product_prod @ B @ C ) )
@ ^ [Y2: B] :
( product_case_prod @ A @ C @ ( product_prod @ A @ ( product_prod @ B @ C ) )
@ ^ [X2: A,Z6: C] : ( product_Pair @ A @ ( product_prod @ B @ C ) @ X2 @ ( product_Pair @ B @ C @ Y2 @ Z6 ) ) ) )
@ ( zip @ B @ ( product_prod @ A @ C ) @ Ys @ ( zip @ A @ C @ Xs @ Zs ) ) ) ) ).
% zip_left_commute
thf(fact_5883_zip__assoc,axiom,
! [B: $tType,A: $tType,C: $tType,Xs: list @ A,Ys: list @ B,Zs: list @ C] :
( ( zip @ A @ ( product_prod @ B @ C ) @ Xs @ ( zip @ B @ C @ Ys @ Zs ) )
= ( map @ ( product_prod @ ( product_prod @ A @ B ) @ C ) @ ( product_prod @ A @ ( product_prod @ B @ C ) )
@ ( product_case_prod @ ( product_prod @ A @ B ) @ C @ ( product_prod @ A @ ( product_prod @ B @ C ) )
@ ( product_case_prod @ A @ B @ ( C > ( product_prod @ A @ ( product_prod @ B @ C ) ) )
@ ^ [X2: A,Y2: B,Z6: C] : ( product_Pair @ A @ ( product_prod @ B @ C ) @ X2 @ ( product_Pair @ B @ C @ Y2 @ Z6 ) ) ) )
@ ( zip @ ( product_prod @ A @ B ) @ C @ ( zip @ A @ B @ Xs @ Ys ) @ Zs ) ) ) ).
% zip_assoc
thf(fact_5884_zip__commute,axiom,
! [B: $tType,A: $tType] :
( ( zip @ A @ B )
= ( ^ [Xs2: list @ A,Ys3: list @ B] :
( map @ ( product_prod @ B @ A ) @ ( product_prod @ A @ B )
@ ( product_case_prod @ B @ A @ ( product_prod @ A @ B )
@ ^ [X2: B,Y2: A] : ( product_Pair @ A @ B @ Y2 @ X2 ) )
@ ( zip @ B @ A @ Ys3 @ Xs2 ) ) ) ) ).
% zip_commute
thf(fact_5885_zip__eq__conv,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,Zs: list @ ( product_prod @ A @ B )] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( ( zip @ A @ B @ Xs @ Ys )
= Zs )
= ( ( ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Zs )
= Xs )
& ( ( map @ ( product_prod @ A @ B ) @ B @ ( product_snd @ A @ B ) @ Zs )
= Ys ) ) ) ) ).
% zip_eq_conv
thf(fact_5886_distinct__insort__key,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,X: B,Xs: list @ B] :
( ( distinct @ A @ ( map @ B @ A @ F2 @ ( linorder_insort_key @ B @ A @ F2 @ X @ Xs ) ) )
= ( ~ ( member2 @ A @ ( F2 @ X ) @ ( image2 @ B @ A @ F2 @ ( set2 @ B @ Xs ) ) )
& ( distinct @ A @ ( map @ B @ A @ F2 @ Xs ) ) ) ) ) ).
% distinct_insort_key
thf(fact_5887_map__removeAll__inj__on,axiom,
! [B: $tType,A: $tType,F2: A > B,X: A,Xs: list @ A] :
( ( inj_on @ A @ B @ F2 @ ( insert2 @ A @ X @ ( set2 @ A @ Xs ) ) )
=> ( ( map @ A @ B @ F2 @ ( removeAll @ A @ X @ Xs ) )
= ( removeAll @ B @ ( F2 @ X ) @ ( map @ A @ B @ F2 @ Xs ) ) ) ) ).
% map_removeAll_inj_on
thf(fact_5888_eq__key__imp__eq__value,axiom,
! [A: $tType,B: $tType,Xs: list @ ( product_prod @ A @ B ),K: A,V1: B,V22: B] :
( ( distinct @ A @ ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Xs ) )
=> ( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ K @ V1 ) @ ( set2 @ ( product_prod @ A @ B ) @ Xs ) )
=> ( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ K @ V22 ) @ ( set2 @ ( product_prod @ A @ B ) @ Xs ) )
=> ( V1 = V22 ) ) ) ) ).
% eq_key_imp_eq_value
thf(fact_5889_inj__on__mapI,axiom,
! [B: $tType,A: $tType,F2: A > B,A4: set @ ( list @ A )] :
( ( inj_on @ A @ B @ F2 @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ ( list @ A ) @ ( set @ A ) @ ( set2 @ A ) @ A4 ) ) )
=> ( inj_on @ ( list @ A ) @ ( list @ B ) @ ( map @ A @ B @ F2 ) @ A4 ) ) ).
% inj_on_mapI
thf(fact_5890_map__of__zip__map,axiom,
! [B: $tType,A: $tType,Xs: list @ A,F2: A > B] :
( ( map_of @ A @ B @ ( zip @ A @ B @ Xs @ ( map @ A @ B @ F2 @ Xs ) ) )
= ( ^ [X2: A] : ( if @ ( option @ B ) @ ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) ) @ ( some @ B @ ( F2 @ X2 ) ) @ ( none @ B ) ) ) ) ).
% map_of_zip_map
thf(fact_5891_map__fst__zip__take,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ B] :
( ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) )
= ( take @ A @ ( ord_min @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ B ) @ Ys ) ) @ Xs ) ) ).
% map_fst_zip_take
thf(fact_5892_map__snd__zip__take,axiom,
! [B: $tType,A: $tType,Xs: list @ B,Ys: list @ A] :
( ( map @ ( product_prod @ B @ A ) @ A @ ( product_snd @ B @ A ) @ ( zip @ B @ A @ Xs @ Ys ) )
= ( take @ A @ ( ord_min @ nat @ ( size_size @ ( list @ B ) @ Xs ) @ ( size_size @ ( list @ A ) @ Ys ) ) @ Ys ) ) ).
% map_snd_zip_take
thf(fact_5893_map__of__mapk__SomeI,axiom,
! [A: $tType,B: $tType,C: $tType,F2: A > B,T2: list @ ( product_prod @ A @ C ),K: A,X: C] :
( ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
=> ( ( ( map_of @ A @ C @ T2 @ K )
= ( some @ C @ X ) )
=> ( ( map_of @ B @ C
@ ( map @ ( product_prod @ A @ C ) @ ( product_prod @ B @ C )
@ ( product_case_prod @ A @ C @ ( product_prod @ B @ C )
@ ^ [K2: A] : ( product_Pair @ B @ C @ ( F2 @ K2 ) ) )
@ T2 )
@ ( F2 @ K ) )
= ( some @ C @ X ) ) ) ) ).
% map_of_mapk_SomeI
thf(fact_5894_set__map__of__compr,axiom,
! [B: $tType,A: $tType,Xs: list @ ( product_prod @ A @ B )] :
( ( distinct @ A @ ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Xs ) )
=> ( ( set2 @ ( product_prod @ A @ B ) @ Xs )
= ( collect @ ( product_prod @ A @ B )
@ ( product_case_prod @ A @ B @ $o
@ ^ [K2: A,V5: B] :
( ( map_of @ A @ B @ Xs @ K2 )
= ( some @ B @ V5 ) ) ) ) ) ) ).
% set_map_of_compr
thf(fact_5895_set__relcomp,axiom,
! [B: $tType,C: $tType,A: $tType,Xys: list @ ( product_prod @ A @ C ),Yzs: list @ ( product_prod @ C @ B )] :
( ( relcomp @ A @ C @ B @ ( set2 @ ( product_prod @ A @ C ) @ Xys ) @ ( set2 @ ( product_prod @ C @ B ) @ Yzs ) )
= ( set2 @ ( product_prod @ A @ B )
@ ( concat @ ( product_prod @ A @ B )
@ ( map @ ( product_prod @ A @ C ) @ ( list @ ( product_prod @ A @ B ) )
@ ^ [Xy2: product_prod @ A @ C] :
( concat @ ( product_prod @ A @ B )
@ ( map @ ( product_prod @ C @ B ) @ ( list @ ( product_prod @ A @ B ) )
@ ^ [Yz: product_prod @ C @ B] :
( if @ ( list @ ( product_prod @ A @ B ) )
@ ( ( product_snd @ A @ C @ Xy2 )
= ( product_fst @ C @ B @ Yz ) )
@ ( cons @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ ( product_fst @ A @ C @ Xy2 ) @ ( product_snd @ C @ B @ Yz ) ) @ ( nil @ ( product_prod @ A @ B ) ) )
@ ( nil @ ( product_prod @ A @ B ) ) )
@ Yzs ) )
@ Xys ) ) ) ) ).
% set_relcomp
thf(fact_5896_dual__min,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( min @ A
@ ^ [X2: A,Y2: A] : ( ord_less_eq @ A @ Y2 @ X2 ) )
= ( ord_max @ A ) ) ) ).
% dual_min
thf(fact_5897_listrel1__subset__listrel,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),R6: set @ ( product_prod @ A @ A )] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R2 @ R6 )
=> ( ( refl_on @ A @ ( top_top @ ( set @ A ) ) @ R6 )
=> ( ord_less_eq @ ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) @ ( listrel1 @ A @ R2 ) @ ( listrel @ A @ A @ R6 ) ) ) ) ).
% listrel1_subset_listrel
thf(fact_5898_list_Oinject,axiom,
! [A: $tType,X21: A,X222: list @ A,Y21: A,Y222: list @ A] :
( ( ( cons @ A @ X21 @ X222 )
= ( cons @ A @ Y21 @ Y222 ) )
= ( ( X21 = Y21 )
& ( X222 = Y222 ) ) ) ).
% list.inject
thf(fact_5899_list_Osimps_I15_J,axiom,
! [A: $tType,X21: A,X222: list @ A] :
( ( set2 @ A @ ( cons @ A @ X21 @ X222 ) )
= ( insert2 @ A @ X21 @ ( set2 @ A @ X222 ) ) ) ).
% list.simps(15)
thf(fact_5900_nth__Cons__Suc,axiom,
! [A: $tType,X: A,Xs: list @ A,N2: nat] :
( ( nth @ A @ ( cons @ A @ X @ Xs ) @ ( suc @ N2 ) )
= ( nth @ A @ Xs @ N2 ) ) ).
% nth_Cons_Suc
thf(fact_5901_nth__Cons__0,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( nth @ A @ ( cons @ A @ X @ Xs ) @ ( zero_zero @ nat ) )
= X ) ).
% nth_Cons_0
thf(fact_5902_take__Suc__Cons,axiom,
! [A: $tType,N2: nat,X: A,Xs: list @ A] :
( ( take @ A @ ( suc @ N2 ) @ ( cons @ A @ X @ Xs ) )
= ( cons @ A @ X @ ( take @ A @ N2 @ Xs ) ) ) ).
% take_Suc_Cons
thf(fact_5903_insert__Nil,axiom,
! [A: $tType,X: A] :
( ( insert @ A @ X @ ( nil @ A ) )
= ( cons @ A @ X @ ( nil @ A ) ) ) ).
% insert_Nil
thf(fact_5904_not__in__set__insert,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( insert @ A @ X @ Xs )
= ( cons @ A @ X @ Xs ) ) ) ).
% not_in_set_insert
thf(fact_5905_nths__singleton,axiom,
! [A: $tType,A4: set @ nat,X: A] :
( ( ( member2 @ nat @ ( zero_zero @ nat ) @ A4 )
=> ( ( nths @ A @ ( cons @ A @ X @ ( nil @ A ) ) @ A4 )
= ( cons @ A @ X @ ( nil @ A ) ) ) )
& ( ~ ( member2 @ nat @ ( zero_zero @ nat ) @ A4 )
=> ( ( nths @ A @ ( cons @ A @ X @ ( nil @ A ) ) @ A4 )
= ( nil @ A ) ) ) ) ).
% nths_singleton
thf(fact_5906_Cons__listrel1__Cons,axiom,
! [A: $tType,X: A,Xs: list @ A,Y: A,Ys: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) ) @ ( listrel1 @ A @ R2 ) )
= ( ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
& ( Xs = Ys ) )
| ( ( X = Y )
& ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel1 @ A @ R2 ) ) ) ) ) ).
% Cons_listrel1_Cons
thf(fact_5907_horner__sum__simps_I2_J,axiom,
! [A: $tType,B: $tType] :
( ( comm_semiring_0 @ A )
=> ! [F2: B > A,A3: A,X: B,Xs: list @ B] :
( ( groups4207007520872428315er_sum @ B @ A @ F2 @ A3 @ ( cons @ B @ X @ Xs ) )
= ( plus_plus @ A @ ( F2 @ X ) @ ( times_times @ A @ A3 @ ( groups4207007520872428315er_sum @ B @ A @ F2 @ A3 @ Xs ) ) ) ) ) ).
% horner_sum_simps(2)
thf(fact_5908_lexord__cons__cons,axiom,
! [A: $tType,A3: A,X: list @ A,B2: A,Y: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ A3 @ X ) @ ( cons @ A @ B2 @ Y ) ) @ ( lexord @ A @ R2 ) )
= ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
| ( ( A3 = B2 )
& ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Y ) @ ( lexord @ A @ R2 ) ) ) ) ) ).
% lexord_cons_cons
thf(fact_5909_lexord__Nil__left,axiom,
! [A: $tType,Y: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Y ) @ ( lexord @ A @ R2 ) )
= ( ? [A5: A,X2: list @ A] :
( Y
= ( cons @ A @ A5 @ X2 ) ) ) ) ).
% lexord_Nil_left
thf(fact_5910_enumerate__simps_I2_J,axiom,
! [B: $tType,N2: nat,X: B,Xs: list @ B] :
( ( enumerate @ B @ N2 @ ( cons @ B @ X @ Xs ) )
= ( cons @ ( product_prod @ nat @ B ) @ ( product_Pair @ nat @ B @ N2 @ X ) @ ( enumerate @ B @ ( suc @ N2 ) @ Xs ) ) ) ).
% enumerate_simps(2)
thf(fact_5911_map__upds__Cons,axiom,
! [A: $tType,B: $tType,M: A > ( option @ B ),A3: A,As: list @ A,B2: B,Bs: list @ B] :
( ( map_upds @ A @ B @ M @ ( cons @ A @ A3 @ As ) @ ( cons @ B @ B2 @ Bs ) )
= ( map_upds @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ M @ A3 @ ( some @ B @ B2 ) ) @ As @ Bs ) ) ).
% map_upds_Cons
thf(fact_5912_zip__Cons__Cons,axiom,
! [A: $tType,B: $tType,X: A,Xs: list @ A,Y: B,Ys: list @ B] :
( ( zip @ A @ B @ ( cons @ A @ X @ Xs ) @ ( cons @ B @ Y @ Ys ) )
= ( cons @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y ) @ ( zip @ A @ B @ Xs @ Ys ) ) ) ).
% zip_Cons_Cons
thf(fact_5913_nth__Cons__numeral,axiom,
! [A: $tType,X: A,Xs: list @ A,V2: num] :
( ( nth @ A @ ( cons @ A @ X @ Xs ) @ ( numeral_numeral @ nat @ V2 ) )
= ( nth @ A @ Xs @ ( minus_minus @ nat @ ( numeral_numeral @ nat @ V2 ) @ ( one_one @ nat ) ) ) ) ).
% nth_Cons_numeral
thf(fact_5914_take__Cons__numeral,axiom,
! [A: $tType,V2: num,X: A,Xs: list @ A] :
( ( take @ A @ ( numeral_numeral @ nat @ V2 ) @ ( cons @ A @ X @ Xs ) )
= ( cons @ A @ X @ ( take @ A @ ( minus_minus @ nat @ ( numeral_numeral @ nat @ V2 ) @ ( one_one @ nat ) ) @ Xs ) ) ) ).
% take_Cons_numeral
thf(fact_5915_Cons__in__lex,axiom,
! [A: $tType,X: A,Xs: list @ A,Y: A,Ys: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) ) @ ( lex @ A @ R2 ) )
= ( ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
& ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ A ) @ Ys ) ) )
| ( ( X = Y )
& ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( lex @ A @ R2 ) ) ) ) ) ).
% Cons_in_lex
thf(fact_5916_concat__map__singleton,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( concat @ A
@ ( map @ B @ ( list @ A )
@ ^ [X2: B] : ( cons @ A @ ( F2 @ X2 ) @ ( nil @ A ) )
@ Xs ) )
= ( map @ B @ A @ F2 @ Xs ) ) ).
% concat_map_singleton
thf(fact_5917_nth__Cons__pos,axiom,
! [A: $tType,N2: nat,X: A,Xs: list @ A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( nth @ A @ ( cons @ A @ X @ Xs ) @ N2 )
= ( nth @ A @ Xs @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) ) ) ) ).
% nth_Cons_pos
thf(fact_5918_product__lists_Osimps_I2_J,axiom,
! [A: $tType,Xs: list @ A,Xss: list @ ( list @ A )] :
( ( product_lists @ A @ ( cons @ ( list @ A ) @ Xs @ Xss ) )
= ( concat @ ( list @ A )
@ ( map @ A @ ( list @ ( list @ A ) )
@ ^ [X2: A] : ( map @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X2 ) @ ( product_lists @ A @ Xss ) )
@ Xs ) ) ) ).
% product_lists.simps(2)
thf(fact_5919_n__lists_Osimps_I2_J,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( n_lists @ A @ ( suc @ N2 ) @ Xs )
= ( concat @ ( list @ A )
@ ( map @ ( list @ A ) @ ( list @ ( list @ A ) )
@ ^ [Ys3: list @ A] :
( map @ A @ ( list @ A )
@ ^ [Y2: A] : ( cons @ A @ Y2 @ Ys3 )
@ Xs )
@ ( n_lists @ A @ N2 @ Xs ) ) ) ) ).
% n_lists.simps(2)
thf(fact_5920_list_Osimps_I9_J,axiom,
! [B: $tType,A: $tType,F2: A > B,X21: A,X222: list @ A] :
( ( map @ A @ B @ F2 @ ( cons @ A @ X21 @ X222 ) )
= ( cons @ B @ ( F2 @ X21 ) @ ( map @ A @ B @ F2 @ X222 ) ) ) ).
% list.simps(9)
thf(fact_5921_Cons__eq__map__D,axiom,
! [A: $tType,B: $tType,X: A,Xs: list @ A,F2: B > A,Ys: list @ B] :
( ( ( cons @ A @ X @ Xs )
= ( map @ B @ A @ F2 @ Ys ) )
=> ? [Z2: B,Zs2: list @ B] :
( ( Ys
= ( cons @ B @ Z2 @ Zs2 ) )
& ( X
= ( F2 @ Z2 ) )
& ( Xs
= ( map @ B @ A @ F2 @ Zs2 ) ) ) ) ).
% Cons_eq_map_D
thf(fact_5922_map__eq__Cons__D,axiom,
! [B: $tType,A: $tType,F2: B > A,Xs: list @ B,Y: A,Ys: list @ A] :
( ( ( map @ B @ A @ F2 @ Xs )
= ( cons @ A @ Y @ Ys ) )
=> ? [Z2: B,Zs2: list @ B] :
( ( Xs
= ( cons @ B @ Z2 @ Zs2 ) )
& ( ( F2 @ Z2 )
= Y )
& ( ( map @ B @ A @ F2 @ Zs2 )
= Ys ) ) ) ).
% map_eq_Cons_D
thf(fact_5923_Cons__eq__map__conv,axiom,
! [A: $tType,B: $tType,X: A,Xs: list @ A,F2: B > A,Ys: list @ B] :
( ( ( cons @ A @ X @ Xs )
= ( map @ B @ A @ F2 @ Ys ) )
= ( ? [Z6: B,Zs3: list @ B] :
( ( Ys
= ( cons @ B @ Z6 @ Zs3 ) )
& ( X
= ( F2 @ Z6 ) )
& ( Xs
= ( map @ B @ A @ F2 @ Zs3 ) ) ) ) ) ).
% Cons_eq_map_conv
thf(fact_5924_map__eq__Cons__conv,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B,Y: A,Ys: list @ A] :
( ( ( map @ B @ A @ F2 @ Xs )
= ( cons @ A @ Y @ Ys ) )
= ( ? [Z6: B,Zs3: list @ B] :
( ( Xs
= ( cons @ B @ Z6 @ Zs3 ) )
& ( ( F2 @ Z6 )
= Y )
& ( ( map @ B @ A @ F2 @ Zs3 )
= Ys ) ) ) ) ).
% map_eq_Cons_conv
thf(fact_5925_product__concat__map,axiom,
! [B: $tType,A: $tType] :
( ( product @ A @ B )
= ( ^ [Xs2: list @ A,Ys3: list @ B] :
( concat @ ( product_prod @ A @ B )
@ ( map @ A @ ( list @ ( product_prod @ A @ B ) )
@ ^ [X2: A] : ( map @ B @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 ) @ Ys3 )
@ Xs2 ) ) ) ) ).
% product_concat_map
thf(fact_5926_listrelp_OCons,axiom,
! [A: $tType,B: $tType,R2: A > B > $o,X: A,Y: B,Xs: list @ A,Ys: list @ B] :
( ( R2 @ X @ Y )
=> ( ( listrelp @ A @ B @ R2 @ Xs @ Ys )
=> ( listrelp @ A @ B @ R2 @ ( cons @ A @ X @ Xs ) @ ( cons @ B @ Y @ Ys ) ) ) ) ).
% listrelp.Cons
thf(fact_5927_successively_Ocases,axiom,
! [A: $tType,X: product_prod @ ( A > A > $o ) @ ( list @ A )] :
( ! [P8: A > A > $o] :
( X
!= ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ P8 @ ( nil @ A ) ) )
=> ( ! [P8: A > A > $o,X5: A] :
( X
!= ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ P8 @ ( cons @ A @ X5 @ ( nil @ A ) ) ) )
=> ~ ! [P8: A > A > $o,X5: A,Y4: A,Xs3: list @ A] :
( X
!= ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ P8 @ ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) ) ) ) ) ).
% successively.cases
thf(fact_5928_arg__min__list_Ocases,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ! [X: product_prod @ ( A > B ) @ ( list @ A )] :
( ! [F4: A > B,X5: A] :
( X
!= ( product_Pair @ ( A > B ) @ ( list @ A ) @ F4 @ ( cons @ A @ X5 @ ( nil @ A ) ) ) )
=> ( ! [F4: A > B,X5: A,Y4: A,Zs2: list @ A] :
( X
!= ( product_Pair @ ( A > B ) @ ( list @ A ) @ F4 @ ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Zs2 ) ) ) )
=> ~ ! [A7: A > B] :
( X
!= ( product_Pair @ ( A > B ) @ ( list @ A ) @ A7 @ ( nil @ A ) ) ) ) ) ) ).
% arg_min_list.cases
thf(fact_5929_sorted__wrt_Ocases,axiom,
! [A: $tType,X: product_prod @ ( A > A > $o ) @ ( list @ A )] :
( ! [P8: A > A > $o] :
( X
!= ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ P8 @ ( nil @ A ) ) )
=> ~ ! [P8: A > A > $o,X5: A,Ys4: list @ A] :
( X
!= ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ P8 @ ( cons @ A @ X5 @ Ys4 ) ) ) ) ).
% sorted_wrt.cases
thf(fact_5930_refl__onD2,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X: A,Y: A] :
( ( refl_on @ A @ A4 @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
=> ( member2 @ A @ Y @ A4 ) ) ) ).
% refl_onD2
thf(fact_5931_refl__onD1,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X: A,Y: A] :
( ( refl_on @ A @ A4 @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
=> ( member2 @ A @ X @ A4 ) ) ) ).
% refl_onD1
thf(fact_5932_refl__onD,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),A3: A] :
( ( refl_on @ A @ A4 @ R2 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ A3 ) @ R2 ) ) ) ).
% refl_onD
thf(fact_5933_zip__eq__ConsE,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,Xy: product_prod @ A @ B,Xys: list @ ( product_prod @ A @ B )] :
( ( ( zip @ A @ B @ Xs @ Ys )
= ( cons @ ( product_prod @ A @ B ) @ Xy @ Xys ) )
=> ~ ! [X5: A,Xs4: list @ A] :
( ( Xs
= ( cons @ A @ X5 @ Xs4 ) )
=> ! [Y4: B,Ys5: list @ B] :
( ( Ys
= ( cons @ B @ Y4 @ Ys5 ) )
=> ( ( Xy
= ( product_Pair @ A @ B @ X5 @ Y4 ) )
=> ( Xys
!= ( zip @ A @ B @ Xs4 @ Ys5 ) ) ) ) ) ) ).
% zip_eq_ConsE
thf(fact_5934_list_Oset__intros_I2_J,axiom,
! [A: $tType,Y: A,X222: list @ A,X21: A] :
( ( member2 @ A @ Y @ ( set2 @ A @ X222 ) )
=> ( member2 @ A @ Y @ ( set2 @ A @ ( cons @ A @ X21 @ X222 ) ) ) ) ).
% list.set_intros(2)
thf(fact_5935_list_Oset__intros_I1_J,axiom,
! [A: $tType,X21: A,X222: list @ A] : ( member2 @ A @ X21 @ ( set2 @ A @ ( cons @ A @ X21 @ X222 ) ) ) ).
% list.set_intros(1)
thf(fact_5936_list_Oset__cases,axiom,
! [A: $tType,E3: A,A3: list @ A] :
( ( member2 @ A @ E3 @ ( set2 @ A @ A3 ) )
=> ( ! [Z23: list @ A] :
( A3
!= ( cons @ A @ E3 @ Z23 ) )
=> ~ ! [Z12: A,Z23: list @ A] :
( ( A3
= ( cons @ A @ Z12 @ Z23 ) )
=> ~ ( member2 @ A @ E3 @ ( set2 @ A @ Z23 ) ) ) ) ) ).
% list.set_cases
thf(fact_5937_set__ConsD,axiom,
! [A: $tType,Y: A,X: A,Xs: list @ A] :
( ( member2 @ A @ Y @ ( set2 @ A @ ( cons @ A @ X @ Xs ) ) )
=> ( ( Y = X )
| ( member2 @ A @ Y @ ( set2 @ A @ Xs ) ) ) ) ).
% set_ConsD
thf(fact_5938_member__rec_I1_J,axiom,
! [A: $tType,X: A,Xs: list @ A,Y: A] :
( ( member @ A @ ( cons @ A @ X @ Xs ) @ Y )
= ( ( X = Y )
| ( member @ A @ Xs @ Y ) ) ) ).
% member_rec(1)
thf(fact_5939_inj__on__Cons1,axiom,
! [A: $tType,X: A,A4: set @ ( list @ A )] : ( inj_on @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X ) @ A4 ) ).
% inj_on_Cons1
thf(fact_5940_remdups__adj_Osimps_I3_J,axiom,
! [A: $tType,X: A,Y: A,Xs: list @ A] :
( ( ( X = Y )
=> ( ( remdups_adj @ A @ ( cons @ A @ X @ ( cons @ A @ Y @ Xs ) ) )
= ( remdups_adj @ A @ ( cons @ A @ X @ Xs ) ) ) )
& ( ( X != Y )
=> ( ( remdups_adj @ A @ ( cons @ A @ X @ ( cons @ A @ Y @ Xs ) ) )
= ( cons @ A @ X @ ( remdups_adj @ A @ ( cons @ A @ Y @ Xs ) ) ) ) ) ) ).
% remdups_adj.simps(3)
thf(fact_5941_list_Odistinct_I1_J,axiom,
! [A: $tType,X21: A,X222: list @ A] :
( ( nil @ A )
!= ( cons @ A @ X21 @ X222 ) ) ).
% list.distinct(1)
thf(fact_5942_list_OdiscI,axiom,
! [A: $tType,List: list @ A,X21: A,X222: list @ A] :
( ( List
= ( cons @ A @ X21 @ X222 ) )
=> ( List
!= ( nil @ A ) ) ) ).
% list.discI
thf(fact_5943_list_Oexhaust,axiom,
! [A: $tType,Y: list @ A] :
( ( Y
!= ( nil @ A ) )
=> ~ ! [X212: A,X223: list @ A] :
( Y
!= ( cons @ A @ X212 @ X223 ) ) ) ).
% list.exhaust
thf(fact_5944_min__list_Ocases,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [X: list @ A] :
( ! [X5: A,Xs3: list @ A] :
( X
!= ( cons @ A @ X5 @ Xs3 ) )
=> ( X
= ( nil @ A ) ) ) ) ).
% min_list.cases
thf(fact_5945_transpose_Ocases,axiom,
! [A: $tType,X: list @ ( list @ A )] :
( ( X
!= ( nil @ ( list @ A ) ) )
=> ( ! [Xss2: list @ ( list @ A )] :
( X
!= ( cons @ ( list @ A ) @ ( nil @ A ) @ Xss2 ) )
=> ~ ! [X5: A,Xs3: list @ A,Xss2: list @ ( list @ A )] :
( X
!= ( cons @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ Xss2 ) ) ) ) ).
% transpose.cases
thf(fact_5946_remdups__adj_Ocases,axiom,
! [A: $tType,X: list @ A] :
( ( X
!= ( nil @ A ) )
=> ( ! [X5: A] :
( X
!= ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ~ ! [X5: A,Y4: A,Xs3: list @ A] :
( X
!= ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) ) ) ) ).
% remdups_adj.cases
thf(fact_5947_neq__Nil__conv,axiom,
! [A: $tType,Xs: list @ A] :
( ( Xs
!= ( nil @ A ) )
= ( ? [Y2: A,Ys3: list @ A] :
( Xs
= ( cons @ A @ Y2 @ Ys3 ) ) ) ) ).
% neq_Nil_conv
thf(fact_5948_list__induct2_H,axiom,
! [A: $tType,B: $tType,P2: ( list @ A ) > ( list @ B ) > $o,Xs: list @ A,Ys: list @ B] :
( ( P2 @ ( nil @ A ) @ ( nil @ B ) )
=> ( ! [X5: A,Xs3: list @ A] : ( P2 @ ( cons @ A @ X5 @ Xs3 ) @ ( nil @ B ) )
=> ( ! [Y4: B,Ys4: list @ B] : ( P2 @ ( nil @ A ) @ ( cons @ B @ Y4 @ Ys4 ) )
=> ( ! [X5: A,Xs3: list @ A,Y4: B,Ys4: list @ B] :
( ( P2 @ Xs3 @ Ys4 )
=> ( P2 @ ( cons @ A @ X5 @ Xs3 ) @ ( cons @ B @ Y4 @ Ys4 ) ) )
=> ( P2 @ Xs @ Ys ) ) ) ) ) ).
% list_induct2'
thf(fact_5949_list__nonempty__induct,axiom,
! [A: $tType,Xs: list @ A,P2: ( list @ A ) > $o] :
( ( Xs
!= ( nil @ A ) )
=> ( ! [X5: A] : ( P2 @ ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ( ! [X5: A,Xs3: list @ A] :
( ( Xs3
!= ( nil @ A ) )
=> ( ( P2 @ Xs3 )
=> ( P2 @ ( cons @ A @ X5 @ Xs3 ) ) ) )
=> ( P2 @ Xs ) ) ) ) ).
% list_nonempty_induct
thf(fact_5950_not__Cons__self2,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( cons @ A @ X @ Xs )
!= Xs ) ).
% not_Cons_self2
thf(fact_5951_remove1_Osimps_I2_J,axiom,
! [A: $tType,X: A,Y: A,Xs: list @ A] :
( ( ( X = Y )
=> ( ( remove1 @ A @ X @ ( cons @ A @ Y @ Xs ) )
= Xs ) )
& ( ( X != Y )
=> ( ( remove1 @ A @ X @ ( cons @ A @ Y @ Xs ) )
= ( cons @ A @ Y @ ( remove1 @ A @ X @ Xs ) ) ) ) ) ).
% remove1.simps(2)
thf(fact_5952_distinct__length__2__or__more,axiom,
! [A: $tType,A3: A,B2: A,Xs: list @ A] :
( ( distinct @ A @ ( cons @ A @ A3 @ ( cons @ A @ B2 @ Xs ) ) )
= ( ( A3 != B2 )
& ( distinct @ A @ ( cons @ A @ A3 @ Xs ) )
& ( distinct @ A @ ( cons @ A @ B2 @ Xs ) ) ) ) ).
% distinct_length_2_or_more
thf(fact_5953_removeAll_Osimps_I2_J,axiom,
! [A: $tType,X: A,Y: A,Xs: list @ A] :
( ( ( X = Y )
=> ( ( removeAll @ A @ X @ ( cons @ A @ Y @ Xs ) )
= ( removeAll @ A @ X @ Xs ) ) )
& ( ( X != Y )
=> ( ( removeAll @ A @ X @ ( cons @ A @ Y @ Xs ) )
= ( cons @ A @ Y @ ( removeAll @ A @ X @ Xs ) ) ) ) ) ).
% removeAll.simps(2)
thf(fact_5954_Cons__in__shuffles__leftI,axiom,
! [A: $tType,Zs: list @ A,Xs: list @ A,Ys: list @ A,Z: A] :
( ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ Xs @ Ys ) )
=> ( member2 @ ( list @ A ) @ ( cons @ A @ Z @ Zs ) @ ( shuffles @ A @ ( cons @ A @ Z @ Xs ) @ Ys ) ) ) ).
% Cons_in_shuffles_leftI
thf(fact_5955_Cons__in__shuffles__rightI,axiom,
! [A: $tType,Zs: list @ A,Xs: list @ A,Ys: list @ A,Z: A] :
( ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ Xs @ Ys ) )
=> ( member2 @ ( list @ A ) @ ( cons @ A @ Z @ Zs ) @ ( shuffles @ A @ Xs @ ( cons @ A @ Z @ Ys ) ) ) ) ).
% Cons_in_shuffles_rightI
thf(fact_5956_list__update_Osimps_I2_J,axiom,
! [A: $tType,X: A,Xs: list @ A,I: nat,V2: A] :
( ( list_update @ A @ ( cons @ A @ X @ Xs ) @ I @ V2 )
= ( case_nat @ ( list @ A ) @ ( cons @ A @ V2 @ Xs )
@ ^ [J3: nat] : ( cons @ A @ X @ ( list_update @ A @ Xs @ J3 @ V2 ) )
@ I ) ) ).
% list_update.simps(2)
thf(fact_5957_foldl__Cons,axiom,
! [B: $tType,A: $tType,F2: B > A > B,A3: B,X: A,Xs: list @ A] :
( ( foldl @ B @ A @ F2 @ A3 @ ( cons @ A @ X @ Xs ) )
= ( foldl @ B @ A @ F2 @ ( F2 @ A3 @ X ) @ Xs ) ) ).
% foldl_Cons
thf(fact_5958_impossible__Cons,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,X: A] :
( ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ A ) @ Ys ) )
=> ( Xs
!= ( cons @ A @ X @ Ys ) ) ) ).
% impossible_Cons
thf(fact_5959_list__induct2,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,P2: ( list @ A ) > ( list @ B ) > $o] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( P2 @ ( nil @ A ) @ ( nil @ B ) )
=> ( ! [X5: A,Xs3: list @ A,Y4: B,Ys4: list @ B] :
( ( ( size_size @ ( list @ A ) @ Xs3 )
= ( size_size @ ( list @ B ) @ Ys4 ) )
=> ( ( P2 @ Xs3 @ Ys4 )
=> ( P2 @ ( cons @ A @ X5 @ Xs3 ) @ ( cons @ B @ Y4 @ Ys4 ) ) ) )
=> ( P2 @ Xs @ Ys ) ) ) ) ).
% list_induct2
thf(fact_5960_list__induct3,axiom,
! [B: $tType,A: $tType,C: $tType,Xs: list @ A,Ys: list @ B,Zs: list @ C,P2: ( list @ A ) > ( list @ B ) > ( list @ C ) > $o] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( ( size_size @ ( list @ B ) @ Ys )
= ( size_size @ ( list @ C ) @ Zs ) )
=> ( ( P2 @ ( nil @ A ) @ ( nil @ B ) @ ( nil @ C ) )
=> ( ! [X5: A,Xs3: list @ A,Y4: B,Ys4: list @ B,Z2: C,Zs2: list @ C] :
( ( ( size_size @ ( list @ A ) @ Xs3 )
= ( size_size @ ( list @ B ) @ Ys4 ) )
=> ( ( ( size_size @ ( list @ B ) @ Ys4 )
= ( size_size @ ( list @ C ) @ Zs2 ) )
=> ( ( P2 @ Xs3 @ Ys4 @ Zs2 )
=> ( P2 @ ( cons @ A @ X5 @ Xs3 ) @ ( cons @ B @ Y4 @ Ys4 ) @ ( cons @ C @ Z2 @ Zs2 ) ) ) ) )
=> ( P2 @ Xs @ Ys @ Zs ) ) ) ) ) ).
% list_induct3
thf(fact_5961_list__induct4,axiom,
! [C: $tType,A: $tType,B: $tType,D: $tType,Xs: list @ A,Ys: list @ B,Zs: list @ C,Ws2: list @ D,P2: ( list @ A ) > ( list @ B ) > ( list @ C ) > ( list @ D ) > $o] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( ( size_size @ ( list @ B ) @ Ys )
= ( size_size @ ( list @ C ) @ Zs ) )
=> ( ( ( size_size @ ( list @ C ) @ Zs )
= ( size_size @ ( list @ D ) @ Ws2 ) )
=> ( ( P2 @ ( nil @ A ) @ ( nil @ B ) @ ( nil @ C ) @ ( nil @ D ) )
=> ( ! [X5: A,Xs3: list @ A,Y4: B,Ys4: list @ B,Z2: C,Zs2: list @ C,W: D,Ws: list @ D] :
( ( ( size_size @ ( list @ A ) @ Xs3 )
= ( size_size @ ( list @ B ) @ Ys4 ) )
=> ( ( ( size_size @ ( list @ B ) @ Ys4 )
= ( size_size @ ( list @ C ) @ Zs2 ) )
=> ( ( ( size_size @ ( list @ C ) @ Zs2 )
= ( size_size @ ( list @ D ) @ Ws ) )
=> ( ( P2 @ Xs3 @ Ys4 @ Zs2 @ Ws )
=> ( P2 @ ( cons @ A @ X5 @ Xs3 ) @ ( cons @ B @ Y4 @ Ys4 ) @ ( cons @ C @ Z2 @ Zs2 ) @ ( cons @ D @ W @ Ws ) ) ) ) ) )
=> ( P2 @ Xs @ Ys @ Zs @ Ws2 ) ) ) ) ) ) ).
% list_induct4
thf(fact_5962_set__subset__Cons,axiom,
! [A: $tType,Xs: list @ A,X: A] : ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ ( cons @ A @ X @ Xs ) ) ) ).
% set_subset_Cons
thf(fact_5963_length__Cons,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( size_size @ ( list @ A ) @ ( cons @ A @ X @ Xs ) )
= ( suc @ ( size_size @ ( list @ A ) @ Xs ) ) ) ).
% length_Cons
thf(fact_5964_Suc__length__conv,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ( suc @ N2 )
= ( size_size @ ( list @ A ) @ Xs ) )
= ( ? [Y2: A,Ys3: list @ A] :
( ( Xs
= ( cons @ A @ Y2 @ Ys3 ) )
& ( ( size_size @ ( list @ A ) @ Ys3 )
= N2 ) ) ) ) ).
% Suc_length_conv
thf(fact_5965_length__Suc__conv,axiom,
! [A: $tType,Xs: list @ A,N2: nat] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( suc @ N2 ) )
= ( ? [Y2: A,Ys3: list @ A] :
( ( Xs
= ( cons @ A @ Y2 @ Ys3 ) )
& ( ( size_size @ ( list @ A ) @ Ys3 )
= N2 ) ) ) ) ).
% length_Suc_conv
thf(fact_5966_inj__split__Cons,axiom,
! [A: $tType,X7: set @ ( product_prod @ ( list @ A ) @ A )] :
( inj_on @ ( product_prod @ ( list @ A ) @ A ) @ ( list @ A )
@ ( product_case_prod @ ( list @ A ) @ A @ ( list @ A )
@ ^ [Xs2: list @ A,N: A] : ( cons @ A @ N @ Xs2 ) )
@ X7 ) ).
% inj_split_Cons
thf(fact_5967_shuffles_Osimps_I3_J,axiom,
! [A: $tType,X: A,Xs: list @ A,Y: A,Ys: list @ A] :
( ( shuffles @ A @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) )
= ( sup_sup @ ( set @ ( list @ A ) ) @ ( image2 @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X ) @ ( shuffles @ A @ Xs @ ( cons @ A @ Y @ Ys ) ) ) @ ( image2 @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ Y ) @ ( shuffles @ A @ ( cons @ A @ X @ Xs ) @ Ys ) ) ) ) ).
% shuffles.simps(3)
thf(fact_5968_Cons__shuffles__subset2,axiom,
! [A: $tType,Y: A,Xs: list @ A,Ys: list @ A] : ( ord_less_eq @ ( set @ ( list @ A ) ) @ ( image2 @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ Y ) @ ( shuffles @ A @ Xs @ Ys ) ) @ ( shuffles @ A @ Xs @ ( cons @ A @ Y @ Ys ) ) ) ).
% Cons_shuffles_subset2
thf(fact_5969_Cons__shuffles__subset1,axiom,
! [A: $tType,X: A,Xs: list @ A,Ys: list @ A] : ( ord_less_eq @ ( set @ ( list @ A ) ) @ ( image2 @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X ) @ ( shuffles @ A @ Xs @ Ys ) ) @ ( shuffles @ A @ ( cons @ A @ X @ Xs ) @ Ys ) ) ).
% Cons_shuffles_subset1
thf(fact_5970_splice_Ocases,axiom,
! [A: $tType,X: product_prod @ ( list @ A ) @ ( list @ A )] :
( ! [Ys4: list @ A] :
( X
!= ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Ys4 ) )
=> ~ ! [X5: A,Xs3: list @ A,Ys4: list @ A] :
( X
!= ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ Ys4 ) ) ) ).
% splice.cases
thf(fact_5971_shuffles_Ocases,axiom,
! [A: $tType,X: product_prod @ ( list @ A ) @ ( list @ A )] :
( ! [Ys4: list @ A] :
( X
!= ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Ys4 ) )
=> ( ! [Xs3: list @ A] :
( X
!= ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs3 @ ( nil @ A ) ) )
=> ~ ! [X5: A,Xs3: list @ A,Y4: A,Ys4: list @ A] :
( X
!= ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ ( cons @ A @ Y4 @ Ys4 ) ) ) ) ) ).
% shuffles.cases
thf(fact_5972_map__tailrec__rev_Ocases,axiom,
! [A: $tType,B: $tType,X: product_prod @ ( A > B ) @ ( product_prod @ ( list @ A ) @ ( list @ B ) )] :
( ! [F4: A > B,Bs2: list @ B] :
( X
!= ( product_Pair @ ( A > B ) @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ F4 @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ ( nil @ A ) @ Bs2 ) ) )
=> ~ ! [F4: A > B,A7: A,As2: list @ A,Bs2: list @ B] :
( X
!= ( product_Pair @ ( A > B ) @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ F4 @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ ( cons @ A @ A7 @ As2 ) @ Bs2 ) ) ) ) ).
% map_tailrec_rev.cases
thf(fact_5973_distinct__singleton,axiom,
! [A: $tType,X: A] : ( distinct @ A @ ( cons @ A @ X @ ( nil @ A ) ) ) ).
% distinct_singleton
thf(fact_5974_distinct_Osimps_I2_J,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( distinct @ A @ ( cons @ A @ X @ Xs ) )
= ( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
& ( distinct @ A @ Xs ) ) ) ).
% distinct.simps(2)
thf(fact_5975_replicate__Suc,axiom,
! [A: $tType,N2: nat,X: A] :
( ( replicate @ A @ ( suc @ N2 ) @ X )
= ( cons @ A @ X @ ( replicate @ A @ N2 @ X ) ) ) ).
% replicate_Suc
thf(fact_5976_list__update__code_I3_J,axiom,
! [A: $tType,X: A,Xs: list @ A,I: nat,Y: A] :
( ( list_update @ A @ ( cons @ A @ X @ Xs ) @ ( suc @ I ) @ Y )
= ( cons @ A @ X @ ( list_update @ A @ Xs @ I @ Y ) ) ) ).
% list_update_code(3)
thf(fact_5977_list__update__code_I2_J,axiom,
! [A: $tType,X: A,Xs: list @ A,Y: A] :
( ( list_update @ A @ ( cons @ A @ X @ Xs ) @ ( zero_zero @ nat ) @ Y )
= ( cons @ A @ Y @ Xs ) ) ).
% list_update_code(2)
thf(fact_5978_insort__key_Osimps_I2_J,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,X: B,Y: B,Ys: list @ B] :
( ( ( ord_less_eq @ A @ ( F2 @ X ) @ ( F2 @ Y ) )
=> ( ( linorder_insort_key @ B @ A @ F2 @ X @ ( cons @ B @ Y @ Ys ) )
= ( cons @ B @ X @ ( cons @ B @ Y @ Ys ) ) ) )
& ( ~ ( ord_less_eq @ A @ ( F2 @ X ) @ ( F2 @ Y ) )
=> ( ( linorder_insort_key @ B @ A @ F2 @ X @ ( cons @ B @ Y @ Ys ) )
= ( cons @ B @ Y @ ( linorder_insort_key @ B @ A @ F2 @ X @ Ys ) ) ) ) ) ) ).
% insort_key.simps(2)
thf(fact_5979_remdups__adj_Osimps_I2_J,axiom,
! [A: $tType,X: A] :
( ( remdups_adj @ A @ ( cons @ A @ X @ ( nil @ A ) ) )
= ( cons @ A @ X @ ( nil @ A ) ) ) ).
% remdups_adj.simps(2)
thf(fact_5980_remdups__adj_Oelims,axiom,
! [A: $tType,X: list @ A,Y: list @ A] :
( ( ( remdups_adj @ A @ X )
= Y )
=> ( ( ( X
= ( nil @ A ) )
=> ( Y
!= ( nil @ A ) ) )
=> ( ! [X5: A] :
( ( X
= ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ( Y
!= ( cons @ A @ X5 @ ( nil @ A ) ) ) )
=> ~ ! [X5: A,Y4: A,Xs3: list @ A] :
( ( X
= ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) )
=> ~ ( ( ( X5 = Y4 )
=> ( Y
= ( remdups_adj @ A @ ( cons @ A @ X5 @ Xs3 ) ) ) )
& ( ( X5 != Y4 )
=> ( Y
= ( cons @ A @ X5 @ ( remdups_adj @ A @ ( cons @ A @ Y4 @ Xs3 ) ) ) ) ) ) ) ) ) ) ).
% remdups_adj.elims
thf(fact_5981_shufflesE,axiom,
! [A: $tType,Zs: list @ A,Xs: list @ A,Ys: list @ A] :
( ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ Xs @ Ys ) )
=> ( ( ( Zs = Xs )
=> ( Ys
!= ( nil @ A ) ) )
=> ( ( ( Zs = Ys )
=> ( Xs
!= ( nil @ A ) ) )
=> ( ! [X5: A,Xs4: list @ A] :
( ( Xs
= ( cons @ A @ X5 @ Xs4 ) )
=> ! [Z2: A,Zs4: list @ A] :
( ( Zs
= ( cons @ A @ Z2 @ Zs4 ) )
=> ( ( X5 = Z2 )
=> ~ ( member2 @ ( list @ A ) @ Zs4 @ ( shuffles @ A @ Xs4 @ Ys ) ) ) ) )
=> ~ ! [Y4: A,Ys5: list @ A] :
( ( Ys
= ( cons @ A @ Y4 @ Ys5 ) )
=> ! [Z2: A,Zs4: list @ A] :
( ( Zs
= ( cons @ A @ Z2 @ Zs4 ) )
=> ( ( Y4 = Z2 )
=> ~ ( member2 @ ( list @ A ) @ Zs4 @ ( shuffles @ A @ Xs @ Ys5 ) ) ) ) ) ) ) ) ) ).
% shufflesE
thf(fact_5982_insort__key_Osimps_I1_J,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,X: B] :
( ( linorder_insort_key @ B @ A @ F2 @ X @ ( nil @ B ) )
= ( cons @ B @ X @ ( nil @ B ) ) ) ) ).
% insort_key.simps(1)
thf(fact_5983_zip__same__conv__map,axiom,
! [A: $tType,Xs: list @ A] :
( ( zip @ A @ A @ Xs @ Xs )
= ( map @ A @ ( product_prod @ A @ A )
@ ^ [X2: A] : ( product_Pair @ A @ A @ X2 @ X2 )
@ Xs ) ) ).
% zip_same_conv_map
thf(fact_5984_remdups_Osimps_I2_J,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( remdups @ A @ ( cons @ A @ X @ Xs ) )
= ( remdups @ A @ Xs ) ) )
& ( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( remdups @ A @ ( cons @ A @ X @ Xs ) )
= ( cons @ A @ X @ ( remdups @ A @ Xs ) ) ) ) ) ).
% remdups.simps(2)
thf(fact_5985_listrel1I2,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A ),X: A] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel1 @ A @ R2 ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ X @ Ys ) ) @ ( listrel1 @ A @ R2 ) ) ) ).
% listrel1I2
thf(fact_5986_refl__on__empty,axiom,
! [A: $tType] : ( refl_on @ A @ ( bot_bot @ ( set @ A ) ) @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ).
% refl_on_empty
thf(fact_5987_List_Obind__def,axiom,
! [B: $tType,A: $tType] :
( ( bind @ A @ B )
= ( ^ [Xs2: list @ A,F3: A > ( list @ B )] : ( concat @ B @ ( map @ A @ ( list @ B ) @ F3 @ Xs2 ) ) ) ) ).
% List.bind_def
thf(fact_5988_List_Oinsert__def,axiom,
! [A: $tType] :
( ( insert @ A )
= ( ^ [X2: A,Xs2: list @ A] : ( if @ ( list @ A ) @ ( member2 @ A @ X2 @ ( set2 @ A @ Xs2 ) ) @ Xs2 @ ( cons @ A @ X2 @ Xs2 ) ) ) ) ).
% List.insert_def
thf(fact_5989_find_Osimps_I2_J,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A] :
( ( ( P2 @ X )
=> ( ( find @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( some @ A @ X ) ) )
& ( ~ ( P2 @ X )
=> ( ( find @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( find @ A @ P2 @ Xs ) ) ) ) ).
% find.simps(2)
thf(fact_5990_listrelp_Ocases,axiom,
! [A: $tType,B: $tType,R2: A > B > $o,A12: list @ A,A23: list @ B] :
( ( listrelp @ A @ B @ R2 @ A12 @ A23 )
=> ( ( ( A12
= ( nil @ A ) )
=> ( A23
!= ( nil @ B ) ) )
=> ~ ! [X5: A,Y4: B,Xs3: list @ A] :
( ( A12
= ( cons @ A @ X5 @ Xs3 ) )
=> ! [Ys4: list @ B] :
( ( A23
= ( cons @ B @ Y4 @ Ys4 ) )
=> ( ( R2 @ X5 @ Y4 )
=> ~ ( listrelp @ A @ B @ R2 @ Xs3 @ Ys4 ) ) ) ) ) ) ).
% listrelp.cases
thf(fact_5991_listrelp_Osimps,axiom,
! [B: $tType,A: $tType] :
( ( listrelp @ A @ B )
= ( ^ [R4: A > B > $o,A1: list @ A,A22: list @ B] :
( ( ( A1
= ( nil @ A ) )
& ( A22
= ( nil @ B ) ) )
| ? [X2: A,Y2: B,Xs2: list @ A,Ys3: list @ B] :
( ( A1
= ( cons @ A @ X2 @ Xs2 ) )
& ( A22
= ( cons @ B @ Y2 @ Ys3 ) )
& ( R4 @ X2 @ Y2 )
& ( listrelp @ A @ B @ R4 @ Xs2 @ Ys3 ) ) ) ) ) ).
% listrelp.simps
thf(fact_5992_arg__min__list_Osimps_I1_J,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ! [F2: A > B,X: A] :
( ( arg_min_list @ A @ B @ F2 @ ( cons @ A @ X @ ( nil @ A ) ) )
= X ) ) ).
% arg_min_list.simps(1)
thf(fact_5993_take__Cons,axiom,
! [A: $tType,N2: nat,X: A,Xs: list @ A] :
( ( take @ A @ N2 @ ( cons @ A @ X @ Xs ) )
= ( case_nat @ ( list @ A ) @ ( nil @ A )
@ ^ [M2: nat] : ( cons @ A @ X @ ( take @ A @ M2 @ Xs ) )
@ N2 ) ) ).
% take_Cons
thf(fact_5994_Cons__in__subseqsD,axiom,
! [A: $tType,Y: A,Ys: list @ A,Xs: list @ A] :
( ( member2 @ ( list @ A ) @ ( cons @ A @ Y @ Ys ) @ ( set2 @ ( list @ A ) @ ( subseqs @ A @ Xs ) ) )
=> ( member2 @ ( list @ A ) @ Ys @ ( set2 @ ( list @ A ) @ ( subseqs @ A @ Xs ) ) ) ) ).
% Cons_in_subseqsD
thf(fact_5995_nth__Cons,axiom,
! [A: $tType,X: A,Xs: list @ A,N2: nat] :
( ( nth @ A @ ( cons @ A @ X @ Xs ) @ N2 )
= ( case_nat @ A @ X @ ( nth @ A @ Xs ) @ N2 ) ) ).
% nth_Cons
thf(fact_5996_ord_Olexordp_Omono,axiom,
! [A: $tType,Less: A > A > $o] :
( order_mono @ ( ( list @ A ) > ( list @ A ) > $o ) @ ( ( list @ A ) > ( list @ A ) > $o )
@ ^ [P6: ( list @ A ) > ( list @ A ) > $o,X16: list @ A,X24: list @ A] :
( ? [Y2: A,Ys3: list @ A] :
( ( X16
= ( nil @ A ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( X16
= ( cons @ A @ X2 @ Xs2 ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) )
& ( Less @ X2 @ Y2 ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( X16
= ( cons @ A @ X2 @ Xs2 ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) )
& ~ ( Less @ X2 @ Y2 )
& ~ ( Less @ Y2 @ X2 )
& ( P6 @ Xs2 @ Ys3 ) ) ) ) ).
% ord.lexordp.mono
thf(fact_5997_arg__min__list_Osimps_I2_J,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ! [F2: A > B,X: A,Y: A,Zs: list @ A] :
( ( arg_min_list @ A @ B @ F2 @ ( cons @ A @ X @ ( cons @ A @ Y @ Zs ) ) )
= ( if @ A @ ( ord_less_eq @ B @ ( F2 @ X ) @ ( F2 @ ( arg_min_list @ A @ B @ F2 @ ( cons @ A @ Y @ Zs ) ) ) ) @ X @ ( arg_min_list @ A @ B @ F2 @ ( cons @ A @ Y @ Zs ) ) ) ) ) ).
% arg_min_list.simps(2)
thf(fact_5998_Suc__le__length__iff,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ord_less_eq @ nat @ ( suc @ N2 ) @ ( size_size @ ( list @ A ) @ Xs ) )
= ( ? [X2: A,Ys3: list @ A] :
( ( Xs
= ( cons @ A @ X2 @ Ys3 ) )
& ( ord_less_eq @ nat @ N2 @ ( size_size @ ( list @ A ) @ Ys3 ) ) ) ) ) ).
% Suc_le_length_iff
thf(fact_5999_distinct__set__subseqs,axiom,
! [A: $tType,Xs: list @ A] :
( ( distinct @ A @ Xs )
=> ( distinct @ ( set @ A ) @ ( map @ ( list @ A ) @ ( set @ A ) @ ( set2 @ A ) @ ( subseqs @ A @ Xs ) ) ) ) ).
% distinct_set_subseqs
thf(fact_6000_insort__is__Cons,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ B,F2: B > A,A3: B] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ ( set2 @ B @ Xs ) )
=> ( ord_less_eq @ A @ ( F2 @ A3 ) @ ( F2 @ X5 ) ) )
=> ( ( linorder_insort_key @ B @ A @ F2 @ A3 @ Xs )
= ( cons @ B @ A3 @ Xs ) ) ) ) ).
% insort_is_Cons
thf(fact_6001_map__of__Cons__code_I2_J,axiom,
! [C: $tType,B: $tType,L: B,K: B,V2: C,Ps: list @ ( product_prod @ B @ C )] :
( ( ( L = K )
=> ( ( map_of @ B @ C @ ( cons @ ( product_prod @ B @ C ) @ ( product_Pair @ B @ C @ L @ V2 ) @ Ps ) @ K )
= ( some @ C @ V2 ) ) )
& ( ( L != K )
=> ( ( map_of @ B @ C @ ( cons @ ( product_prod @ B @ C ) @ ( product_Pair @ B @ C @ L @ V2 ) @ Ps ) @ K )
= ( map_of @ B @ C @ Ps @ K ) ) ) ) ).
% map_of_Cons_code(2)
thf(fact_6002_Cons__listrel1E2,axiom,
! [A: $tType,Xs: list @ A,Y: A,Ys: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ ( cons @ A @ Y @ Ys ) ) @ ( listrel1 @ A @ R2 ) )
=> ( ! [X5: A] :
( ( Xs
= ( cons @ A @ X5 @ Ys ) )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Y ) @ R2 ) )
=> ~ ! [Zs2: list @ A] :
( ( Xs
= ( cons @ A @ Y @ Zs2 ) )
=> ~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Zs2 @ Ys ) @ ( listrel1 @ A @ R2 ) ) ) ) ) ).
% Cons_listrel1E2
thf(fact_6003_Cons__listrel1E1,axiom,
! [A: $tType,X: A,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ Ys ) @ ( listrel1 @ A @ R2 ) )
=> ( ! [Y4: A] :
( ( Ys
= ( cons @ A @ Y4 @ Xs ) )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y4 ) @ R2 ) )
=> ~ ! [Zs2: list @ A] :
( ( Ys
= ( cons @ A @ X @ Zs2 ) )
=> ~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Zs2 ) @ ( listrel1 @ A @ R2 ) ) ) ) ) ).
% Cons_listrel1E1
thf(fact_6004_listrel1I1,axiom,
! [A: $tType,X: A,Y: A,R2: set @ ( product_prod @ A @ A ),Xs: list @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Xs ) ) @ ( listrel1 @ A @ R2 ) ) ) ).
% listrel1I1
thf(fact_6005_listrel__Cons2,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Y: B,Ys: list @ B,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ Xs @ ( cons @ B @ Y @ Ys ) ) @ ( listrel @ A @ B @ R2 ) )
=> ~ ! [X5: A,Xs3: list @ A] :
( ( Xs
= ( cons @ A @ X5 @ Xs3 ) )
=> ( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X5 @ Y ) @ R2 )
=> ~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ Xs3 @ Ys ) @ ( listrel @ A @ B @ R2 ) ) ) ) ) ).
% listrel_Cons2
thf(fact_6006_listrel__Cons1,axiom,
! [B: $tType,A: $tType,Y: A,Ys: list @ A,Xs: list @ B,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ ( cons @ A @ Y @ Ys ) @ Xs ) @ ( listrel @ A @ B @ R2 ) )
=> ~ ! [Y4: B,Ys4: list @ B] :
( ( Xs
= ( cons @ B @ Y4 @ Ys4 ) )
=> ( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Y @ Y4 ) @ R2 )
=> ~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ Ys @ Ys4 ) @ ( listrel @ A @ B @ R2 ) ) ) ) ) ).
% listrel_Cons1
thf(fact_6007_listrel_OCons,axiom,
! [B: $tType,A: $tType,X: A,Y: B,R2: set @ ( product_prod @ A @ B ),Xs: list @ A,Ys: list @ B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y ) @ R2 )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ Xs @ Ys ) @ ( listrel @ A @ B @ R2 ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ ( cons @ A @ X @ Xs ) @ ( cons @ B @ Y @ Ys ) ) @ ( listrel @ A @ B @ R2 ) ) ) ) ).
% listrel.Cons
thf(fact_6008_count__list_Osimps_I2_J,axiom,
! [A: $tType,X: A,Y: A,Xs: list @ A] :
( ( ( X = Y )
=> ( ( count_list @ A @ ( cons @ A @ X @ Xs ) @ Y )
= ( plus_plus @ nat @ ( count_list @ A @ Xs @ Y ) @ ( one_one @ nat ) ) ) )
& ( ( X != Y )
=> ( ( count_list @ A @ ( cons @ A @ X @ Xs ) @ Y )
= ( count_list @ A @ Xs @ Y ) ) ) ) ).
% count_list.simps(2)
thf(fact_6009_the__elem__set,axiom,
! [A: $tType,X: A] :
( ( the_elem @ A @ ( set2 @ A @ ( cons @ A @ X @ ( nil @ A ) ) ) )
= X ) ).
% the_elem_set
thf(fact_6010_rtrancl__listrel1__ConsI1,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A ),X: A] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( transitive_rtrancl @ ( list @ A ) @ ( listrel1 @ A @ R2 ) ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ X @ Ys ) ) @ ( transitive_rtrancl @ ( list @ A ) @ ( listrel1 @ A @ R2 ) ) ) ) ).
% rtrancl_listrel1_ConsI1
thf(fact_6011_lexordp_Omono,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( order_mono @ ( ( list @ A ) > ( list @ A ) > $o ) @ ( ( list @ A ) > ( list @ A ) > $o )
@ ^ [P6: ( list @ A ) > ( list @ A ) > $o,X16: list @ A,X24: list @ A] :
( ? [Y2: A,Ys3: list @ A] :
( ( X16
= ( nil @ A ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( X16
= ( cons @ A @ X2 @ Xs2 ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) )
& ( ord_less @ A @ X2 @ Y2 ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( X16
= ( cons @ A @ X2 @ Xs2 ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) )
& ~ ( ord_less @ A @ X2 @ Y2 )
& ~ ( ord_less @ A @ Y2 @ X2 )
& ( P6 @ Xs2 @ Ys3 ) ) ) ) ) ).
% lexordp.mono
thf(fact_6012_zip__replicate1,axiom,
! [A: $tType,B: $tType,N2: nat,X: A,Ys: list @ B] :
( ( zip @ A @ B @ ( replicate @ A @ N2 @ X ) @ Ys )
= ( map @ B @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X ) @ ( take @ B @ N2 @ Ys ) ) ) ).
% zip_replicate1
thf(fact_6013_list_Osize_I4_J,axiom,
! [A: $tType,X21: A,X222: list @ A] :
( ( size_size @ ( list @ A ) @ ( cons @ A @ X21 @ X222 ) )
= ( plus_plus @ nat @ ( size_size @ ( list @ A ) @ X222 ) @ ( suc @ ( zero_zero @ nat ) ) ) ) ).
% list.size(4)
thf(fact_6014_refl__on__def_H,axiom,
! [A: $tType] :
( ( refl_on @ A )
= ( ^ [A6: set @ A,R4: set @ ( product_prod @ A @ A )] :
( ! [X2: product_prod @ A @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ X2 @ R4 )
=> ( product_case_prod @ A @ A @ $o
@ ^ [Y2: A,Z6: A] :
( ( member2 @ A @ Y2 @ A6 )
& ( member2 @ A @ Z6 @ A6 ) )
@ X2 ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ X2 ) @ R4 ) ) ) ) ) ).
% refl_on_def'
thf(fact_6015_nth__Cons_H,axiom,
! [A: $tType,N2: nat,X: A,Xs: list @ A] :
( ( ( N2
= ( zero_zero @ nat ) )
=> ( ( nth @ A @ ( cons @ A @ X @ Xs ) @ N2 )
= X ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( nth @ A @ ( cons @ A @ X @ Xs ) @ N2 )
= ( nth @ A @ Xs @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) ) ) ) ) ).
% nth_Cons'
thf(fact_6016_zip__replicate2,axiom,
! [B: $tType,A: $tType,Xs: list @ A,N2: nat,Y: B] :
( ( zip @ A @ B @ Xs @ ( replicate @ B @ N2 @ Y ) )
= ( map @ A @ ( product_prod @ A @ B )
@ ^ [X2: A] : ( product_Pair @ A @ B @ X2 @ Y )
@ ( take @ A @ N2 @ Xs ) ) ) ).
% zip_replicate2
thf(fact_6017_listrel_Ocases,axiom,
! [B: $tType,A: $tType,A12: list @ A,A23: list @ B,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ A12 @ A23 ) @ ( listrel @ A @ B @ R2 ) )
=> ( ( ( A12
= ( nil @ A ) )
=> ( A23
!= ( nil @ B ) ) )
=> ~ ! [X5: A,Y4: B,Xs3: list @ A] :
( ( A12
= ( cons @ A @ X5 @ Xs3 ) )
=> ! [Ys4: list @ B] :
( ( A23
= ( cons @ B @ Y4 @ Ys4 ) )
=> ( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X5 @ Y4 ) @ R2 )
=> ~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ Xs3 @ Ys4 ) @ ( listrel @ A @ B @ R2 ) ) ) ) ) ) ) ).
% listrel.cases
thf(fact_6018_listrel_Osimps,axiom,
! [B: $tType,A: $tType,A12: list @ A,A23: list @ B,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ A12 @ A23 ) @ ( listrel @ A @ B @ R2 ) )
= ( ( ( A12
= ( nil @ A ) )
& ( A23
= ( nil @ B ) ) )
| ? [X2: A,Y2: B,Xs2: list @ A,Ys3: list @ B] :
( ( A12
= ( cons @ A @ X2 @ Xs2 ) )
& ( A23
= ( cons @ B @ Y2 @ Ys3 ) )
& ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R2 )
& ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ Xs2 @ Ys3 ) @ ( listrel @ A @ B @ R2 ) ) ) ) ) ).
% listrel.simps
thf(fact_6019_remdups__adj__replicate,axiom,
! [A: $tType,N2: nat,X: A] :
( ( ( N2
= ( zero_zero @ nat ) )
=> ( ( remdups_adj @ A @ ( replicate @ A @ N2 @ X ) )
= ( nil @ A ) ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( remdups_adj @ A @ ( replicate @ A @ N2 @ X ) )
= ( cons @ A @ X @ ( nil @ A ) ) ) ) ) ).
% remdups_adj_replicate
thf(fact_6020_remdups__adj__singleton,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( ( remdups_adj @ A @ Xs )
= ( cons @ A @ X @ ( nil @ A ) ) )
=> ( Xs
= ( replicate @ A @ ( size_size @ ( list @ A ) @ Xs ) @ X ) ) ) ).
% remdups_adj_singleton
thf(fact_6021_Id__on__set,axiom,
! [A: $tType,Xs: list @ A] :
( ( id_on @ A @ ( set2 @ A @ Xs ) )
= ( set2 @ ( product_prod @ A @ A )
@ ( map @ A @ ( product_prod @ A @ A )
@ ^ [X2: A] : ( product_Pair @ A @ A @ X2 @ X2 )
@ Xs ) ) ) ).
% Id_on_set
thf(fact_6022_list_Osize__gen_I2_J,axiom,
! [A: $tType,X: A > nat,X21: A,X222: list @ A] :
( ( size_list @ A @ X @ ( cons @ A @ X21 @ X222 ) )
= ( plus_plus @ nat @ ( plus_plus @ nat @ ( X @ X21 ) @ ( size_list @ A @ X @ X222 ) ) @ ( suc @ ( zero_zero @ nat ) ) ) ) ).
% list.size_gen(2)
thf(fact_6023_shuffles_Oelims,axiom,
! [A: $tType,X: list @ A,Xa2: list @ A,Y: set @ ( list @ A )] :
( ( ( shuffles @ A @ X @ Xa2 )
= Y )
=> ( ( ( X
= ( nil @ A ) )
=> ( Y
!= ( insert2 @ ( list @ A ) @ Xa2 @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) ) )
=> ( ( ( Xa2
= ( nil @ A ) )
=> ( Y
!= ( insert2 @ ( list @ A ) @ X @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) ) )
=> ~ ! [X5: A,Xs3: list @ A] :
( ( X
= ( cons @ A @ X5 @ Xs3 ) )
=> ! [Y4: A,Ys4: list @ A] :
( ( Xa2
= ( cons @ A @ Y4 @ Ys4 ) )
=> ( Y
!= ( sup_sup @ ( set @ ( list @ A ) ) @ ( image2 @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X5 ) @ ( shuffles @ A @ Xs3 @ ( cons @ A @ Y4 @ Ys4 ) ) ) @ ( image2 @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ Y4 ) @ ( shuffles @ A @ ( cons @ A @ X5 @ Xs3 ) @ Ys4 ) ) ) ) ) ) ) ) ) ).
% shuffles.elims
thf(fact_6024_nth__equal__first__eq,axiom,
! [A: $tType,X: A,Xs: list @ A,N2: nat] :
( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( ord_less_eq @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ( nth @ A @ ( cons @ A @ X @ Xs ) @ N2 )
= X )
= ( N2
= ( zero_zero @ nat ) ) ) ) ) ).
% nth_equal_first_eq
thf(fact_6025_nth__non__equal__first__eq,axiom,
! [A: $tType,X: A,Y: A,Xs: list @ A,N2: nat] :
( ( X != Y )
=> ( ( ( nth @ A @ ( cons @ A @ X @ Xs ) @ N2 )
= Y )
= ( ( ( nth @ A @ Xs @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) )
= Y )
& ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% nth_non_equal_first_eq
thf(fact_6026_take__Cons_H,axiom,
! [A: $tType,N2: nat,X: A,Xs: list @ A] :
( ( ( N2
= ( zero_zero @ nat ) )
=> ( ( take @ A @ N2 @ ( cons @ A @ X @ Xs ) )
= ( nil @ A ) ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( take @ A @ N2 @ ( cons @ A @ X @ Xs ) )
= ( cons @ A @ X @ ( take @ A @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ Xs ) ) ) ) ) ).
% take_Cons'
thf(fact_6027_Cons__replicate__eq,axiom,
! [A: $tType,X: A,Xs: list @ A,N2: nat,Y: A] :
( ( ( cons @ A @ X @ Xs )
= ( replicate @ A @ N2 @ Y ) )
= ( ( X = Y )
& ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
& ( Xs
= ( replicate @ A @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ X ) ) ) ) ).
% Cons_replicate_eq
thf(fact_6028_map__of__map__restrict,axiom,
! [B: $tType,A: $tType,F2: A > B,Ks2: list @ A] :
( ( map_of @ A @ B
@ ( map @ A @ ( product_prod @ A @ B )
@ ^ [K2: A] : ( product_Pair @ A @ B @ K2 @ ( F2 @ K2 ) )
@ Ks2 ) )
= ( restrict_map @ A @ B @ ( comp @ B @ ( option @ B ) @ A @ ( some @ B ) @ F2 ) @ ( set2 @ A @ Ks2 ) ) ) ).
% map_of_map_restrict
thf(fact_6029_map__of__map__keys,axiom,
! [B: $tType,A: $tType,Xs: list @ A,M: A > ( option @ B )] :
( ( ( set2 @ A @ Xs )
= ( dom @ A @ B @ M ) )
=> ( ( map_of @ A @ B
@ ( map @ A @ ( product_prod @ A @ B )
@ ^ [K2: A] : ( product_Pair @ A @ B @ K2 @ ( the2 @ B @ ( M @ K2 ) ) )
@ Xs ) )
= M ) ) ).
% map_of_map_keys
thf(fact_6030_Cons__lenlex__iff,axiom,
! [A: $tType,M: A,Ms: list @ A,N2: A,Ns: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ M @ Ms ) @ ( cons @ A @ N2 @ Ns ) ) @ ( lenlex @ A @ R2 ) )
= ( ( ord_less @ nat @ ( size_size @ ( list @ A ) @ Ms ) @ ( size_size @ ( list @ A ) @ Ns ) )
| ( ( ( size_size @ ( list @ A ) @ Ms )
= ( size_size @ ( list @ A ) @ Ns ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ M @ N2 ) @ R2 ) )
| ( ( M = N2 )
& ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Ms @ Ns ) @ ( lenlex @ A @ R2 ) ) ) ) ) ).
% Cons_lenlex_iff
thf(fact_6031_map__of_Osimps_I2_J,axiom,
! [B: $tType,A: $tType,P4: product_prod @ A @ B,Ps: list @ ( product_prod @ A @ B )] :
( ( map_of @ A @ B @ ( cons @ ( product_prod @ A @ B ) @ P4 @ Ps ) )
= ( fun_upd @ A @ ( option @ B ) @ ( map_of @ A @ B @ Ps ) @ ( product_fst @ A @ B @ P4 ) @ ( some @ B @ ( product_snd @ A @ B @ P4 ) ) ) ) ).
% map_of.simps(2)
thf(fact_6032_refl__on__singleton,axiom,
! [A: $tType,X: A] : ( refl_on @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) @ ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ X ) @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ) ).
% refl_on_singleton
thf(fact_6033_rtrancl__listrel1__ConsI2,axiom,
! [A: $tType,X: A,Y: A,R2: set @ ( product_prod @ A @ A ),Xs: list @ A,Ys: list @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( transitive_rtrancl @ ( list @ A ) @ ( listrel1 @ A @ R2 ) ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) ) @ ( transitive_rtrancl @ ( list @ A ) @ ( listrel1 @ A @ R2 ) ) ) ) ) ).
% rtrancl_listrel1_ConsI2
thf(fact_6034_Pow__set_I2_J,axiom,
! [B: $tType,X: B,Xs: list @ B] :
( ( pow2 @ B @ ( set2 @ B @ ( cons @ B @ X @ Xs ) ) )
= ( sup_sup @ ( set @ ( set @ B ) ) @ ( pow2 @ B @ ( set2 @ B @ Xs ) ) @ ( image2 @ ( set @ B ) @ ( set @ B ) @ ( insert2 @ B @ X ) @ ( pow2 @ B @ ( set2 @ B @ Xs ) ) ) ) ) ).
% Pow_set(2)
thf(fact_6035_sorted__list__of__set__nonempty,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( linord4507533701916653071of_set @ A @ A4 )
= ( cons @ A @ ( lattic643756798350308766er_Min @ A @ A4 ) @ ( linord4507533701916653071of_set @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ ( lattic643756798350308766er_Min @ A @ A4 ) @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ).
% sorted_list_of_set_nonempty
thf(fact_6036_product__code,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ B] :
( ( product_product @ A @ B @ ( set2 @ A @ Xs ) @ ( set2 @ B @ Ys ) )
= ( set2 @ ( product_prod @ A @ B )
@ ( concat @ ( product_prod @ A @ B )
@ ( map @ A @ ( list @ ( product_prod @ A @ B ) )
@ ^ [X2: A] : ( map @ B @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 ) @ Ys )
@ Xs ) ) ) ) ).
% product_code
thf(fact_6037_set__Cons__sing__Nil,axiom,
! [A: $tType,A4: set @ A] :
( ( set_Cons @ A @ A4 @ ( insert2 @ ( list @ A ) @ ( nil @ A ) @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) )
= ( image2 @ A @ ( list @ A )
@ ^ [X2: A] : ( cons @ A @ X2 @ ( nil @ A ) )
@ A4 ) ) ).
% set_Cons_sing_Nil
thf(fact_6038_concat__inth,axiom,
! [A: $tType,Xs: list @ A,X: A,Ys: list @ A] :
( ( nth @ A @ ( append @ A @ Xs @ ( append @ A @ ( cons @ A @ X @ ( nil @ A ) ) @ Ys ) ) @ ( size_size @ ( list @ A ) @ Xs ) )
= X ) ).
% concat_inth
thf(fact_6039_append_Oassoc,axiom,
! [A: $tType,A3: list @ A,B2: list @ A,C2: list @ A] :
( ( append @ A @ ( append @ A @ A3 @ B2 ) @ C2 )
= ( append @ A @ A3 @ ( append @ A @ B2 @ C2 ) ) ) ).
% append.assoc
thf(fact_6040_append__assoc,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ( append @ A @ ( append @ A @ Xs @ Ys ) @ Zs )
= ( append @ A @ Xs @ ( append @ A @ Ys @ Zs ) ) ) ).
% append_assoc
thf(fact_6041_append__same__eq,axiom,
! [A: $tType,Ys: list @ A,Xs: list @ A,Zs: list @ A] :
( ( ( append @ A @ Ys @ Xs )
= ( append @ A @ Zs @ Xs ) )
= ( Ys = Zs ) ) ).
% append_same_eq
thf(fact_6042_same__append__eq,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ( ( append @ A @ Xs @ Ys )
= ( append @ A @ Xs @ Zs ) )
= ( Ys = Zs ) ) ).
% same_append_eq
thf(fact_6043_append__is__Nil__conv,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( append @ A @ Xs @ Ys )
= ( nil @ A ) )
= ( ( Xs
= ( nil @ A ) )
& ( Ys
= ( nil @ A ) ) ) ) ).
% append_is_Nil_conv
thf(fact_6044_Nil__is__append__conv,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( nil @ A )
= ( append @ A @ Xs @ Ys ) )
= ( ( Xs
= ( nil @ A ) )
& ( Ys
= ( nil @ A ) ) ) ) ).
% Nil_is_append_conv
thf(fact_6045_self__append__conv2,axiom,
! [A: $tType,Y: list @ A,Xs: list @ A] :
( ( Y
= ( append @ A @ Xs @ Y ) )
= ( Xs
= ( nil @ A ) ) ) ).
% self_append_conv2
thf(fact_6046_append__self__conv2,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( append @ A @ Xs @ Ys )
= Ys )
= ( Xs
= ( nil @ A ) ) ) ).
% append_self_conv2
thf(fact_6047_self__append__conv,axiom,
! [A: $tType,Y: list @ A,Ys: list @ A] :
( ( Y
= ( append @ A @ Y @ Ys ) )
= ( Ys
= ( nil @ A ) ) ) ).
% self_append_conv
thf(fact_6048_append__self__conv,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( append @ A @ Xs @ Ys )
= Xs )
= ( Ys
= ( nil @ A ) ) ) ).
% append_self_conv
thf(fact_6049_append__Nil2,axiom,
! [A: $tType,Xs: list @ A] :
( ( append @ A @ Xs @ ( nil @ A ) )
= Xs ) ).
% append_Nil2
thf(fact_6050_append_Oright__neutral,axiom,
! [A: $tType,A3: list @ A] :
( ( append @ A @ A3 @ ( nil @ A ) )
= A3 ) ).
% append.right_neutral
thf(fact_6051_append__eq__append__conv,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,Us: list @ A,Vs2: list @ A] :
( ( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ A ) @ Ys ) )
| ( ( size_size @ ( list @ A ) @ Us )
= ( size_size @ ( list @ A ) @ Vs2 ) ) )
=> ( ( ( append @ A @ Xs @ Us )
= ( append @ A @ Ys @ Vs2 ) )
= ( ( Xs = Ys )
& ( Us = Vs2 ) ) ) ) ).
% append_eq_append_conv
thf(fact_6052_map__append,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B,Ys: list @ B] :
( ( map @ B @ A @ F2 @ ( append @ B @ Xs @ Ys ) )
= ( append @ A @ ( map @ B @ A @ F2 @ Xs ) @ ( map @ B @ A @ F2 @ Ys ) ) ) ).
% map_append
thf(fact_6053_concat__append,axiom,
! [A: $tType,Xs: list @ ( list @ A ),Ys: list @ ( list @ A )] :
( ( concat @ A @ ( append @ ( list @ A ) @ Xs @ Ys ) )
= ( append @ A @ ( concat @ A @ Xs ) @ ( concat @ A @ Ys ) ) ) ).
% concat_append
thf(fact_6054_removeAll__append,axiom,
! [A: $tType,X: A,Xs: list @ A,Ys: list @ A] :
( ( removeAll @ A @ X @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ ( removeAll @ A @ X @ Xs ) @ ( removeAll @ A @ X @ Ys ) ) ) ).
% removeAll_append
thf(fact_6055_foldl__append,axiom,
! [A: $tType,B: $tType,F2: A > B > A,A3: A,Xs: list @ B,Ys: list @ B] :
( ( foldl @ A @ B @ F2 @ A3 @ ( append @ B @ Xs @ Ys ) )
= ( foldl @ A @ B @ F2 @ ( foldl @ A @ B @ F2 @ A3 @ Xs ) @ Ys ) ) ).
% foldl_append
thf(fact_6056_append1__eq__conv,axiom,
! [A: $tType,Xs: list @ A,X: A,Ys: list @ A,Y: A] :
( ( ( append @ A @ Xs @ ( cons @ A @ X @ ( nil @ A ) ) )
= ( append @ A @ Ys @ ( cons @ A @ Y @ ( nil @ A ) ) ) )
= ( ( Xs = Ys )
& ( X = Y ) ) ) ).
% append1_eq_conv
thf(fact_6057_length__append,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( size_size @ ( list @ A ) @ ( append @ A @ Xs @ Ys ) )
= ( plus_plus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ A ) @ Ys ) ) ) ).
% length_append
thf(fact_6058_set__append,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( set2 @ A @ ( append @ A @ Xs @ Ys ) )
= ( sup_sup @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ Ys ) ) ) ).
% set_append
thf(fact_6059_zip__append,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Us: list @ B,Ys: list @ A,Vs2: list @ B] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Us ) )
=> ( ( zip @ A @ B @ ( append @ A @ Xs @ Ys ) @ ( append @ B @ Us @ Vs2 ) )
= ( append @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Us ) @ ( zip @ A @ B @ Ys @ Vs2 ) ) ) ) ).
% zip_append
thf(fact_6060_size__list__append,axiom,
! [A: $tType,F2: A > nat,Xs: list @ A,Ys: list @ A] :
( ( size_list @ A @ F2 @ ( append @ A @ Xs @ Ys ) )
= ( plus_plus @ nat @ ( size_list @ A @ F2 @ Xs ) @ ( size_list @ A @ F2 @ Ys ) ) ) ).
% size_list_append
thf(fact_6061_sorted__list__of__set__lessThan__Suc,axiom,
! [K: nat] :
( ( linord4507533701916653071of_set @ nat @ ( set_ord_lessThan @ nat @ ( suc @ K ) ) )
= ( append @ nat @ ( linord4507533701916653071of_set @ nat @ ( set_ord_lessThan @ nat @ K ) ) @ ( cons @ nat @ K @ ( nil @ nat ) ) ) ) ).
% sorted_list_of_set_lessThan_Suc
thf(fact_6062_sorted__list__of__set__atMost__Suc,axiom,
! [K: nat] :
( ( linord4507533701916653071of_set @ nat @ ( set_ord_atMost @ nat @ ( suc @ K ) ) )
= ( append @ nat @ ( linord4507533701916653071of_set @ nat @ ( set_ord_atMost @ nat @ K ) ) @ ( cons @ nat @ ( suc @ K ) @ ( nil @ nat ) ) ) ) ).
% sorted_list_of_set_atMost_Suc
thf(fact_6063_bind__simps_I2_J,axiom,
! [A: $tType,B: $tType,X: B,Xs: list @ B,F2: B > ( list @ A )] :
( ( bind @ B @ A @ ( cons @ B @ X @ Xs ) @ F2 )
= ( append @ A @ ( F2 @ X ) @ ( bind @ B @ A @ Xs @ F2 ) ) ) ).
% bind_simps(2)
thf(fact_6064_nth__append__length,axiom,
! [A: $tType,Xs: list @ A,X: A,Ys: list @ A] :
( ( nth @ A @ ( append @ A @ Xs @ ( cons @ A @ X @ Ys ) ) @ ( size_size @ ( list @ A ) @ Xs ) )
= X ) ).
% nth_append_length
thf(fact_6065_nth__append__length__plus,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,N2: nat] :
( ( nth @ A @ ( append @ A @ Xs @ Ys ) @ ( plus_plus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 ) )
= ( nth @ A @ Ys @ N2 ) ) ).
% nth_append_length_plus
thf(fact_6066_take__append,axiom,
! [A: $tType,N2: nat,Xs: list @ A,Ys: list @ A] :
( ( take @ A @ N2 @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ ( take @ A @ N2 @ Xs ) @ ( take @ A @ ( minus_minus @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) ) @ Ys ) ) ) ).
% take_append
thf(fact_6067_list__update__length,axiom,
! [A: $tType,Xs: list @ A,X: A,Ys: list @ A,Y: A] :
( ( list_update @ A @ ( append @ A @ Xs @ ( cons @ A @ X @ Ys ) ) @ ( size_size @ ( list @ A ) @ Xs ) @ Y )
= ( append @ A @ Xs @ ( cons @ A @ Y @ Ys ) ) ) ).
% list_update_length
thf(fact_6068_distinct__append,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( distinct @ A @ ( append @ A @ Xs @ Ys ) )
= ( ( distinct @ A @ Xs )
& ( distinct @ A @ Ys )
& ( ( inf_inf @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ Ys ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% distinct_append
thf(fact_6069_n__lists__Nil,axiom,
! [A: $tType,N2: nat] :
( ( ( N2
= ( zero_zero @ nat ) )
=> ( ( n_lists @ A @ N2 @ ( nil @ A ) )
= ( cons @ ( list @ A ) @ ( nil @ A ) @ ( nil @ ( list @ A ) ) ) ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( n_lists @ A @ N2 @ ( nil @ A ) )
= ( nil @ ( list @ A ) ) ) ) ) ).
% n_lists_Nil
thf(fact_6070_map__upds__append1,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ B,M: A > ( option @ B ),X: A] :
( ( ord_less @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( map_upds @ A @ B @ M @ ( append @ A @ Xs @ ( cons @ A @ X @ ( nil @ A ) ) ) @ Ys )
= ( fun_upd @ A @ ( option @ B ) @ ( map_upds @ A @ B @ M @ Xs @ Ys ) @ X @ ( some @ B @ ( nth @ B @ Ys @ ( size_size @ ( list @ A ) @ Xs ) ) ) ) ) ) ).
% map_upds_append1
thf(fact_6071_append__eq__map__conv,axiom,
! [A: $tType,B: $tType,Ys: list @ A,Zs: list @ A,F2: B > A,Xs: list @ B] :
( ( ( append @ A @ Ys @ Zs )
= ( map @ B @ A @ F2 @ Xs ) )
= ( ? [Us2: list @ B,Vs: list @ B] :
( ( Xs
= ( append @ B @ Us2 @ Vs ) )
& ( Ys
= ( map @ B @ A @ F2 @ Us2 ) )
& ( Zs
= ( map @ B @ A @ F2 @ Vs ) ) ) ) ) ).
% append_eq_map_conv
thf(fact_6072_map__eq__append__conv,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B,Ys: list @ A,Zs: list @ A] :
( ( ( map @ B @ A @ F2 @ Xs )
= ( append @ A @ Ys @ Zs ) )
= ( ? [Us2: list @ B,Vs: list @ B] :
( ( Xs
= ( append @ B @ Us2 @ Vs ) )
& ( Ys
= ( map @ B @ A @ F2 @ Us2 ) )
& ( Zs
= ( map @ B @ A @ F2 @ Vs ) ) ) ) ) ).
% map_eq_append_conv
thf(fact_6073_split__list__first__prop__iff,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ( ? [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
& ( P2 @ X2 ) ) )
= ( ? [Ys3: list @ A,X2: A] :
( ? [Zs3: list @ A] :
( Xs
= ( append @ A @ Ys3 @ ( cons @ A @ X2 @ Zs3 ) ) )
& ( P2 @ X2 )
& ! [Y2: A] :
( ( member2 @ A @ Y2 @ ( set2 @ A @ Ys3 ) )
=> ~ ( P2 @ Y2 ) ) ) ) ) ).
% split_list_first_prop_iff
thf(fact_6074_split__list__last__prop__iff,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ( ? [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
& ( P2 @ X2 ) ) )
= ( ? [Ys3: list @ A,X2: A,Zs3: list @ A] :
( ( Xs
= ( append @ A @ Ys3 @ ( cons @ A @ X2 @ Zs3 ) ) )
& ( P2 @ X2 )
& ! [Y2: A] :
( ( member2 @ A @ Y2 @ ( set2 @ A @ Zs3 ) )
=> ~ ( P2 @ Y2 ) ) ) ) ) ).
% split_list_last_prop_iff
thf(fact_6075_in__set__conv__decomp__first,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
= ( ? [Ys3: list @ A,Zs3: list @ A] :
( ( Xs
= ( append @ A @ Ys3 @ ( cons @ A @ X @ Zs3 ) ) )
& ~ ( member2 @ A @ X @ ( set2 @ A @ Ys3 ) ) ) ) ) ).
% in_set_conv_decomp_first
thf(fact_6076_in__set__conv__decomp__last,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
= ( ? [Ys3: list @ A,Zs3: list @ A] :
( ( Xs
= ( append @ A @ Ys3 @ ( cons @ A @ X @ Zs3 ) ) )
& ~ ( member2 @ A @ X @ ( set2 @ A @ Zs3 ) ) ) ) ) ).
% in_set_conv_decomp_last
thf(fact_6077_split__list__first__propE,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ? [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Xs ) )
& ( P2 @ X3 ) )
=> ~ ! [Ys4: list @ A,X5: A] :
( ? [Zs2: list @ A] :
( Xs
= ( append @ A @ Ys4 @ ( cons @ A @ X5 @ Zs2 ) ) )
=> ( ( P2 @ X5 )
=> ~ ! [Xa: A] :
( ( member2 @ A @ Xa @ ( set2 @ A @ Ys4 ) )
=> ~ ( P2 @ Xa ) ) ) ) ) ).
% split_list_first_propE
thf(fact_6078_split__list__last__propE,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ? [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Xs ) )
& ( P2 @ X3 ) )
=> ~ ! [Ys4: list @ A,X5: A,Zs2: list @ A] :
( ( Xs
= ( append @ A @ Ys4 @ ( cons @ A @ X5 @ Zs2 ) ) )
=> ( ( P2 @ X5 )
=> ~ ! [Xa: A] :
( ( member2 @ A @ Xa @ ( set2 @ A @ Zs2 ) )
=> ~ ( P2 @ Xa ) ) ) ) ) ).
% split_list_last_propE
thf(fact_6079_split__list__first__prop,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ? [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Xs ) )
& ( P2 @ X3 ) )
=> ? [Ys4: list @ A,X5: A] :
( ? [Zs2: list @ A] :
( Xs
= ( append @ A @ Ys4 @ ( cons @ A @ X5 @ Zs2 ) ) )
& ( P2 @ X5 )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ ( set2 @ A @ Ys4 ) )
=> ~ ( P2 @ Xa ) ) ) ) ).
% split_list_first_prop
thf(fact_6080_split__list__last__prop,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ? [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Xs ) )
& ( P2 @ X3 ) )
=> ? [Ys4: list @ A,X5: A,Zs2: list @ A] :
( ( Xs
= ( append @ A @ Ys4 @ ( cons @ A @ X5 @ Zs2 ) ) )
& ( P2 @ X5 )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ ( set2 @ A @ Zs2 ) )
=> ~ ( P2 @ Xa ) ) ) ) ).
% split_list_last_prop
thf(fact_6081_in__set__conv__decomp,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
= ( ? [Ys3: list @ A,Zs3: list @ A] :
( Xs
= ( append @ A @ Ys3 @ ( cons @ A @ X @ Zs3 ) ) ) ) ) ).
% in_set_conv_decomp
thf(fact_6082_append__Cons__eq__iff,axiom,
! [A: $tType,X: A,Xs: list @ A,Ys: list @ A,Xs5: list @ A,Ys6: list @ A] :
( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ~ ( member2 @ A @ X @ ( set2 @ A @ Ys ) )
=> ( ( ( append @ A @ Xs @ ( cons @ A @ X @ Ys ) )
= ( append @ A @ Xs5 @ ( cons @ A @ X @ Ys6 ) ) )
= ( ( Xs = Xs5 )
& ( Ys = Ys6 ) ) ) ) ) ).
% append_Cons_eq_iff
thf(fact_6083_split__list__propE,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ? [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Xs ) )
& ( P2 @ X3 ) )
=> ~ ! [Ys4: list @ A,X5: A] :
( ? [Zs2: list @ A] :
( Xs
= ( append @ A @ Ys4 @ ( cons @ A @ X5 @ Zs2 ) ) )
=> ~ ( P2 @ X5 ) ) ) ).
% split_list_propE
thf(fact_6084_split__list__first,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ? [Ys4: list @ A,Zs2: list @ A] :
( ( Xs
= ( append @ A @ Ys4 @ ( cons @ A @ X @ Zs2 ) ) )
& ~ ( member2 @ A @ X @ ( set2 @ A @ Ys4 ) ) ) ) ).
% split_list_first
thf(fact_6085_split__list__prop,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ? [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Xs ) )
& ( P2 @ X3 ) )
=> ? [Ys4: list @ A,X5: A] :
( ? [Zs2: list @ A] :
( Xs
= ( append @ A @ Ys4 @ ( cons @ A @ X5 @ Zs2 ) ) )
& ( P2 @ X5 ) ) ) ).
% split_list_prop
thf(fact_6086_split__list__last,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ? [Ys4: list @ A,Zs2: list @ A] :
( ( Xs
= ( append @ A @ Ys4 @ ( cons @ A @ X @ Zs2 ) ) )
& ~ ( member2 @ A @ X @ ( set2 @ A @ Zs2 ) ) ) ) ).
% split_list_last
thf(fact_6087_split__list,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ? [Ys4: list @ A,Zs2: list @ A] :
( Xs
= ( append @ A @ Ys4 @ ( cons @ A @ X @ Zs2 ) ) ) ) ).
% split_list
thf(fact_6088_listset_Osimps_I2_J,axiom,
! [A: $tType,A4: set @ A,As3: list @ ( set @ A )] :
( ( listset @ A @ ( cons @ ( set @ A ) @ A4 @ As3 ) )
= ( set_Cons @ A @ A4 @ ( listset @ A @ As3 ) ) ) ).
% listset.simps(2)
thf(fact_6089_rev__induct,axiom,
! [A: $tType,P2: ( list @ A ) > $o,Xs: list @ A] :
( ( P2 @ ( nil @ A ) )
=> ( ! [X5: A,Xs3: list @ A] :
( ( P2 @ Xs3 )
=> ( P2 @ ( append @ A @ Xs3 @ ( cons @ A @ X5 @ ( nil @ A ) ) ) ) )
=> ( P2 @ Xs ) ) ) ).
% rev_induct
thf(fact_6090_rev__exhaust,axiom,
! [A: $tType,Xs: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ~ ! [Ys4: list @ A,Y4: A] :
( Xs
!= ( append @ A @ Ys4 @ ( cons @ A @ Y4 @ ( nil @ A ) ) ) ) ) ).
% rev_exhaust
thf(fact_6091_Cons__eq__append__conv,axiom,
! [A: $tType,X: A,Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ( ( cons @ A @ X @ Xs )
= ( append @ A @ Ys @ Zs ) )
= ( ( ( Ys
= ( nil @ A ) )
& ( ( cons @ A @ X @ Xs )
= Zs ) )
| ? [Ys7: list @ A] :
( ( ( cons @ A @ X @ Ys7 )
= Ys )
& ( Xs
= ( append @ A @ Ys7 @ Zs ) ) ) ) ) ).
% Cons_eq_append_conv
thf(fact_6092_append__eq__Cons__conv,axiom,
! [A: $tType,Ys: list @ A,Zs: list @ A,X: A,Xs: list @ A] :
( ( ( append @ A @ Ys @ Zs )
= ( cons @ A @ X @ Xs ) )
= ( ( ( Ys
= ( nil @ A ) )
& ( Zs
= ( cons @ A @ X @ Xs ) ) )
| ? [Ys7: list @ A] :
( ( Ys
= ( cons @ A @ X @ Ys7 ) )
& ( ( append @ A @ Ys7 @ Zs )
= Xs ) ) ) ) ).
% append_eq_Cons_conv
thf(fact_6093_rev__nonempty__induct,axiom,
! [A: $tType,Xs: list @ A,P2: ( list @ A ) > $o] :
( ( Xs
!= ( nil @ A ) )
=> ( ! [X5: A] : ( P2 @ ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ( ! [X5: A,Xs3: list @ A] :
( ( Xs3
!= ( nil @ A ) )
=> ( ( P2 @ Xs3 )
=> ( P2 @ ( append @ A @ Xs3 @ ( cons @ A @ X5 @ ( nil @ A ) ) ) ) ) )
=> ( P2 @ Xs ) ) ) ) ).
% rev_nonempty_induct
thf(fact_6094_concat__eq__append__conv,axiom,
! [A: $tType,Xss: list @ ( list @ A ),Ys: list @ A,Zs: list @ A] :
( ( ( concat @ A @ Xss )
= ( append @ A @ Ys @ Zs ) )
= ( ( ( Xss
= ( nil @ ( list @ A ) ) )
=> ( ( Ys
= ( nil @ A ) )
& ( Zs
= ( nil @ A ) ) ) )
& ( ( Xss
!= ( nil @ ( list @ A ) ) )
=> ? [Xss1: list @ ( list @ A ),Xs2: list @ A,Xs6: list @ A,Xss22: list @ ( list @ A )] :
( ( Xss
= ( append @ ( list @ A ) @ Xss1 @ ( cons @ ( list @ A ) @ ( append @ A @ Xs2 @ Xs6 ) @ Xss22 ) ) )
& ( Ys
= ( append @ A @ ( concat @ A @ Xss1 ) @ Xs2 ) )
& ( Zs
= ( append @ A @ Xs6 @ ( concat @ A @ Xss22 ) ) ) ) ) ) ) ).
% concat_eq_append_conv
thf(fact_6095_concat__eq__appendD,axiom,
! [A: $tType,Xss: list @ ( list @ A ),Ys: list @ A,Zs: list @ A] :
( ( ( concat @ A @ Xss )
= ( append @ A @ Ys @ Zs ) )
=> ( ( Xss
!= ( nil @ ( list @ A ) ) )
=> ? [Xss12: list @ ( list @ A ),Xs3: list @ A,Xs4: list @ A,Xss23: list @ ( list @ A )] :
( ( Xss
= ( append @ ( list @ A ) @ Xss12 @ ( cons @ ( list @ A ) @ ( append @ A @ Xs3 @ Xs4 ) @ Xss23 ) ) )
& ( Ys
= ( append @ A @ ( concat @ A @ Xss12 ) @ Xs3 ) )
& ( Zs
= ( append @ A @ Xs4 @ ( concat @ A @ Xss23 ) ) ) ) ) ) ).
% concat_eq_appendD
thf(fact_6096_concat_Osimps_I2_J,axiom,
! [A: $tType,X: list @ A,Xs: list @ ( list @ A )] :
( ( concat @ A @ ( cons @ ( list @ A ) @ X @ Xs ) )
= ( append @ A @ X @ ( concat @ A @ Xs ) ) ) ).
% concat.simps(2)
thf(fact_6097_Cons__eq__appendI,axiom,
! [A: $tType,X: A,Xs1: list @ A,Ys: list @ A,Xs: list @ A,Zs: list @ A] :
( ( ( cons @ A @ X @ Xs1 )
= Ys )
=> ( ( Xs
= ( append @ A @ Xs1 @ Zs ) )
=> ( ( cons @ A @ X @ Xs )
= ( append @ A @ Ys @ Zs ) ) ) ) ).
% Cons_eq_appendI
thf(fact_6098_append__Cons,axiom,
! [A: $tType,X: A,Xs: list @ A,Ys: list @ A] :
( ( append @ A @ ( cons @ A @ X @ Xs ) @ Ys )
= ( cons @ A @ X @ ( append @ A @ Xs @ Ys ) ) ) ).
% append_Cons
thf(fact_6099_replicate__app__Cons__same,axiom,
! [A: $tType,N2: nat,X: A,Xs: list @ A] :
( ( append @ A @ ( replicate @ A @ N2 @ X ) @ ( cons @ A @ X @ Xs ) )
= ( cons @ A @ X @ ( append @ A @ ( replicate @ A @ N2 @ X ) @ Xs ) ) ) ).
% replicate_app_Cons_same
thf(fact_6100_append__replicate__commute,axiom,
! [A: $tType,N2: nat,X: A,K: nat] :
( ( append @ A @ ( replicate @ A @ N2 @ X ) @ ( replicate @ A @ K @ X ) )
= ( append @ A @ ( replicate @ A @ K @ X ) @ ( replicate @ A @ N2 @ X ) ) ) ).
% append_replicate_commute
thf(fact_6101_enumerate__append__eq,axiom,
! [A: $tType,N2: nat,Xs: list @ A,Ys: list @ A] :
( ( enumerate @ A @ N2 @ ( append @ A @ Xs @ Ys ) )
= ( append @ ( product_prod @ nat @ A ) @ ( enumerate @ A @ N2 @ Xs ) @ ( enumerate @ A @ ( plus_plus @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) ) @ Ys ) ) ) ).
% enumerate_append_eq
thf(fact_6102_remdups__append2,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( remdups @ A @ ( append @ A @ Xs @ ( remdups @ A @ Ys ) ) )
= ( remdups @ A @ ( append @ A @ Xs @ Ys ) ) ) ).
% remdups_append2
thf(fact_6103_append__eq__appendI,axiom,
! [A: $tType,Xs: list @ A,Xs1: list @ A,Zs: list @ A,Ys: list @ A,Us: list @ A] :
( ( ( append @ A @ Xs @ Xs1 )
= Zs )
=> ( ( Ys
= ( append @ A @ Xs1 @ Us ) )
=> ( ( append @ A @ Xs @ Ys )
= ( append @ A @ Zs @ Us ) ) ) ) ).
% append_eq_appendI
thf(fact_6104_append__eq__append__conv2,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,Zs: list @ A,Ts: list @ A] :
( ( ( append @ A @ Xs @ Ys )
= ( append @ A @ Zs @ Ts ) )
= ( ? [Us2: list @ A] :
( ( ( Xs
= ( append @ A @ Zs @ Us2 ) )
& ( ( append @ A @ Us2 @ Ys )
= Ts ) )
| ( ( ( append @ A @ Xs @ Us2 )
= Zs )
& ( Ys
= ( append @ A @ Us2 @ Ts ) ) ) ) ) ) ).
% append_eq_append_conv2
thf(fact_6105_eq__Nil__appendI,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( Xs = Ys )
=> ( Xs
= ( append @ A @ ( nil @ A ) @ Ys ) ) ) ).
% eq_Nil_appendI
thf(fact_6106_append_Oleft__neutral,axiom,
! [A: $tType,A3: list @ A] :
( ( append @ A @ ( nil @ A ) @ A3 )
= A3 ) ).
% append.left_neutral
thf(fact_6107_append__Nil,axiom,
! [A: $tType,Ys: list @ A] :
( ( append @ A @ ( nil @ A ) @ Ys )
= Ys ) ).
% append_Nil
thf(fact_6108_replicate__add,axiom,
! [A: $tType,N2: nat,M: nat,X: A] :
( ( replicate @ A @ ( plus_plus @ nat @ N2 @ M ) @ X )
= ( append @ A @ ( replicate @ A @ N2 @ X ) @ ( replicate @ A @ M @ X ) ) ) ).
% replicate_add
thf(fact_6109_remove1__append,axiom,
! [A: $tType,X: A,Xs: list @ A,Ys: list @ A] :
( ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( remove1 @ A @ X @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ ( remove1 @ A @ X @ Xs ) @ Ys ) ) )
& ( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( remove1 @ A @ X @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ Xs @ ( remove1 @ A @ X @ Ys ) ) ) ) ) ).
% remove1_append
thf(fact_6110_append__listrel1I,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A ),Us: list @ A,Vs2: list @ A] :
( ( ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel1 @ A @ R2 ) )
& ( Us = Vs2 ) )
| ( ( Xs = Ys )
& ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Us @ Vs2 ) @ ( listrel1 @ A @ R2 ) ) ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ Xs @ Us ) @ ( append @ A @ Ys @ Vs2 ) ) @ ( listrel1 @ A @ R2 ) ) ) ).
% append_listrel1I
thf(fact_6111_lexord__append__leftI,axiom,
! [A: $tType,U: list @ A,V2: list @ A,R2: set @ ( product_prod @ A @ A ),X: list @ A] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ U @ V2 ) @ ( lexord @ A @ R2 ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ X @ U ) @ ( append @ A @ X @ V2 ) ) @ ( lexord @ A @ R2 ) ) ) ).
% lexord_append_leftI
thf(fact_6112_lex__append__leftI,axiom,
! [A: $tType,Ys: list @ A,Zs: list @ A,R2: set @ ( product_prod @ A @ A ),Xs: list @ A] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Ys @ Zs ) @ ( lex @ A @ R2 ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ Xs @ Ys ) @ ( append @ A @ Xs @ Zs ) ) @ ( lex @ A @ R2 ) ) ) ).
% lex_append_leftI
thf(fact_6113_comm__append__are__replicate,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( append @ A @ Xs @ Ys )
= ( append @ A @ Ys @ Xs ) )
=> ? [M3: nat,N3: nat,Zs2: list @ A] :
( ( ( concat @ A @ ( replicate @ ( list @ A ) @ M3 @ Zs2 ) )
= Xs )
& ( ( concat @ A @ ( replicate @ ( list @ A ) @ N3 @ Zs2 ) )
= Ys ) ) ) ).
% comm_append_are_replicate
thf(fact_6114_same__length__different,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( Xs != Ys )
=> ( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ A ) @ Ys ) )
=> ? [Pre: list @ A,X5: A,Xs4: list @ A,Y4: A,Ys5: list @ A] :
( ( X5 != Y4 )
& ( Xs
= ( append @ A @ Pre @ ( append @ A @ ( cons @ A @ X5 @ ( nil @ A ) ) @ Xs4 ) ) )
& ( Ys
= ( append @ A @ Pre @ ( append @ A @ ( cons @ A @ Y4 @ ( nil @ A ) ) @ Ys5 ) ) ) ) ) ) ).
% same_length_different
thf(fact_6115_not__distinct__decomp,axiom,
! [A: $tType,Ws2: list @ A] :
( ~ ( distinct @ A @ Ws2 )
=> ? [Xs3: list @ A,Ys4: list @ A,Zs2: list @ A,Y4: A] :
( Ws2
= ( append @ A @ Xs3 @ ( append @ A @ ( cons @ A @ Y4 @ ( nil @ A ) ) @ ( append @ A @ Ys4 @ ( append @ A @ ( cons @ A @ Y4 @ ( nil @ A ) ) @ Zs2 ) ) ) ) ) ) ).
% not_distinct_decomp
thf(fact_6116_not__distinct__conv__prefix,axiom,
! [A: $tType,As: list @ A] :
( ( ~ ( distinct @ A @ As ) )
= ( ? [Xs2: list @ A,Y2: A,Ys3: list @ A] :
( ( member2 @ A @ Y2 @ ( set2 @ A @ Xs2 ) )
& ( distinct @ A @ Xs2 )
& ( As
= ( append @ A @ Xs2 @ ( cons @ A @ Y2 @ Ys3 ) ) ) ) ) ) ).
% not_distinct_conv_prefix
thf(fact_6117_replicate__append__same,axiom,
! [A: $tType,I: nat,X: A] :
( ( append @ A @ ( replicate @ A @ I @ X ) @ ( cons @ A @ X @ ( nil @ A ) ) )
= ( cons @ A @ X @ ( replicate @ A @ I @ X ) ) ) ).
% replicate_append_same
thf(fact_6118_list__update__append1,axiom,
! [A: $tType,I: nat,Xs: list @ A,Ys: list @ A,X: A] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( list_update @ A @ ( append @ A @ Xs @ Ys ) @ I @ X )
= ( append @ A @ ( list_update @ A @ Xs @ I @ X ) @ Ys ) ) ) ).
% list_update_append1
thf(fact_6119_remdups__adj__append__two,axiom,
! [A: $tType,Xs: list @ A,X: A,Y: A] :
( ( remdups_adj @ A @ ( append @ A @ Xs @ ( cons @ A @ X @ ( cons @ A @ Y @ ( nil @ A ) ) ) ) )
= ( append @ A @ ( remdups_adj @ A @ ( append @ A @ Xs @ ( cons @ A @ X @ ( nil @ A ) ) ) ) @ ( if @ ( list @ A ) @ ( X = Y ) @ ( nil @ A ) @ ( cons @ A @ Y @ ( nil @ A ) ) ) ) ) ).
% remdups_adj_append_two
thf(fact_6120_remove1__split,axiom,
! [A: $tType,A3: A,Xs: list @ A,Ys: list @ A] :
( ( member2 @ A @ A3 @ ( set2 @ A @ Xs ) )
=> ( ( ( remove1 @ A @ A3 @ Xs )
= Ys )
= ( ? [Ls: list @ A,Rs: list @ A] :
( ( Xs
= ( append @ A @ Ls @ ( cons @ A @ A3 @ Rs ) ) )
& ~ ( member2 @ A @ A3 @ ( set2 @ A @ Ls ) )
& ( Ys
= ( append @ A @ Ls @ Rs ) ) ) ) ) ) ).
% remove1_split
thf(fact_6121_lexord__append__leftD,axiom,
! [A: $tType,X: list @ A,U: list @ A,V2: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ X @ U ) @ ( append @ A @ X @ V2 ) ) @ ( lexord @ A @ R2 ) )
=> ( ! [A7: A] :
~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A7 @ A7 ) @ R2 )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ U @ V2 ) @ ( lexord @ A @ R2 ) ) ) ) ).
% lexord_append_leftD
thf(fact_6122_lexord__append__rightI,axiom,
! [A: $tType,Y: list @ A,X: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ? [B9: A,Z4: list @ A] :
( Y
= ( cons @ A @ B9 @ Z4 ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ ( append @ A @ X @ Y ) ) @ ( lexord @ A @ R2 ) ) ) ).
% lexord_append_rightI
thf(fact_6123_lexord__sufE,axiom,
! [A: $tType,Xs: list @ A,Zs: list @ A,Ys: list @ A,Qs: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ Xs @ Zs ) @ ( append @ A @ Ys @ Qs ) ) @ ( lexord @ A @ R2 ) )
=> ( ( Xs != Ys )
=> ( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ A ) @ Ys ) )
=> ( ( ( size_size @ ( list @ A ) @ Zs )
= ( size_size @ ( list @ A ) @ Qs ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( lexord @ A @ R2 ) ) ) ) ) ) ).
% lexord_sufE
thf(fact_6124_lex__append__left__iff,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ! [X5: A] :
~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ X5 ) @ R2 )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ Xs @ Ys ) @ ( append @ A @ Xs @ Zs ) ) @ ( lex @ A @ R2 ) )
= ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Ys @ Zs ) @ ( lex @ A @ R2 ) ) ) ) ).
% lex_append_left_iff
thf(fact_6125_lex__append__leftD,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ! [X5: A] :
~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ X5 ) @ R2 )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ Xs @ Ys ) @ ( append @ A @ Xs @ Zs ) ) @ ( lex @ A @ R2 ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Ys @ Zs ) @ ( lex @ A @ R2 ) ) ) ) ).
% lex_append_leftD
thf(fact_6126_rotate1_Osimps_I2_J,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( rotate1 @ A @ ( cons @ A @ X @ Xs ) )
= ( append @ A @ Xs @ ( cons @ A @ X @ ( nil @ A ) ) ) ) ).
% rotate1.simps(2)
thf(fact_6127_lex__append__rightI,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A ),Vs2: list @ A,Us: list @ A] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( lex @ A @ R2 ) )
=> ( ( ( size_size @ ( list @ A ) @ Vs2 )
= ( size_size @ ( list @ A ) @ Us ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ Xs @ Us ) @ ( append @ A @ Ys @ Vs2 ) ) @ ( lex @ A @ R2 ) ) ) ) ).
% lex_append_rightI
thf(fact_6128_lenlex__append1,axiom,
! [A: $tType,Us: list @ A,Xs: list @ A,R: set @ ( product_prod @ A @ A ),Vs2: list @ A,Ys: list @ A] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Us @ Xs ) @ ( lenlex @ A @ R ) )
=> ( ( ( size_size @ ( list @ A ) @ Vs2 )
= ( size_size @ ( list @ A ) @ Ys ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ Us @ Vs2 ) @ ( append @ A @ Xs @ Ys ) ) @ ( lenlex @ A @ R ) ) ) ) ).
% lenlex_append1
thf(fact_6129_nths__append,axiom,
! [A: $tType,L: list @ A,L3: list @ A,A4: set @ nat] :
( ( nths @ A @ ( append @ A @ L @ L3 ) @ A4 )
= ( append @ A @ ( nths @ A @ L @ A4 )
@ ( nths @ A @ L3
@ ( collect @ nat
@ ^ [J3: nat] : ( member2 @ nat @ ( plus_plus @ nat @ J3 @ ( size_size @ ( list @ A ) @ L ) ) @ A4 ) ) ) ) ) ).
% nths_append
thf(fact_6130_subseqs_Osimps_I1_J,axiom,
! [A: $tType] :
( ( subseqs @ A @ ( nil @ A ) )
= ( cons @ ( list @ A ) @ ( nil @ A ) @ ( nil @ ( list @ A ) ) ) ) ).
% subseqs.simps(1)
thf(fact_6131_product__lists_Osimps_I1_J,axiom,
! [A: $tType] :
( ( product_lists @ A @ ( nil @ ( list @ A ) ) )
= ( cons @ ( list @ A ) @ ( nil @ A ) @ ( nil @ ( list @ A ) ) ) ) ).
% product_lists.simps(1)
thf(fact_6132_length__append__singleton,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( size_size @ ( list @ A ) @ ( append @ A @ Xs @ ( cons @ A @ X @ ( nil @ A ) ) ) )
= ( suc @ ( size_size @ ( list @ A ) @ Xs ) ) ) ).
% length_append_singleton
thf(fact_6133_length__Suc__conv__rev,axiom,
! [A: $tType,Xs: list @ A,N2: nat] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( suc @ N2 ) )
= ( ? [Y2: A,Ys3: list @ A] :
( ( Xs
= ( append @ A @ Ys3 @ ( cons @ A @ Y2 @ ( nil @ A ) ) ) )
& ( ( size_size @ ( list @ A ) @ Ys3 )
= N2 ) ) ) ) ).
% length_Suc_conv_rev
thf(fact_6134_subseqs_Osimps_I2_J,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( subseqs @ A @ ( cons @ A @ X @ Xs ) )
= ( append @ ( list @ A ) @ ( map @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X ) @ ( subseqs @ A @ Xs ) ) @ ( subseqs @ A @ Xs ) ) ) ).
% subseqs.simps(2)
thf(fact_6135_nth__append,axiom,
! [A: $tType,N2: nat,Xs: list @ A,Ys: list @ A] :
( ( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ A @ ( append @ A @ Xs @ Ys ) @ N2 )
= ( nth @ A @ Xs @ N2 ) ) )
& ( ~ ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ A @ ( append @ A @ Xs @ Ys ) @ N2 )
= ( nth @ A @ Ys @ ( minus_minus @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) ) ) ) ) ) ).
% nth_append
thf(fact_6136_list__update__append,axiom,
! [A: $tType,N2: nat,Xs: list @ A,Ys: list @ A,X: A] :
( ( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( list_update @ A @ ( append @ A @ Xs @ Ys ) @ N2 @ X )
= ( append @ A @ ( list_update @ A @ Xs @ N2 @ X ) @ Ys ) ) )
& ( ~ ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( list_update @ A @ ( append @ A @ Xs @ Ys ) @ N2 @ X )
= ( append @ A @ Xs @ ( list_update @ A @ Ys @ ( minus_minus @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) ) @ X ) ) ) ) ) ).
% list_update_append
thf(fact_6137_listrel1I,axiom,
! [A: $tType,X: A,Y: A,R2: set @ ( product_prod @ A @ A ),Xs: list @ A,Us: list @ A,Vs2: list @ A,Ys: list @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
=> ( ( Xs
= ( append @ A @ Us @ ( cons @ A @ X @ Vs2 ) ) )
=> ( ( Ys
= ( append @ A @ Us @ ( cons @ A @ Y @ Vs2 ) ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel1 @ A @ R2 ) ) ) ) ) ).
% listrel1I
thf(fact_6138_listrel1E,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel1 @ A @ R2 ) )
=> ~ ! [X5: A,Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Y4 ) @ R2 )
=> ! [Us3: list @ A,Vs3: list @ A] :
( ( Xs
= ( append @ A @ Us3 @ ( cons @ A @ X5 @ Vs3 ) ) )
=> ( Ys
!= ( append @ A @ Us3 @ ( cons @ A @ Y4 @ Vs3 ) ) ) ) ) ) ).
% listrel1E
thf(fact_6139_lexord__append__left__rightI,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),U: list @ A,X: list @ A,Y: list @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ U @ ( cons @ A @ A3 @ X ) ) @ ( append @ A @ U @ ( cons @ A @ B2 @ Y ) ) ) @ ( lexord @ A @ R2 ) ) ) ).
% lexord_append_left_rightI
thf(fact_6140_lexord__same__pref__iff,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,Zs: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ Xs @ Ys ) @ ( append @ A @ Xs @ Zs ) ) @ ( lexord @ A @ R2 ) )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ X2 ) @ R2 ) )
| ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Ys @ Zs ) @ ( lexord @ A @ R2 ) ) ) ) ).
% lexord_same_pref_iff
thf(fact_6141_lexord__sufI,axiom,
! [A: $tType,U: list @ A,W2: list @ A,R2: set @ ( product_prod @ A @ A ),V2: list @ A,Z: list @ A] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ U @ W2 ) @ ( lexord @ A @ R2 ) )
=> ( ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ W2 ) @ ( size_size @ ( list @ A ) @ U ) )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ U @ V2 ) @ ( append @ A @ W2 @ Z ) ) @ ( lexord @ A @ R2 ) ) ) ) ).
% lexord_sufI
thf(fact_6142_product_Osimps_I2_J,axiom,
! [A: $tType,B: $tType,X: A,Xs: list @ A,Ys: list @ B] :
( ( product @ A @ B @ ( cons @ A @ X @ Xs ) @ Ys )
= ( append @ ( product_prod @ A @ B ) @ ( map @ B @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X ) @ Ys ) @ ( product @ A @ B @ Xs @ Ys ) ) ) ).
% product.simps(2)
thf(fact_6143_n__lists_Osimps_I1_J,axiom,
! [A: $tType,Xs: list @ A] :
( ( n_lists @ A @ ( zero_zero @ nat ) @ Xs )
= ( cons @ ( list @ A ) @ ( nil @ A ) @ ( nil @ ( list @ A ) ) ) ) ).
% n_lists.simps(1)
thf(fact_6144_sorted__list__of__set__greaterThanAtMost,axiom,
! [I: nat,J: nat] :
( ( ord_less_eq @ nat @ ( suc @ I ) @ J )
=> ( ( linord4507533701916653071of_set @ nat @ ( set_or3652927894154168847AtMost @ nat @ I @ J ) )
= ( cons @ nat @ ( suc @ I ) @ ( linord4507533701916653071of_set @ nat @ ( set_or3652927894154168847AtMost @ nat @ ( suc @ I ) @ J ) ) ) ) ) ).
% sorted_list_of_set_greaterThanAtMost
thf(fact_6145_sorted__list__of__set__greaterThanLessThan,axiom,
! [I: nat,J: nat] :
( ( ord_less @ nat @ ( suc @ I ) @ J )
=> ( ( linord4507533701916653071of_set @ nat @ ( set_or5935395276787703475ssThan @ nat @ I @ J ) )
= ( cons @ nat @ ( suc @ I ) @ ( linord4507533701916653071of_set @ nat @ ( set_or5935395276787703475ssThan @ nat @ ( suc @ I ) @ J ) ) ) ) ) ).
% sorted_list_of_set_greaterThanLessThan
thf(fact_6146_snoc__listrel1__snoc__iff,axiom,
! [A: $tType,Xs: list @ A,X: A,Ys: list @ A,Y: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ Xs @ ( cons @ A @ X @ ( nil @ A ) ) ) @ ( append @ A @ Ys @ ( cons @ A @ Y @ ( nil @ A ) ) ) ) @ ( listrel1 @ A @ R2 ) )
= ( ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( listrel1 @ A @ R2 ) )
& ( X = Y ) )
| ( ( Xs = Ys )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 ) ) ) ) ).
% snoc_listrel1_snoc_iff
thf(fact_6147_horner__sum__append,axiom,
! [A: $tType,B: $tType] :
( ( comm_semiring_1 @ A )
=> ! [F2: B > A,A3: A,Xs: list @ B,Ys: list @ B] :
( ( groups4207007520872428315er_sum @ B @ A @ F2 @ A3 @ ( append @ B @ Xs @ Ys ) )
= ( plus_plus @ A @ ( groups4207007520872428315er_sum @ B @ A @ F2 @ A3 @ Xs ) @ ( times_times @ A @ ( power_power @ A @ A3 @ ( size_size @ ( list @ B ) @ Xs ) ) @ ( groups4207007520872428315er_sum @ B @ A @ F2 @ A3 @ Ys ) ) ) ) ) ).
% horner_sum_append
thf(fact_6148_nths__Cons,axiom,
! [A: $tType,X: A,L: list @ A,A4: set @ nat] :
( ( nths @ A @ ( cons @ A @ X @ L ) @ A4 )
= ( append @ A @ ( if @ ( list @ A ) @ ( member2 @ nat @ ( zero_zero @ nat ) @ A4 ) @ ( cons @ A @ X @ ( nil @ A ) ) @ ( nil @ A ) )
@ ( nths @ A @ L
@ ( collect @ nat
@ ^ [J3: nat] : ( member2 @ nat @ ( suc @ J3 ) @ A4 ) ) ) ) ) ).
% nths_Cons
thf(fact_6149_set__Cons__def,axiom,
! [A: $tType] :
( ( set_Cons @ A )
= ( ^ [A6: set @ A,XS: set @ ( list @ A )] :
( collect @ ( list @ A )
@ ^ [Z6: list @ A] :
? [X2: A,Xs2: list @ A] :
( ( Z6
= ( cons @ A @ X2 @ Xs2 ) )
& ( member2 @ A @ X2 @ A6 )
& ( member2 @ ( list @ A ) @ Xs2 @ XS ) ) ) ) ) ).
% set_Cons_def
thf(fact_6150_comm__append__is__replicate,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( Ys
!= ( nil @ A ) )
=> ( ( ( append @ A @ Xs @ Ys )
= ( append @ A @ Ys @ Xs ) )
=> ? [N3: nat,Zs2: list @ A] :
( ( ord_less @ nat @ ( one_one @ nat ) @ N3 )
& ( ( concat @ A @ ( replicate @ ( list @ A ) @ N3 @ Zs2 ) )
= ( append @ A @ Xs @ Ys ) ) ) ) ) ) ).
% comm_append_is_replicate
thf(fact_6151_listrel1__def,axiom,
! [A: $tType] :
( ( listrel1 @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
( collect @ ( product_prod @ ( list @ A ) @ ( list @ A ) )
@ ( product_case_prod @ ( list @ A ) @ ( list @ A ) @ $o
@ ^ [Xs2: list @ A,Ys3: list @ A] :
? [Us2: list @ A,Z6: A,Z7: A,Vs: list @ A] :
( ( Xs2
= ( append @ A @ Us2 @ ( cons @ A @ Z6 @ Vs ) ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Z6 @ Z7 ) @ R4 )
& ( Ys3
= ( append @ A @ Us2 @ ( cons @ A @ Z7 @ Vs ) ) ) ) ) ) ) ) ).
% listrel1_def
thf(fact_6152_lexord__def,axiom,
! [A: $tType] :
( ( lexord @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
( collect @ ( product_prod @ ( list @ A ) @ ( list @ A ) )
@ ( product_case_prod @ ( list @ A ) @ ( list @ A ) @ $o
@ ^ [X2: list @ A,Y2: list @ A] :
? [A5: A,V5: list @ A] :
( ( Y2
= ( append @ A @ X2 @ ( cons @ A @ A5 @ V5 ) ) )
| ? [U2: list @ A,B4: A,C3: A,W3: list @ A,Z6: list @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B4 @ C3 ) @ R4 )
& ( X2
= ( append @ A @ U2 @ ( cons @ A @ B4 @ W3 ) ) )
& ( Y2
= ( append @ A @ U2 @ ( cons @ A @ C3 @ Z6 ) ) ) ) ) ) ) ) ) ).
% lexord_def
thf(fact_6153_lex__conv,axiom,
! [A: $tType] :
( ( lex @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
( collect @ ( product_prod @ ( list @ A ) @ ( list @ A ) )
@ ( product_case_prod @ ( list @ A ) @ ( list @ A ) @ $o
@ ^ [Xs2: list @ A,Ys3: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs2 )
= ( size_size @ ( list @ A ) @ Ys3 ) )
& ? [Xys2: list @ A,X2: A,Y2: A,Xs6: list @ A,Ys7: list @ A] :
( ( Xs2
= ( append @ A @ Xys2 @ ( cons @ A @ X2 @ Xs6 ) ) )
& ( Ys3
= ( append @ A @ Xys2 @ ( cons @ A @ Y2 @ Ys7 ) ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R4 ) ) ) ) ) ) ) ).
% lex_conv
thf(fact_6154_take__Suc__conv__app__nth,axiom,
! [A: $tType,I: nat,Xs: list @ A] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( take @ A @ ( suc @ I ) @ Xs )
= ( append @ A @ ( take @ A @ I @ Xs ) @ ( cons @ A @ ( nth @ A @ Xs @ I ) @ ( nil @ A ) ) ) ) ) ).
% take_Suc_conv_app_nth
thf(fact_6155_nth__repl,axiom,
! [A: $tType,M: nat,Xs: list @ A,N2: nat,X: A] :
( ( ord_less @ nat @ M @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( M != N2 )
=> ( ( nth @ A @ ( append @ A @ ( take @ A @ N2 @ Xs ) @ ( append @ A @ ( cons @ A @ X @ ( nil @ A ) ) @ ( drop @ A @ ( plus_plus @ nat @ N2 @ ( one_one @ nat ) ) @ Xs ) ) ) @ M )
= ( nth @ A @ Xs @ M ) ) ) ) ) ).
% nth_repl
thf(fact_6156_pos__n__replace,axiom,
! [A: $tType,N2: nat,Xs: list @ A,Y: A] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ A ) @ ( append @ A @ ( take @ A @ N2 @ Xs ) @ ( append @ A @ ( cons @ A @ Y @ ( nil @ A ) ) @ ( drop @ A @ ( suc @ N2 ) @ Xs ) ) ) ) ) ) ).
% pos_n_replace
thf(fact_6157_drop0,axiom,
! [A: $tType] :
( ( drop @ A @ ( zero_zero @ nat ) )
= ( ^ [X2: list @ A] : X2 ) ) ).
% drop0
thf(fact_6158_drop__drop,axiom,
! [A: $tType,N2: nat,M: nat,Xs: list @ A] :
( ( drop @ A @ N2 @ ( drop @ A @ M @ Xs ) )
= ( drop @ A @ ( plus_plus @ nat @ N2 @ M ) @ Xs ) ) ).
% drop_drop
thf(fact_6159_drop__Suc__Cons,axiom,
! [A: $tType,N2: nat,X: A,Xs: list @ A] :
( ( drop @ A @ ( suc @ N2 ) @ ( cons @ A @ X @ Xs ) )
= ( drop @ A @ N2 @ Xs ) ) ).
% drop_Suc_Cons
thf(fact_6160_length__drop,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( size_size @ ( list @ A ) @ ( drop @ A @ N2 @ Xs ) )
= ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 ) ) ).
% length_drop
thf(fact_6161_drop__update__cancel,axiom,
! [A: $tType,N2: nat,M: nat,Xs: list @ A,X: A] :
( ( ord_less @ nat @ N2 @ M )
=> ( ( drop @ A @ M @ ( list_update @ A @ Xs @ N2 @ X ) )
= ( drop @ A @ M @ Xs ) ) ) ).
% drop_update_cancel
thf(fact_6162_append__take__drop__id,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( append @ A @ ( take @ A @ N2 @ Xs ) @ ( drop @ A @ N2 @ Xs ) )
= Xs ) ).
% append_take_drop_id
thf(fact_6163_drop__replicate,axiom,
! [A: $tType,I: nat,K: nat,X: A] :
( ( drop @ A @ I @ ( replicate @ A @ K @ X ) )
= ( replicate @ A @ ( minus_minus @ nat @ K @ I ) @ X ) ) ).
% drop_replicate
thf(fact_6164_drop__all,axiom,
! [A: $tType,Xs: list @ A,N2: nat] :
( ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 )
=> ( ( drop @ A @ N2 @ Xs )
= ( nil @ A ) ) ) ).
% drop_all
thf(fact_6165_drop__eq__Nil,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ( drop @ A @ N2 @ Xs )
= ( nil @ A ) )
= ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 ) ) ).
% drop_eq_Nil
thf(fact_6166_drop__eq__Nil2,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ( nil @ A )
= ( drop @ A @ N2 @ Xs ) )
= ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 ) ) ).
% drop_eq_Nil2
thf(fact_6167_drop__append,axiom,
! [A: $tType,N2: nat,Xs: list @ A,Ys: list @ A] :
( ( drop @ A @ N2 @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ ( drop @ A @ N2 @ Xs ) @ ( drop @ A @ ( minus_minus @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) ) @ Ys ) ) ) ).
% drop_append
thf(fact_6168_drop__Cons__numeral,axiom,
! [A: $tType,V2: num,X: A,Xs: list @ A] :
( ( drop @ A @ ( numeral_numeral @ nat @ V2 ) @ ( cons @ A @ X @ Xs ) )
= ( drop @ A @ ( minus_minus @ nat @ ( numeral_numeral @ nat @ V2 ) @ ( one_one @ nat ) ) @ Xs ) ) ).
% drop_Cons_numeral
thf(fact_6169_nth__drop,axiom,
! [A: $tType,N2: nat,Xs: list @ A,I: nat] :
( ( ord_less_eq @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ A @ ( drop @ A @ N2 @ Xs ) @ I )
= ( nth @ A @ Xs @ ( plus_plus @ nat @ N2 @ I ) ) ) ) ).
% nth_drop
thf(fact_6170_drop__map,axiom,
! [A: $tType,B: $tType,N2: nat,F2: B > A,Xs: list @ B] :
( ( drop @ A @ N2 @ ( map @ B @ A @ F2 @ Xs ) )
= ( map @ B @ A @ F2 @ ( drop @ B @ N2 @ Xs ) ) ) ).
% drop_map
thf(fact_6171_nth__via__drop,axiom,
! [A: $tType,N2: nat,Xs: list @ A,Y: A,Ys: list @ A] :
( ( ( drop @ A @ N2 @ Xs )
= ( cons @ A @ Y @ Ys ) )
=> ( ( nth @ A @ Xs @ N2 )
= Y ) ) ).
% nth_via_drop
thf(fact_6172_distinct__drop,axiom,
! [A: $tType,Xs: list @ A,I: nat] :
( ( distinct @ A @ Xs )
=> ( distinct @ A @ ( drop @ A @ I @ Xs ) ) ) ).
% distinct_drop
thf(fact_6173_set__drop__subset,axiom,
! [A: $tType,N2: nat,Xs: list @ A] : ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ ( drop @ A @ N2 @ Xs ) ) @ ( set2 @ A @ Xs ) ) ).
% set_drop_subset
thf(fact_6174_in__set__dropD,axiom,
! [A: $tType,X: A,N2: nat,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ ( drop @ A @ N2 @ Xs ) ) )
=> ( member2 @ A @ X @ ( set2 @ A @ Xs ) ) ) ).
% in_set_dropD
thf(fact_6175_drop__Nil,axiom,
! [A: $tType,N2: nat] :
( ( drop @ A @ N2 @ ( nil @ A ) )
= ( nil @ A ) ) ).
% drop_Nil
thf(fact_6176_drop__0,axiom,
! [A: $tType,Xs: list @ A] :
( ( drop @ A @ ( zero_zero @ nat ) @ Xs )
= Xs ) ).
% drop_0
thf(fact_6177_drop__take,axiom,
! [A: $tType,N2: nat,M: nat,Xs: list @ A] :
( ( drop @ A @ N2 @ ( take @ A @ M @ Xs ) )
= ( take @ A @ ( minus_minus @ nat @ M @ N2 ) @ ( drop @ A @ N2 @ Xs ) ) ) ).
% drop_take
thf(fact_6178_take__drop,axiom,
! [A: $tType,N2: nat,M: nat,Xs: list @ A] :
( ( take @ A @ N2 @ ( drop @ A @ M @ Xs ) )
= ( drop @ A @ M @ ( take @ A @ ( plus_plus @ nat @ N2 @ M ) @ Xs ) ) ) ).
% take_drop
thf(fact_6179_drop__zip,axiom,
! [A: $tType,B: $tType,N2: nat,Xs: list @ A,Ys: list @ B] :
( ( drop @ ( product_prod @ A @ B ) @ N2 @ ( zip @ A @ B @ Xs @ Ys ) )
= ( zip @ A @ B @ ( drop @ A @ N2 @ Xs ) @ ( drop @ B @ N2 @ Ys ) ) ) ).
% drop_zip
thf(fact_6180_drop__eq__nths,axiom,
! [A: $tType] :
( ( drop @ A )
= ( ^ [N: nat,Xs2: list @ A] : ( nths @ A @ Xs2 @ ( collect @ nat @ ( ord_less_eq @ nat @ N ) ) ) ) ) ).
% drop_eq_nths
thf(fact_6181_set__drop__subset__set__drop,axiom,
! [A: $tType,N2: nat,M: nat,Xs: list @ A] :
( ( ord_less_eq @ nat @ N2 @ M )
=> ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ ( drop @ A @ M @ Xs ) ) @ ( set2 @ A @ ( drop @ A @ N2 @ Xs ) ) ) ) ).
% set_drop_subset_set_drop
thf(fact_6182_append__eq__conv__conj,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ( ( append @ A @ Xs @ Ys )
= Zs )
= ( ( Xs
= ( take @ A @ ( size_size @ ( list @ A ) @ Xs ) @ Zs ) )
& ( Ys
= ( drop @ A @ ( size_size @ ( list @ A ) @ Xs ) @ Zs ) ) ) ) ).
% append_eq_conv_conj
thf(fact_6183_take__add,axiom,
! [A: $tType,I: nat,J: nat,Xs: list @ A] :
( ( take @ A @ ( plus_plus @ nat @ I @ J ) @ Xs )
= ( append @ A @ ( take @ A @ I @ Xs ) @ ( take @ A @ J @ ( drop @ A @ I @ Xs ) ) ) ) ).
% take_add
thf(fact_6184_drop__update__swap,axiom,
! [A: $tType,M: nat,N2: nat,Xs: list @ A,X: A] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( drop @ A @ M @ ( list_update @ A @ Xs @ N2 @ X ) )
= ( list_update @ A @ ( drop @ A @ M @ Xs ) @ ( minus_minus @ nat @ N2 @ M ) @ X ) ) ) ).
% drop_update_swap
thf(fact_6185_drop__Cons,axiom,
! [A: $tType,N2: nat,X: A,Xs: list @ A] :
( ( drop @ A @ N2 @ ( cons @ A @ X @ Xs ) )
= ( case_nat @ ( list @ A ) @ ( cons @ A @ X @ Xs )
@ ^ [M2: nat] : ( drop @ A @ M2 @ Xs )
@ N2 ) ) ).
% drop_Cons
thf(fact_6186_nths__drop,axiom,
! [A: $tType,N2: nat,Xs: list @ A,I6: set @ nat] :
( ( nths @ A @ ( drop @ A @ N2 @ Xs ) @ I6 )
= ( nths @ A @ Xs @ ( image2 @ nat @ nat @ ( plus_plus @ nat @ N2 ) @ I6 ) ) ) ).
% nths_drop
thf(fact_6187_drop__Cons_H,axiom,
! [A: $tType,N2: nat,X: A,Xs: list @ A] :
( ( ( N2
= ( zero_zero @ nat ) )
=> ( ( drop @ A @ N2 @ ( cons @ A @ X @ Xs ) )
= ( cons @ A @ X @ Xs ) ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( drop @ A @ N2 @ ( cons @ A @ X @ Xs ) )
= ( drop @ A @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ Xs ) ) ) ) ).
% drop_Cons'
thf(fact_6188_append__eq__append__conv__if,axiom,
! [A: $tType,Xs_1: list @ A,Xs_2: list @ A,Ys_1: list @ A,Ys_2: list @ A] :
( ( ( append @ A @ Xs_1 @ Xs_2 )
= ( append @ A @ Ys_1 @ Ys_2 ) )
= ( ( ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs_1 ) @ ( size_size @ ( list @ A ) @ Ys_1 ) )
=> ( ( Xs_1
= ( take @ A @ ( size_size @ ( list @ A ) @ Xs_1 ) @ Ys_1 ) )
& ( Xs_2
= ( append @ A @ ( drop @ A @ ( size_size @ ( list @ A ) @ Xs_1 ) @ Ys_1 ) @ Ys_2 ) ) ) )
& ( ~ ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs_1 ) @ ( size_size @ ( list @ A ) @ Ys_1 ) )
=> ( ( ( take @ A @ ( size_size @ ( list @ A ) @ Ys_1 ) @ Xs_1 )
= Ys_1 )
& ( ( append @ A @ ( drop @ A @ ( size_size @ ( list @ A ) @ Ys_1 ) @ Xs_1 ) @ Xs_2 )
= Ys_2 ) ) ) ) ) ).
% append_eq_append_conv_if
thf(fact_6189_zip__append2,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,Zs: list @ B] :
( ( zip @ A @ B @ Xs @ ( append @ B @ Ys @ Zs ) )
= ( append @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ ( take @ A @ ( size_size @ ( list @ B ) @ Ys ) @ Xs ) @ Ys ) @ ( zip @ A @ B @ ( drop @ A @ ( size_size @ ( list @ B ) @ Ys ) @ Xs ) @ Zs ) ) ) ).
% zip_append2
thf(fact_6190_zip__append1,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ A,Zs: list @ B] :
( ( zip @ A @ B @ ( append @ A @ Xs @ Ys ) @ Zs )
= ( append @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ ( take @ B @ ( size_size @ ( list @ A ) @ Xs ) @ Zs ) ) @ ( zip @ A @ B @ Ys @ ( drop @ B @ ( size_size @ ( list @ A ) @ Xs ) @ Zs ) ) ) ) ).
% zip_append1
thf(fact_6191_Cons__nth__drop__Suc,axiom,
! [A: $tType,I: nat,Xs: list @ A] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( cons @ A @ ( nth @ A @ Xs @ I ) @ ( drop @ A @ ( suc @ I ) @ Xs ) )
= ( drop @ A @ I @ Xs ) ) ) ).
% Cons_nth_drop_Suc
thf(fact_6192_set__take__disj__set__drop__if__distinct,axiom,
! [A: $tType,Vs2: list @ A,I: nat,J: nat] :
( ( distinct @ A @ Vs2 )
=> ( ( ord_less_eq @ nat @ I @ J )
=> ( ( inf_inf @ ( set @ A ) @ ( set2 @ A @ ( take @ A @ I @ Vs2 ) ) @ ( set2 @ A @ ( drop @ A @ J @ Vs2 ) ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% set_take_disj_set_drop_if_distinct
thf(fact_6193_id__take__nth__drop,axiom,
! [A: $tType,I: nat,Xs: list @ A] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( Xs
= ( append @ A @ ( take @ A @ I @ Xs ) @ ( cons @ A @ ( nth @ A @ Xs @ I ) @ ( drop @ A @ ( suc @ I ) @ Xs ) ) ) ) ) ).
% id_take_nth_drop
thf(fact_6194_upd__conv__take__nth__drop,axiom,
! [A: $tType,I: nat,Xs: list @ A,A3: A] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( list_update @ A @ Xs @ I @ A3 )
= ( append @ A @ ( take @ A @ I @ Xs ) @ ( cons @ A @ A3 @ ( drop @ A @ ( suc @ I ) @ Xs ) ) ) ) ) ).
% upd_conv_take_nth_drop
thf(fact_6195_lexn__conv,axiom,
! [A: $tType] :
( ( lexn @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A ),N: nat] :
( collect @ ( product_prod @ ( list @ A ) @ ( list @ A ) )
@ ( product_case_prod @ ( list @ A ) @ ( list @ A ) @ $o
@ ^ [Xs2: list @ A,Ys3: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs2 )
= N )
& ( ( size_size @ ( list @ A ) @ Ys3 )
= N )
& ? [Xys2: list @ A,X2: A,Y2: A,Xs6: list @ A,Ys7: list @ A] :
( ( Xs2
= ( append @ A @ Xys2 @ ( cons @ A @ X2 @ Xs6 ) ) )
& ( Ys3
= ( append @ A @ Xys2 @ ( cons @ A @ Y2 @ Ys7 ) ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R4 ) ) ) ) ) ) ) ).
% lexn_conv
thf(fact_6196_list__encode_Oelims,axiom,
! [X: list @ nat,Y: nat] :
( ( ( nat_list_encode @ X )
= Y )
=> ( ( ( X
= ( nil @ nat ) )
=> ( Y
!= ( zero_zero @ nat ) ) )
=> ~ ! [X5: nat,Xs3: list @ nat] :
( ( X
= ( cons @ nat @ X5 @ Xs3 ) )
=> ( Y
!= ( suc @ ( nat_prod_encode @ ( product_Pair @ nat @ nat @ X5 @ ( nat_list_encode @ Xs3 ) ) ) ) ) ) ) ) ).
% list_encode.elims
thf(fact_6197_lexn_Osimps_I1_J,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( lexn @ A @ R2 @ ( zero_zero @ nat ) )
= ( bot_bot @ ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) ) ) ).
% lexn.simps(1)
thf(fact_6198_list__encode_Osimps_I1_J,axiom,
( ( nat_list_encode @ ( nil @ nat ) )
= ( zero_zero @ nat ) ) ).
% list_encode.simps(1)
thf(fact_6199_lexn__length,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,R2: set @ ( product_prod @ A @ A ),N2: nat] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( lexn @ A @ R2 @ N2 ) )
=> ( ( ( size_size @ ( list @ A ) @ Xs )
= N2 )
& ( ( size_size @ ( list @ A ) @ Ys )
= N2 ) ) ) ).
% lexn_length
thf(fact_6200_lex__def,axiom,
! [A: $tType] :
( ( lex @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] : ( complete_Sup_Sup @ ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) @ ( image2 @ nat @ ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) @ ( lexn @ A @ R4 ) @ ( top_top @ ( set @ nat ) ) ) ) ) ) ).
% lex_def
thf(fact_6201_list__encode_Osimps_I2_J,axiom,
! [X: nat,Xs: list @ nat] :
( ( nat_list_encode @ ( cons @ nat @ X @ Xs ) )
= ( suc @ ( nat_prod_encode @ ( product_Pair @ nat @ nat @ X @ ( nat_list_encode @ Xs ) ) ) ) ) ).
% list_encode.simps(2)
thf(fact_6202_upto__aux__rec,axiom,
( upto_aux
= ( ^ [I5: int,J3: int,Js: list @ int] : ( if @ ( list @ int ) @ ( ord_less @ int @ J3 @ I5 ) @ Js @ ( upto_aux @ I5 @ ( minus_minus @ int @ J3 @ ( one_one @ int ) ) @ ( cons @ int @ J3 @ Js ) ) ) ) ) ).
% upto_aux_rec
thf(fact_6203_list_Ocase__distrib,axiom,
! [B: $tType,C: $tType,A: $tType,H2: B > C,F1: B,F22: A > ( list @ A ) > B,List: list @ A] :
( ( H2 @ ( case_list @ B @ A @ F1 @ F22 @ List ) )
= ( case_list @ C @ A @ ( H2 @ F1 )
@ ^ [X16: A,X24: list @ A] : ( H2 @ ( F22 @ X16 @ X24 ) )
@ List ) ) ).
% list.case_distrib
thf(fact_6204_list_Osimps_I4_J,axiom,
! [A: $tType,B: $tType,F1: B,F22: A > ( list @ A ) > B] :
( ( case_list @ B @ A @ F1 @ F22 @ ( nil @ A ) )
= F1 ) ).
% list.simps(4)
thf(fact_6205_list_Osimps_I5_J,axiom,
! [B: $tType,A: $tType,F1: B,F22: A > ( list @ A ) > B,X21: A,X222: list @ A] :
( ( case_list @ B @ A @ F1 @ F22 @ ( cons @ A @ X21 @ X222 ) )
= ( F22 @ X21 @ X222 ) ) ).
% list.simps(5)
thf(fact_6206_remdups__adj__Cons,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( remdups_adj @ A @ ( cons @ A @ X @ Xs ) )
= ( case_list @ ( list @ A ) @ A @ ( cons @ A @ X @ ( nil @ A ) )
@ ^ [Y2: A,Xs2: list @ A] : ( if @ ( list @ A ) @ ( X = Y2 ) @ ( cons @ A @ Y2 @ Xs2 ) @ ( cons @ A @ X @ ( cons @ A @ Y2 @ Xs2 ) ) )
@ ( remdups_adj @ A @ Xs ) ) ) ).
% remdups_adj_Cons
thf(fact_6207_min__list_Osimps,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [X: A,Xs: list @ A] :
( ( min_list @ A @ ( cons @ A @ X @ Xs ) )
= ( case_list @ A @ A @ X
@ ^ [A5: A,List2: list @ A] : ( ord_min @ A @ X @ ( min_list @ A @ Xs ) )
@ Xs ) ) ) ).
% min_list.simps
thf(fact_6208_transpose_Osimps_I3_J,axiom,
! [A: $tType,X: A,Xs: list @ A,Xss: list @ ( list @ A )] :
( ( transpose @ A @ ( cons @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ Xss ) )
= ( cons @ ( list @ A )
@ ( cons @ A @ X
@ ( concat @ A
@ ( map @ ( list @ A ) @ ( list @ A )
@ ( case_list @ ( list @ A ) @ A @ ( nil @ A )
@ ^ [H: A,T3: list @ A] : ( cons @ A @ H @ ( nil @ A ) ) )
@ Xss ) ) )
@ ( transpose @ A
@ ( cons @ ( list @ A ) @ Xs
@ ( concat @ ( list @ A )
@ ( map @ ( list @ A ) @ ( list @ ( list @ A ) )
@ ( case_list @ ( list @ ( list @ A ) ) @ A @ ( nil @ ( list @ A ) )
@ ^ [H: A,T3: list @ A] : ( cons @ ( list @ A ) @ T3 @ ( nil @ ( list @ A ) ) ) )
@ Xss ) ) ) ) ) ) ).
% transpose.simps(3)
thf(fact_6209_transpose_Oelims,axiom,
! [A: $tType,X: list @ ( list @ A ),Y: list @ ( list @ A )] :
( ( ( transpose @ A @ X )
= Y )
=> ( ( ( X
= ( nil @ ( list @ A ) ) )
=> ( Y
!= ( nil @ ( list @ A ) ) ) )
=> ( ! [Xss2: list @ ( list @ A )] :
( ( X
= ( cons @ ( list @ A ) @ ( nil @ A ) @ Xss2 ) )
=> ( Y
!= ( transpose @ A @ Xss2 ) ) )
=> ~ ! [X5: A,Xs3: list @ A,Xss2: list @ ( list @ A )] :
( ( X
= ( cons @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ Xss2 ) )
=> ( Y
!= ( cons @ ( list @ A )
@ ( cons @ A @ X5
@ ( concat @ A
@ ( map @ ( list @ A ) @ ( list @ A )
@ ( case_list @ ( list @ A ) @ A @ ( nil @ A )
@ ^ [H: A,T3: list @ A] : ( cons @ A @ H @ ( nil @ A ) ) )
@ Xss2 ) ) )
@ ( transpose @ A
@ ( cons @ ( list @ A ) @ Xs3
@ ( concat @ ( list @ A )
@ ( map @ ( list @ A ) @ ( list @ ( list @ A ) )
@ ( case_list @ ( list @ ( list @ A ) ) @ A @ ( nil @ ( list @ A ) )
@ ^ [H: A,T3: list @ A] : ( cons @ ( list @ A ) @ T3 @ ( nil @ ( list @ A ) ) ) )
@ Xss2 ) ) ) ) ) ) ) ) ) ) ).
% transpose.elims
thf(fact_6210_list_Odisc__eq__case_I2_J,axiom,
! [A: $tType,List: list @ A] :
( ( List
!= ( nil @ A ) )
= ( case_list @ $o @ A @ $false
@ ^ [Uu3: A,Uv3: list @ A] : $true
@ List ) ) ).
% list.disc_eq_case(2)
thf(fact_6211_list_Odisc__eq__case_I1_J,axiom,
! [A: $tType,List: list @ A] :
( ( List
= ( nil @ A ) )
= ( case_list @ $o @ A @ $true
@ ^ [Uu3: A,Uv3: list @ A] : $false
@ List ) ) ).
% list.disc_eq_case(1)
thf(fact_6212_transpose_Osimps_I1_J,axiom,
! [A: $tType] :
( ( transpose @ A @ ( nil @ ( list @ A ) ) )
= ( nil @ ( list @ A ) ) ) ).
% transpose.simps(1)
thf(fact_6213_transpose_Osimps_I2_J,axiom,
! [A: $tType,Xss: list @ ( list @ A )] :
( ( transpose @ A @ ( cons @ ( list @ A ) @ ( nil @ A ) @ Xss ) )
= ( transpose @ A @ Xss ) ) ).
% transpose.simps(2)
thf(fact_6214_transpose__map__map,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ ( list @ B )] :
( ( transpose @ A @ ( map @ ( list @ B ) @ ( list @ A ) @ ( map @ B @ A @ F2 ) @ Xs ) )
= ( map @ ( list @ B ) @ ( list @ A ) @ ( map @ B @ A @ F2 ) @ ( transpose @ B @ Xs ) ) ) ).
% transpose_map_map
thf(fact_6215_transpose__empty,axiom,
! [A: $tType,Xs: list @ ( list @ A )] :
( ( ( transpose @ A @ Xs )
= ( nil @ ( list @ A ) ) )
= ( ! [X2: list @ A] :
( ( member2 @ ( list @ A ) @ X2 @ ( set2 @ ( list @ A ) @ Xs ) )
=> ( X2
= ( nil @ A ) ) ) ) ) ).
% transpose_empty
thf(fact_6216_zip__Cons,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Y: B,Ys: list @ B] :
( ( zip @ A @ B @ Xs @ ( cons @ B @ Y @ Ys ) )
= ( case_list @ ( list @ ( product_prod @ A @ B ) ) @ A @ ( nil @ ( product_prod @ A @ B ) )
@ ^ [Z6: A,Zs3: list @ A] : ( cons @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Z6 @ Y ) @ ( zip @ A @ B @ Zs3 @ Ys ) )
@ Xs ) ) ).
% zip_Cons
thf(fact_6217_zip__Cons1,axiom,
! [A: $tType,B: $tType,X: A,Xs: list @ A,Ys: list @ B] :
( ( zip @ A @ B @ ( cons @ A @ X @ Xs ) @ Ys )
= ( case_list @ ( list @ ( product_prod @ A @ B ) ) @ B @ ( nil @ ( product_prod @ A @ B ) )
@ ^ [Y2: B,Ys3: list @ B] : ( cons @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y2 ) @ ( zip @ A @ B @ Xs @ Ys3 ) )
@ Ys ) ) ).
% zip_Cons1
thf(fact_6218_upto_Opsimps,axiom,
! [I: int,J: int] :
( ( accp @ ( product_prod @ int @ int ) @ upto_rel @ ( product_Pair @ int @ int @ I @ J ) )
=> ( ( ( ord_less_eq @ int @ I @ J )
=> ( ( upto @ I @ J )
= ( cons @ int @ I @ ( upto @ ( plus_plus @ int @ I @ ( one_one @ int ) ) @ J ) ) ) )
& ( ~ ( ord_less_eq @ int @ I @ J )
=> ( ( upto @ I @ J )
= ( nil @ int ) ) ) ) ) ).
% upto.psimps
thf(fact_6219_upto_Opelims,axiom,
! [X: int,Xa2: int,Y: list @ int] :
( ( ( upto @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ int @ int ) @ upto_rel @ ( product_Pair @ int @ int @ X @ Xa2 ) )
=> ~ ( ( ( ( ord_less_eq @ int @ X @ Xa2 )
=> ( Y
= ( cons @ int @ X @ ( upto @ ( plus_plus @ int @ X @ ( one_one @ int ) ) @ Xa2 ) ) ) )
& ( ~ ( ord_less_eq @ int @ X @ Xa2 )
=> ( Y
= ( nil @ int ) ) ) )
=> ~ ( accp @ ( product_prod @ int @ int ) @ upto_rel @ ( product_Pair @ int @ int @ X @ Xa2 ) ) ) ) ) ).
% upto.pelims
thf(fact_6220_upto__Nil,axiom,
! [I: int,J: int] :
( ( ( upto @ I @ J )
= ( nil @ int ) )
= ( ord_less @ int @ J @ I ) ) ).
% upto_Nil
thf(fact_6221_upto__Nil2,axiom,
! [I: int,J: int] :
( ( ( nil @ int )
= ( upto @ I @ J ) )
= ( ord_less @ int @ J @ I ) ) ).
% upto_Nil2
thf(fact_6222_upto__empty,axiom,
! [J: int,I: int] :
( ( ord_less @ int @ J @ I )
=> ( ( upto @ I @ J )
= ( nil @ int ) ) ) ).
% upto_empty
thf(fact_6223_upto__single,axiom,
! [I: int] :
( ( upto @ I @ I )
= ( cons @ int @ I @ ( nil @ int ) ) ) ).
% upto_single
thf(fact_6224_nth__upto,axiom,
! [I: int,K: nat,J: int] :
( ( ord_less_eq @ int @ ( plus_plus @ int @ I @ ( semiring_1_of_nat @ int @ K ) ) @ J )
=> ( ( nth @ int @ ( upto @ I @ J ) @ K )
= ( plus_plus @ int @ I @ ( semiring_1_of_nat @ int @ K ) ) ) ) ).
% nth_upto
thf(fact_6225_length__upto,axiom,
! [I: int,J: int] :
( ( size_size @ ( list @ int ) @ ( upto @ I @ J ) )
= ( nat2 @ ( plus_plus @ int @ ( minus_minus @ int @ J @ I ) @ ( one_one @ int ) ) ) ) ).
% length_upto
thf(fact_6226_upto__rec__numeral_I1_J,axiom,
! [M: num,N2: num] :
( ( ( ord_less_eq @ int @ ( numeral_numeral @ int @ M ) @ ( numeral_numeral @ int @ N2 ) )
=> ( ( upto @ ( numeral_numeral @ int @ M ) @ ( numeral_numeral @ int @ N2 ) )
= ( cons @ int @ ( numeral_numeral @ int @ M ) @ ( upto @ ( plus_plus @ int @ ( numeral_numeral @ int @ M ) @ ( one_one @ int ) ) @ ( numeral_numeral @ int @ N2 ) ) ) ) )
& ( ~ ( ord_less_eq @ int @ ( numeral_numeral @ int @ M ) @ ( numeral_numeral @ int @ N2 ) )
=> ( ( upto @ ( numeral_numeral @ int @ M ) @ ( numeral_numeral @ int @ N2 ) )
= ( nil @ int ) ) ) ) ).
% upto_rec_numeral(1)
thf(fact_6227_upto__rec__numeral_I4_J,axiom,
! [M: num,N2: num] :
( ( ( ord_less_eq @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ N2 ) ) )
=> ( ( upto @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ N2 ) ) )
= ( cons @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( upto @ ( plus_plus @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( one_one @ int ) ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ N2 ) ) ) ) ) )
& ( ~ ( ord_less_eq @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ N2 ) ) )
=> ( ( upto @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ N2 ) ) )
= ( nil @ int ) ) ) ) ).
% upto_rec_numeral(4)
thf(fact_6228_upto__rec__numeral_I3_J,axiom,
! [M: num,N2: num] :
( ( ( ord_less_eq @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( numeral_numeral @ int @ N2 ) )
=> ( ( upto @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( numeral_numeral @ int @ N2 ) )
= ( cons @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( upto @ ( plus_plus @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( one_one @ int ) ) @ ( numeral_numeral @ int @ N2 ) ) ) ) )
& ( ~ ( ord_less_eq @ int @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( numeral_numeral @ int @ N2 ) )
=> ( ( upto @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ M ) ) @ ( numeral_numeral @ int @ N2 ) )
= ( nil @ int ) ) ) ) ).
% upto_rec_numeral(3)
thf(fact_6229_upto__rec__numeral_I2_J,axiom,
! [M: num,N2: num] :
( ( ( ord_less_eq @ int @ ( numeral_numeral @ int @ M ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ N2 ) ) )
=> ( ( upto @ ( numeral_numeral @ int @ M ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ N2 ) ) )
= ( cons @ int @ ( numeral_numeral @ int @ M ) @ ( upto @ ( plus_plus @ int @ ( numeral_numeral @ int @ M ) @ ( one_one @ int ) ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ N2 ) ) ) ) ) )
& ( ~ ( ord_less_eq @ int @ ( numeral_numeral @ int @ M ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ N2 ) ) )
=> ( ( upto @ ( numeral_numeral @ int @ M ) @ ( uminus_uminus @ int @ ( numeral_numeral @ int @ N2 ) ) )
= ( nil @ int ) ) ) ) ).
% upto_rec_numeral(2)
thf(fact_6230_distinct__upto,axiom,
! [I: int,J: int] : ( distinct @ int @ ( upto @ I @ J ) ) ).
% distinct_upto
thf(fact_6231_atLeastAtMost__upto,axiom,
( ( set_or1337092689740270186AtMost @ int )
= ( ^ [I5: int,J3: int] : ( set2 @ int @ ( upto @ I5 @ J3 ) ) ) ) ).
% atLeastAtMost_upto
thf(fact_6232_atLeastLessThan__upto,axiom,
( ( set_or7035219750837199246ssThan @ int )
= ( ^ [I5: int,J3: int] : ( set2 @ int @ ( upto @ I5 @ ( minus_minus @ int @ J3 @ ( one_one @ int ) ) ) ) ) ) ).
% atLeastLessThan_upto
thf(fact_6233_greaterThanAtMost__upto,axiom,
( ( set_or3652927894154168847AtMost @ int )
= ( ^ [I5: int,J3: int] : ( set2 @ int @ ( upto @ ( plus_plus @ int @ I5 @ ( one_one @ int ) ) @ J3 ) ) ) ) ).
% greaterThanAtMost_upto
thf(fact_6234_upto__aux__def,axiom,
( upto_aux
= ( ^ [I5: int,J3: int] : ( append @ int @ ( upto @ I5 @ J3 ) ) ) ) ).
% upto_aux_def
thf(fact_6235_upto__code,axiom,
( upto
= ( ^ [I5: int,J3: int] : ( upto_aux @ I5 @ J3 @ ( nil @ int ) ) ) ) ).
% upto_code
thf(fact_6236_upto__split2,axiom,
! [I: int,J: int,K: int] :
( ( ord_less_eq @ int @ I @ J )
=> ( ( ord_less_eq @ int @ J @ K )
=> ( ( upto @ I @ K )
= ( append @ int @ ( upto @ I @ J ) @ ( upto @ ( plus_plus @ int @ J @ ( one_one @ int ) ) @ K ) ) ) ) ) ).
% upto_split2
thf(fact_6237_upto__split1,axiom,
! [I: int,J: int,K: int] :
( ( ord_less_eq @ int @ I @ J )
=> ( ( ord_less_eq @ int @ J @ K )
=> ( ( upto @ I @ K )
= ( append @ int @ ( upto @ I @ ( minus_minus @ int @ J @ ( one_one @ int ) ) ) @ ( upto @ J @ K ) ) ) ) ) ).
% upto_split1
thf(fact_6238_greaterThanLessThan__upto,axiom,
( ( set_or5935395276787703475ssThan @ int )
= ( ^ [I5: int,J3: int] : ( set2 @ int @ ( upto @ ( plus_plus @ int @ I5 @ ( one_one @ int ) ) @ ( minus_minus @ int @ J3 @ ( one_one @ int ) ) ) ) ) ) ).
% greaterThanLessThan_upto
thf(fact_6239_upto_Oelims,axiom,
! [X: int,Xa2: int,Y: list @ int] :
( ( ( upto @ X @ Xa2 )
= Y )
=> ( ( ( ord_less_eq @ int @ X @ Xa2 )
=> ( Y
= ( cons @ int @ X @ ( upto @ ( plus_plus @ int @ X @ ( one_one @ int ) ) @ Xa2 ) ) ) )
& ( ~ ( ord_less_eq @ int @ X @ Xa2 )
=> ( Y
= ( nil @ int ) ) ) ) ) ).
% upto.elims
thf(fact_6240_upto_Osimps,axiom,
( upto
= ( ^ [I5: int,J3: int] : ( if @ ( list @ int ) @ ( ord_less_eq @ int @ I5 @ J3 ) @ ( cons @ int @ I5 @ ( upto @ ( plus_plus @ int @ I5 @ ( one_one @ int ) ) @ J3 ) ) @ ( nil @ int ) ) ) ) ).
% upto.simps
thf(fact_6241_upto__rec1,axiom,
! [I: int,J: int] :
( ( ord_less_eq @ int @ I @ J )
=> ( ( upto @ I @ J )
= ( cons @ int @ I @ ( upto @ ( plus_plus @ int @ I @ ( one_one @ int ) ) @ J ) ) ) ) ).
% upto_rec1
thf(fact_6242_upto__rec2,axiom,
! [I: int,J: int] :
( ( ord_less_eq @ int @ I @ J )
=> ( ( upto @ I @ J )
= ( append @ int @ ( upto @ I @ ( minus_minus @ int @ J @ ( one_one @ int ) ) ) @ ( cons @ int @ J @ ( nil @ int ) ) ) ) ) ).
% upto_rec2
thf(fact_6243_upto__split3,axiom,
! [I: int,J: int,K: int] :
( ( ord_less_eq @ int @ I @ J )
=> ( ( ord_less_eq @ int @ J @ K )
=> ( ( upto @ I @ K )
= ( append @ int @ ( upto @ I @ ( minus_minus @ int @ J @ ( one_one @ int ) ) ) @ ( cons @ int @ J @ ( upto @ ( plus_plus @ int @ J @ ( one_one @ int ) ) @ K ) ) ) ) ) ) ).
% upto_split3
thf(fact_6244_transpose_Opsimps_I3_J,axiom,
! [A: $tType,X: A,Xs: list @ A,Xss: list @ ( list @ A )] :
( ( accp @ ( list @ ( list @ A ) ) @ ( transpose_rel @ A ) @ ( cons @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ Xss ) )
=> ( ( transpose @ A @ ( cons @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ Xss ) )
= ( cons @ ( list @ A )
@ ( cons @ A @ X
@ ( concat @ A
@ ( map @ ( list @ A ) @ ( list @ A )
@ ( case_list @ ( list @ A ) @ A @ ( nil @ A )
@ ^ [H: A,T3: list @ A] : ( cons @ A @ H @ ( nil @ A ) ) )
@ Xss ) ) )
@ ( transpose @ A
@ ( cons @ ( list @ A ) @ Xs
@ ( concat @ ( list @ A )
@ ( map @ ( list @ A ) @ ( list @ ( list @ A ) )
@ ( case_list @ ( list @ ( list @ A ) ) @ A @ ( nil @ ( list @ A ) )
@ ^ [H: A,T3: list @ A] : ( cons @ ( list @ A ) @ T3 @ ( nil @ ( list @ A ) ) ) )
@ Xss ) ) ) ) ) ) ) ).
% transpose.psimps(3)
thf(fact_6245_transpose_Opelims,axiom,
! [A: $tType,X: list @ ( list @ A ),Y: list @ ( list @ A )] :
( ( ( transpose @ A @ X )
= Y )
=> ( ( accp @ ( list @ ( list @ A ) ) @ ( transpose_rel @ A ) @ X )
=> ( ( ( X
= ( nil @ ( list @ A ) ) )
=> ( ( Y
= ( nil @ ( list @ A ) ) )
=> ~ ( accp @ ( list @ ( list @ A ) ) @ ( transpose_rel @ A ) @ ( nil @ ( list @ A ) ) ) ) )
=> ( ! [Xss2: list @ ( list @ A )] :
( ( X
= ( cons @ ( list @ A ) @ ( nil @ A ) @ Xss2 ) )
=> ( ( Y
= ( transpose @ A @ Xss2 ) )
=> ~ ( accp @ ( list @ ( list @ A ) ) @ ( transpose_rel @ A ) @ ( cons @ ( list @ A ) @ ( nil @ A ) @ Xss2 ) ) ) )
=> ~ ! [X5: A,Xs3: list @ A,Xss2: list @ ( list @ A )] :
( ( X
= ( cons @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ Xss2 ) )
=> ( ( Y
= ( cons @ ( list @ A )
@ ( cons @ A @ X5
@ ( concat @ A
@ ( map @ ( list @ A ) @ ( list @ A )
@ ( case_list @ ( list @ A ) @ A @ ( nil @ A )
@ ^ [H: A,T3: list @ A] : ( cons @ A @ H @ ( nil @ A ) ) )
@ Xss2 ) ) )
@ ( transpose @ A
@ ( cons @ ( list @ A ) @ Xs3
@ ( concat @ ( list @ A )
@ ( map @ ( list @ A ) @ ( list @ ( list @ A ) )
@ ( case_list @ ( list @ ( list @ A ) ) @ A @ ( nil @ ( list @ A ) )
@ ^ [H: A,T3: list @ A] : ( cons @ ( list @ A ) @ T3 @ ( nil @ ( list @ A ) ) ) )
@ Xss2 ) ) ) ) ) )
=> ~ ( accp @ ( list @ ( list @ A ) ) @ ( transpose_rel @ A ) @ ( cons @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ Xss2 ) ) ) ) ) ) ) ) ).
% transpose.pelims
thf(fact_6246_transpose_Opsimps_I2_J,axiom,
! [A: $tType,Xss: list @ ( list @ A )] :
( ( accp @ ( list @ ( list @ A ) ) @ ( transpose_rel @ A ) @ ( cons @ ( list @ A ) @ ( nil @ A ) @ Xss ) )
=> ( ( transpose @ A @ ( cons @ ( list @ A ) @ ( nil @ A ) @ Xss ) )
= ( transpose @ A @ Xss ) ) ) ).
% transpose.psimps(2)
thf(fact_6247_transpose_Opsimps_I1_J,axiom,
! [A: $tType] :
( ( accp @ ( list @ ( list @ A ) ) @ ( transpose_rel @ A ) @ ( nil @ ( list @ A ) ) )
=> ( ( transpose @ A @ ( nil @ ( list @ A ) ) )
= ( nil @ ( list @ A ) ) ) ) ).
% transpose.psimps(1)
thf(fact_6248_transpose_Opinduct,axiom,
! [A: $tType,A0: list @ ( list @ A ),P2: ( list @ ( list @ A ) ) > $o] :
( ( accp @ ( list @ ( list @ A ) ) @ ( transpose_rel @ A ) @ A0 )
=> ( ( ( accp @ ( list @ ( list @ A ) ) @ ( transpose_rel @ A ) @ ( nil @ ( list @ A ) ) )
=> ( P2 @ ( nil @ ( list @ A ) ) ) )
=> ( ! [Xss2: list @ ( list @ A )] :
( ( accp @ ( list @ ( list @ A ) ) @ ( transpose_rel @ A ) @ ( cons @ ( list @ A ) @ ( nil @ A ) @ Xss2 ) )
=> ( ( P2 @ Xss2 )
=> ( P2 @ ( cons @ ( list @ A ) @ ( nil @ A ) @ Xss2 ) ) ) )
=> ( ! [X5: A,Xs3: list @ A,Xss2: list @ ( list @ A )] :
( ( accp @ ( list @ ( list @ A ) ) @ ( transpose_rel @ A ) @ ( cons @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ Xss2 ) )
=> ( ( P2
@ ( cons @ ( list @ A ) @ Xs3
@ ( concat @ ( list @ A )
@ ( map @ ( list @ A ) @ ( list @ ( list @ A ) )
@ ( case_list @ ( list @ ( list @ A ) ) @ A @ ( nil @ ( list @ A ) )
@ ^ [H: A,T3: list @ A] : ( cons @ ( list @ A ) @ T3 @ ( nil @ ( list @ A ) ) ) )
@ Xss2 ) ) ) )
=> ( P2 @ ( cons @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ Xss2 ) ) ) )
=> ( P2 @ A0 ) ) ) ) ) ).
% transpose.pinduct
thf(fact_6249_remdups__adj_Opelims,axiom,
! [A: $tType,X: list @ A,Y: list @ A] :
( ( ( remdups_adj @ A @ X )
= Y )
=> ( ( accp @ ( list @ A ) @ ( remdups_adj_rel @ A ) @ X )
=> ( ( ( X
= ( nil @ A ) )
=> ( ( Y
= ( nil @ A ) )
=> ~ ( accp @ ( list @ A ) @ ( remdups_adj_rel @ A ) @ ( nil @ A ) ) ) )
=> ( ! [X5: A] :
( ( X
= ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ( ( Y
= ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ~ ( accp @ ( list @ A ) @ ( remdups_adj_rel @ A ) @ ( cons @ A @ X5 @ ( nil @ A ) ) ) ) )
=> ~ ! [X5: A,Y4: A,Xs3: list @ A] :
( ( X
= ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) )
=> ( ( ( ( X5 = Y4 )
=> ( Y
= ( remdups_adj @ A @ ( cons @ A @ X5 @ Xs3 ) ) ) )
& ( ( X5 != Y4 )
=> ( Y
= ( cons @ A @ X5 @ ( remdups_adj @ A @ ( cons @ A @ Y4 @ Xs3 ) ) ) ) ) )
=> ~ ( accp @ ( list @ A ) @ ( remdups_adj_rel @ A ) @ ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) ) ) ) ) ) ) ) ).
% remdups_adj.pelims
thf(fact_6250_take__hd__drop,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( append @ A @ ( take @ A @ N2 @ Xs ) @ ( cons @ A @ ( hd @ A @ ( drop @ A @ N2 @ Xs ) ) @ ( nil @ A ) ) )
= ( take @ A @ ( suc @ N2 ) @ Xs ) ) ) ).
% take_hd_drop
thf(fact_6251_hd__remdups__adj,axiom,
! [A: $tType,Xs: list @ A] :
( ( hd @ A @ ( remdups_adj @ A @ Xs ) )
= ( hd @ A @ Xs ) ) ).
% hd_remdups_adj
thf(fact_6252_hd__append2,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( hd @ A @ ( append @ A @ Xs @ Ys ) )
= ( hd @ A @ Xs ) ) ) ).
% hd_append2
thf(fact_6253_hd__replicate,axiom,
! [A: $tType,N2: nat,X: A] :
( ( N2
!= ( zero_zero @ nat ) )
=> ( ( hd @ A @ ( replicate @ A @ N2 @ X ) )
= X ) ) ).
% hd_replicate
thf(fact_6254_hd__take,axiom,
! [A: $tType,J: nat,Xs: list @ A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ J )
=> ( ( hd @ A @ ( take @ A @ J @ Xs ) )
= ( hd @ A @ Xs ) ) ) ).
% hd_take
thf(fact_6255_hd__in__set,axiom,
! [A: $tType,Xs: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( member2 @ A @ ( hd @ A @ Xs ) @ ( set2 @ A @ Xs ) ) ) ).
% hd_in_set
thf(fact_6256_list_Oset__sel_I1_J,axiom,
! [A: $tType,A3: list @ A] :
( ( A3
!= ( nil @ A ) )
=> ( member2 @ A @ ( hd @ A @ A3 ) @ ( set2 @ A @ A3 ) ) ) ).
% list.set_sel(1)
thf(fact_6257_hd__append,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( Xs
= ( nil @ A ) )
=> ( ( hd @ A @ ( append @ A @ Xs @ Ys ) )
= ( hd @ A @ Ys ) ) )
& ( ( Xs
!= ( nil @ A ) )
=> ( ( hd @ A @ ( append @ A @ Xs @ Ys ) )
= ( hd @ A @ Xs ) ) ) ) ).
% hd_append
thf(fact_6258_longest__common__prefix,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
? [Ps2: list @ A,Xs4: list @ A,Ys5: list @ A] :
( ( Xs
= ( append @ A @ Ps2 @ Xs4 ) )
& ( Ys
= ( append @ A @ Ps2 @ Ys5 ) )
& ( ( Xs4
= ( nil @ A ) )
| ( Ys5
= ( nil @ A ) )
| ( ( hd @ A @ Xs4 )
!= ( hd @ A @ Ys5 ) ) ) ) ).
% longest_common_prefix
thf(fact_6259_list_Osel_I1_J,axiom,
! [A: $tType,X21: A,X222: list @ A] :
( ( hd @ A @ ( cons @ A @ X21 @ X222 ) )
= X21 ) ).
% list.sel(1)
thf(fact_6260_hd__map,axiom,
! [B: $tType,A: $tType,Xs: list @ A,F2: A > B] :
( ( Xs
!= ( nil @ A ) )
=> ( ( hd @ B @ ( map @ A @ B @ F2 @ Xs ) )
= ( F2 @ ( hd @ A @ Xs ) ) ) ) ).
% hd_map
thf(fact_6261_list_Omap__sel_I1_J,axiom,
! [B: $tType,A: $tType,A3: list @ A,F2: A > B] :
( ( A3
!= ( nil @ A ) )
=> ( ( hd @ B @ ( map @ A @ B @ F2 @ A3 ) )
= ( F2 @ ( hd @ A @ A3 ) ) ) ) ).
% list.map_sel(1)
thf(fact_6262_hd__zip,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B] :
( ( Xs
!= ( nil @ A ) )
=> ( ( Ys
!= ( nil @ B ) )
=> ( ( hd @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) )
= ( product_Pair @ A @ B @ ( hd @ A @ Xs ) @ ( hd @ B @ Ys ) ) ) ) ) ).
% hd_zip
thf(fact_6263_hd__concat,axiom,
! [A: $tType,Xs: list @ ( list @ A )] :
( ( Xs
!= ( nil @ ( list @ A ) ) )
=> ( ( ( hd @ ( list @ A ) @ Xs )
!= ( nil @ A ) )
=> ( ( hd @ A @ ( concat @ A @ Xs ) )
= ( hd @ A @ ( hd @ ( list @ A ) @ Xs ) ) ) ) ) ).
% hd_concat
thf(fact_6264_hd__conv__nth,axiom,
! [A: $tType,Xs: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( hd @ A @ Xs )
= ( nth @ A @ Xs @ ( zero_zero @ nat ) ) ) ) ).
% hd_conv_nth
thf(fact_6265_hd__drop__conv__nth,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( hd @ A @ ( drop @ A @ N2 @ Xs ) )
= ( nth @ A @ Xs @ N2 ) ) ) ).
% hd_drop_conv_nth
thf(fact_6266_remdups__adj__singleton__iff,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( size_size @ ( list @ A ) @ ( remdups_adj @ A @ Xs ) )
= ( suc @ ( zero_zero @ nat ) ) )
= ( ( Xs
!= ( nil @ A ) )
& ( Xs
= ( replicate @ A @ ( size_size @ ( list @ A ) @ Xs ) @ ( hd @ A @ Xs ) ) ) ) ) ).
% remdups_adj_singleton_iff
thf(fact_6267_list__encode_Opelims,axiom,
! [X: list @ nat,Y: nat] :
( ( ( nat_list_encode @ X )
= Y )
=> ( ( accp @ ( list @ nat ) @ nat_list_encode_rel @ X )
=> ( ( ( X
= ( nil @ nat ) )
=> ( ( Y
= ( zero_zero @ nat ) )
=> ~ ( accp @ ( list @ nat ) @ nat_list_encode_rel @ ( nil @ nat ) ) ) )
=> ~ ! [X5: nat,Xs3: list @ nat] :
( ( X
= ( cons @ nat @ X5 @ Xs3 ) )
=> ( ( Y
= ( suc @ ( nat_prod_encode @ ( product_Pair @ nat @ nat @ X5 @ ( nat_list_encode @ Xs3 ) ) ) ) )
=> ~ ( accp @ ( list @ nat ) @ nat_list_encode_rel @ ( cons @ nat @ X5 @ Xs3 ) ) ) ) ) ) ) ).
% list_encode.pelims
thf(fact_6268_horner__sum__bit__eq__take__bit,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [A3: A,N2: nat] :
( ( groups4207007520872428315er_sum @ $o @ A @ ( zero_neq_one_of_bool @ A ) @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( map @ nat @ $o @ ( bit_se5641148757651400278ts_bit @ A @ A3 ) @ ( upt @ ( zero_zero @ nat ) @ N2 ) ) )
= ( bit_se2584673776208193580ke_bit @ A @ N2 @ A3 ) ) ) ).
% horner_sum_bit_eq_take_bit
thf(fact_6269_remdups__upt,axiom,
! [M: nat,N2: nat] :
( ( remdups @ nat @ ( upt @ M @ N2 ) )
= ( upt @ M @ N2 ) ) ).
% remdups_upt
thf(fact_6270_hd__upt,axiom,
! [I: nat,J: nat] :
( ( ord_less @ nat @ I @ J )
=> ( ( hd @ nat @ ( upt @ I @ J ) )
= I ) ) ).
% hd_upt
thf(fact_6271_drop__upt,axiom,
! [M: nat,I: nat,J: nat] :
( ( drop @ nat @ M @ ( upt @ I @ J ) )
= ( upt @ ( plus_plus @ nat @ I @ M ) @ J ) ) ).
% drop_upt
thf(fact_6272_length__upt,axiom,
! [I: nat,J: nat] :
( ( size_size @ ( list @ nat ) @ ( upt @ I @ J ) )
= ( minus_minus @ nat @ J @ I ) ) ).
% length_upt
thf(fact_6273_take__upt,axiom,
! [I: nat,M: nat,N2: nat] :
( ( ord_less_eq @ nat @ ( plus_plus @ nat @ I @ M ) @ N2 )
=> ( ( take @ nat @ M @ ( upt @ I @ N2 ) )
= ( upt @ I @ ( plus_plus @ nat @ I @ M ) ) ) ) ).
% take_upt
thf(fact_6274_upt__conv__Nil,axiom,
! [J: nat,I: nat] :
( ( ord_less_eq @ nat @ J @ I )
=> ( ( upt @ I @ J )
= ( nil @ nat ) ) ) ).
% upt_conv_Nil
thf(fact_6275_sorted__list__of__set__range,axiom,
! [M: nat,N2: nat] :
( ( linord4507533701916653071of_set @ nat @ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) )
= ( upt @ M @ N2 ) ) ).
% sorted_list_of_set_range
thf(fact_6276_upt__eq__Nil__conv,axiom,
! [I: nat,J: nat] :
( ( ( upt @ I @ J )
= ( nil @ nat ) )
= ( ( J
= ( zero_zero @ nat ) )
| ( ord_less_eq @ nat @ J @ I ) ) ) ).
% upt_eq_Nil_conv
thf(fact_6277_nth__upt,axiom,
! [I: nat,K: nat,J: nat] :
( ( ord_less @ nat @ ( plus_plus @ nat @ I @ K ) @ J )
=> ( ( nth @ nat @ ( upt @ I @ J ) @ K )
= ( plus_plus @ nat @ I @ K ) ) ) ).
% nth_upt
thf(fact_6278_map__fst__enumerate,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( map @ ( product_prod @ nat @ A ) @ nat @ ( product_fst @ nat @ A ) @ ( enumerate @ A @ N2 @ Xs ) )
= ( upt @ N2 @ ( plus_plus @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) ) ) ) ).
% map_fst_enumerate
thf(fact_6279_upt__rec__numeral,axiom,
! [M: num,N2: num] :
( ( ( ord_less @ nat @ ( numeral_numeral @ nat @ M ) @ ( numeral_numeral @ nat @ N2 ) )
=> ( ( upt @ ( numeral_numeral @ nat @ M ) @ ( numeral_numeral @ nat @ N2 ) )
= ( cons @ nat @ ( numeral_numeral @ nat @ M ) @ ( upt @ ( suc @ ( numeral_numeral @ nat @ M ) ) @ ( numeral_numeral @ nat @ N2 ) ) ) ) )
& ( ~ ( ord_less @ nat @ ( numeral_numeral @ nat @ M ) @ ( numeral_numeral @ nat @ N2 ) )
=> ( ( upt @ ( numeral_numeral @ nat @ M ) @ ( numeral_numeral @ nat @ N2 ) )
= ( nil @ nat ) ) ) ) ).
% upt_rec_numeral
thf(fact_6280_map__add__upt,axiom,
! [N2: nat,M: nat] :
( ( map @ nat @ nat
@ ^ [I5: nat] : ( plus_plus @ nat @ I5 @ N2 )
@ ( upt @ ( zero_zero @ nat ) @ M ) )
= ( upt @ N2 @ ( plus_plus @ nat @ M @ N2 ) ) ) ).
% map_add_upt
thf(fact_6281_upt__0,axiom,
! [I: nat] :
( ( upt @ I @ ( zero_zero @ nat ) )
= ( nil @ nat ) ) ).
% upt_0
thf(fact_6282_upt__conv__Cons__Cons,axiom,
! [M: nat,N2: nat,Ns: list @ nat,Q2: nat] :
( ( ( cons @ nat @ M @ ( cons @ nat @ N2 @ Ns ) )
= ( upt @ M @ Q2 ) )
= ( ( cons @ nat @ N2 @ Ns )
= ( upt @ ( suc @ M ) @ Q2 ) ) ) ).
% upt_conv_Cons_Cons
thf(fact_6283_map__Suc__upt,axiom,
! [M: nat,N2: nat] :
( ( map @ nat @ nat @ suc @ ( upt @ M @ N2 ) )
= ( upt @ ( suc @ M ) @ ( suc @ N2 ) ) ) ).
% map_Suc_upt
thf(fact_6284_greaterThanAtMost__upt,axiom,
( ( set_or3652927894154168847AtMost @ nat )
= ( ^ [N: nat,M2: nat] : ( set2 @ nat @ ( upt @ ( suc @ N ) @ ( suc @ M2 ) ) ) ) ) ).
% greaterThanAtMost_upt
thf(fact_6285_distinct__upt,axiom,
! [I: nat,J: nat] : ( distinct @ nat @ ( upt @ I @ J ) ) ).
% distinct_upt
thf(fact_6286_atLeast__upt,axiom,
( ( set_ord_lessThan @ nat )
= ( ^ [N: nat] : ( set2 @ nat @ ( upt @ ( zero_zero @ nat ) @ N ) ) ) ) ).
% atLeast_upt
thf(fact_6287_atLeastLessThan__upt,axiom,
( ( set_or7035219750837199246ssThan @ nat )
= ( ^ [I5: nat,J3: nat] : ( set2 @ nat @ ( upt @ I5 @ J3 ) ) ) ) ).
% atLeastLessThan_upt
thf(fact_6288_atLeastAtMost__upt,axiom,
( ( set_or1337092689740270186AtMost @ nat )
= ( ^ [N: nat,M2: nat] : ( set2 @ nat @ ( upt @ N @ ( suc @ M2 ) ) ) ) ) ).
% atLeastAtMost_upt
thf(fact_6289_map__replicate__trivial,axiom,
! [A: $tType,X: A,I: nat] :
( ( map @ nat @ A
@ ^ [I5: nat] : X
@ ( upt @ ( zero_zero @ nat ) @ I ) )
= ( replicate @ A @ I @ X ) ) ).
% map_replicate_trivial
thf(fact_6290_greaterThanLessThan__upt,axiom,
( ( set_or5935395276787703475ssThan @ nat )
= ( ^ [N: nat,M2: nat] : ( set2 @ nat @ ( upt @ ( suc @ N ) @ M2 ) ) ) ) ).
% greaterThanLessThan_upt
thf(fact_6291_enumerate__map__upt,axiom,
! [A: $tType,N2: nat,F2: nat > A,M: nat] :
( ( enumerate @ A @ N2 @ ( map @ nat @ A @ F2 @ ( upt @ N2 @ M ) ) )
= ( map @ nat @ ( product_prod @ nat @ A )
@ ^ [K2: nat] : ( product_Pair @ nat @ A @ K2 @ ( F2 @ K2 ) )
@ ( upt @ N2 @ M ) ) ) ).
% enumerate_map_upt
thf(fact_6292_atMost__upto,axiom,
( ( set_ord_atMost @ nat )
= ( ^ [N: nat] : ( set2 @ nat @ ( upt @ ( zero_zero @ nat ) @ ( suc @ N ) ) ) ) ) ).
% atMost_upto
thf(fact_6293_upt__conv__Cons,axiom,
! [I: nat,J: nat] :
( ( ord_less @ nat @ I @ J )
=> ( ( upt @ I @ J )
= ( cons @ nat @ I @ ( upt @ ( suc @ I ) @ J ) ) ) ) ).
% upt_conv_Cons
thf(fact_6294_enumerate__eq__zip,axiom,
! [A: $tType] :
( ( enumerate @ A )
= ( ^ [N: nat,Xs2: list @ A] : ( zip @ nat @ A @ ( upt @ N @ ( plus_plus @ nat @ N @ ( size_size @ ( list @ A ) @ Xs2 ) ) ) @ Xs2 ) ) ) ).
% enumerate_eq_zip
thf(fact_6295_map__upt__Suc,axiom,
! [A: $tType,F2: nat > A,N2: nat] :
( ( map @ nat @ A @ F2 @ ( upt @ ( zero_zero @ nat ) @ ( suc @ N2 ) ) )
= ( cons @ A @ ( F2 @ ( zero_zero @ nat ) )
@ ( map @ nat @ A
@ ^ [I5: nat] : ( F2 @ ( suc @ I5 ) )
@ ( upt @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% map_upt_Suc
thf(fact_6296_map__decr__upt,axiom,
! [M: nat,N2: nat] :
( ( map @ nat @ nat
@ ^ [N: nat] : ( minus_minus @ nat @ N @ ( suc @ ( zero_zero @ nat ) ) )
@ ( upt @ ( suc @ M ) @ ( suc @ N2 ) ) )
= ( upt @ M @ N2 ) ) ).
% map_decr_upt
thf(fact_6297_map__nth,axiom,
! [A: $tType,Xs: list @ A] :
( ( map @ nat @ A @ ( nth @ A @ Xs ) @ ( upt @ ( zero_zero @ nat ) @ ( size_size @ ( list @ A ) @ Xs ) ) )
= Xs ) ).
% map_nth
thf(fact_6298_upt__add__eq__append,axiom,
! [I: nat,J: nat,K: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( upt @ I @ ( plus_plus @ nat @ J @ K ) )
= ( append @ nat @ ( upt @ I @ J ) @ ( upt @ J @ ( plus_plus @ nat @ J @ K ) ) ) ) ) ).
% upt_add_eq_append
thf(fact_6299_nth__map__upt,axiom,
! [A: $tType,I: nat,N2: nat,M: nat,F2: nat > A] :
( ( ord_less @ nat @ I @ ( minus_minus @ nat @ N2 @ M ) )
=> ( ( nth @ A @ ( map @ nat @ A @ F2 @ ( upt @ M @ N2 ) ) @ I )
= ( F2 @ ( plus_plus @ nat @ M @ I ) ) ) ) ).
% nth_map_upt
thf(fact_6300_upt__eq__Cons__conv,axiom,
! [I: nat,J: nat,X: nat,Xs: list @ nat] :
( ( ( upt @ I @ J )
= ( cons @ nat @ X @ Xs ) )
= ( ( ord_less @ nat @ I @ J )
& ( I = X )
& ( ( upt @ ( plus_plus @ nat @ I @ ( one_one @ nat ) ) @ J )
= Xs ) ) ) ).
% upt_eq_Cons_conv
thf(fact_6301_upt__rec,axiom,
( upt
= ( ^ [I5: nat,J3: nat] : ( if @ ( list @ nat ) @ ( ord_less @ nat @ I5 @ J3 ) @ ( cons @ nat @ I5 @ ( upt @ ( suc @ I5 ) @ J3 ) ) @ ( nil @ nat ) ) ) ) ).
% upt_rec
thf(fact_6302_enumerate__replicate__eq,axiom,
! [A: $tType,N2: nat,M: nat,A3: A] :
( ( enumerate @ A @ N2 @ ( replicate @ A @ M @ A3 ) )
= ( map @ nat @ ( product_prod @ nat @ A )
@ ^ [Q5: nat] : ( product_Pair @ nat @ A @ Q5 @ A3 )
@ ( upt @ N2 @ ( plus_plus @ nat @ N2 @ M ) ) ) ) ).
% enumerate_replicate_eq
thf(fact_6303_map__upt__eqI,axiom,
! [A: $tType,Xs: list @ A,N2: nat,M: nat,F2: nat > A] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( minus_minus @ nat @ N2 @ M ) )
=> ( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ A @ Xs @ I3 )
= ( F2 @ ( plus_plus @ nat @ M @ I3 ) ) ) )
=> ( ( map @ nat @ A @ F2 @ ( upt @ M @ N2 ) )
= Xs ) ) ) ).
% map_upt_eqI
thf(fact_6304_upt__Suc__append,axiom,
! [I: nat,J: nat] :
( ( ord_less_eq @ nat @ I @ J )
=> ( ( upt @ I @ ( suc @ J ) )
= ( append @ nat @ ( upt @ I @ J ) @ ( cons @ nat @ J @ ( nil @ nat ) ) ) ) ) ).
% upt_Suc_append
thf(fact_6305_upt__Suc,axiom,
! [I: nat,J: nat] :
( ( ( ord_less_eq @ nat @ I @ J )
=> ( ( upt @ I @ ( suc @ J ) )
= ( append @ nat @ ( upt @ I @ J ) @ ( cons @ nat @ J @ ( nil @ nat ) ) ) ) )
& ( ~ ( ord_less_eq @ nat @ I @ J )
=> ( ( upt @ I @ ( suc @ J ) )
= ( nil @ nat ) ) ) ) ).
% upt_Suc
thf(fact_6306_transpose__rectangle,axiom,
! [A: $tType,Xs: list @ ( list @ A ),N2: nat] :
( ( ( Xs
= ( nil @ ( list @ A ) ) )
=> ( N2
= ( zero_zero @ nat ) ) )
=> ( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( size_size @ ( list @ ( list @ A ) ) @ Xs ) )
=> ( ( size_size @ ( list @ A ) @ ( nth @ ( list @ A ) @ Xs @ I3 ) )
= N2 ) )
=> ( ( transpose @ A @ Xs )
= ( map @ nat @ ( list @ A )
@ ^ [I5: nat] :
( map @ nat @ A
@ ^ [J3: nat] : ( nth @ A @ ( nth @ ( list @ A ) @ Xs @ J3 ) @ I5 )
@ ( upt @ ( zero_zero @ nat ) @ ( size_size @ ( list @ ( list @ A ) ) @ Xs ) ) )
@ ( upt @ ( zero_zero @ nat ) @ N2 ) ) ) ) ) ).
% transpose_rectangle
thf(fact_6307_extract__SomeE,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A,Ys: list @ A,Y: A,Zs: list @ A] :
( ( ( extract @ A @ P2 @ Xs )
= ( some @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) @ ( product_Pair @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) @ Ys @ ( product_Pair @ A @ ( list @ A ) @ Y @ Zs ) ) ) )
=> ( ( Xs
= ( append @ A @ Ys @ ( cons @ A @ Y @ Zs ) ) )
& ( P2 @ Y )
& ~ ? [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Ys ) )
& ( P2 @ X3 ) ) ) ) ).
% extract_SomeE
thf(fact_6308_extract__Some__iff,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A,Ys: list @ A,Y: A,Zs: list @ A] :
( ( ( extract @ A @ P2 @ Xs )
= ( some @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) @ ( product_Pair @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) @ Ys @ ( product_Pair @ A @ ( list @ A ) @ Y @ Zs ) ) ) )
= ( ( Xs
= ( append @ A @ Ys @ ( cons @ A @ Y @ Zs ) ) )
& ( P2 @ Y )
& ~ ? [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Ys ) )
& ( P2 @ X2 ) ) ) ) ).
% extract_Some_iff
thf(fact_6309_extract__None__iff,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ( extract @ A @ P2 @ Xs )
= ( none @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) ) )
= ( ~ ? [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
& ( P2 @ X2 ) ) ) ) ).
% extract_None_iff
thf(fact_6310_extract__Nil__code,axiom,
! [A: $tType,P2: A > $o] :
( ( extract @ A @ P2 @ ( nil @ A ) )
= ( none @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) ) ) ).
% extract_Nil_code
thf(fact_6311_extract__Cons__code,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A] :
( ( ( P2 @ X )
=> ( ( extract @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( some @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) @ ( product_Pair @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) @ ( nil @ A ) @ ( product_Pair @ A @ ( list @ A ) @ X @ Xs ) ) ) ) )
& ( ~ ( P2 @ X )
=> ( ( extract @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( case_option @ ( option @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) ) @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) @ ( none @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) )
@ ( product_case_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) @ ( option @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) )
@ ^ [Ys3: list @ A] :
( product_case_prod @ A @ ( list @ A ) @ ( option @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) )
@ ^ [Y2: A,Zs3: list @ A] : ( some @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) @ ( product_Pair @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) @ ( cons @ A @ X @ Ys3 ) @ ( product_Pair @ A @ ( list @ A ) @ Y2 @ Zs3 ) ) ) ) )
@ ( extract @ A @ P2 @ Xs ) ) ) ) ) ).
% extract_Cons_code
thf(fact_6312_sum__list__map__eq__sum__count2,axiom,
! [A: $tType,Xs: list @ A,X7: set @ A,F2: A > nat] :
( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs ) @ X7 )
=> ( ( finite_finite @ A @ X7 )
=> ( ( groups8242544230860333062m_list @ nat @ ( map @ A @ nat @ F2 @ Xs ) )
= ( groups7311177749621191930dd_sum @ A @ nat
@ ^ [X2: A] : ( times_times @ nat @ ( count_list @ A @ Xs @ X2 ) @ ( F2 @ X2 ) )
@ X7 ) ) ) ) ).
% sum_list_map_eq_sum_count2
thf(fact_6313_nth__transpose,axiom,
! [A: $tType,I: nat,Xs: list @ ( list @ A )] :
( ( ord_less @ nat @ I @ ( size_size @ ( list @ ( list @ A ) ) @ ( transpose @ A @ Xs ) ) )
=> ( ( nth @ ( list @ A ) @ ( transpose @ A @ Xs ) @ I )
= ( map @ ( list @ A ) @ A
@ ^ [Xs2: list @ A] : ( nth @ A @ Xs2 @ I )
@ ( filter2 @ ( list @ A )
@ ^ [Ys3: list @ A] : ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Ys3 ) )
@ Xs ) ) ) ) ).
% nth_transpose
thf(fact_6314_filter__filter,axiom,
! [A: $tType,P2: A > $o,Q: A > $o,Xs: list @ A] :
( ( filter2 @ A @ P2 @ ( filter2 @ A @ Q @ Xs ) )
= ( filter2 @ A
@ ^ [X2: A] :
( ( Q @ X2 )
& ( P2 @ X2 ) )
@ Xs ) ) ).
% filter_filter
thf(fact_6315_filter__True,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X5 ) )
=> ( ( filter2 @ A @ P2 @ Xs )
= Xs ) ) ).
% filter_True
thf(fact_6316_filter__append,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A,Ys: list @ A] :
( ( filter2 @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ ( filter2 @ A @ P2 @ Xs ) @ ( filter2 @ A @ P2 @ Ys ) ) ) ).
% filter_append
thf(fact_6317_remove1__filter__not,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A] :
( ~ ( P2 @ X )
=> ( ( remove1 @ A @ X @ ( filter2 @ A @ P2 @ Xs ) )
= ( filter2 @ A @ P2 @ Xs ) ) ) ).
% remove1_filter_not
thf(fact_6318_removeAll__filter__not,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A] :
( ~ ( P2 @ X )
=> ( ( removeAll @ A @ X @ ( filter2 @ A @ P2 @ Xs ) )
= ( filter2 @ A @ P2 @ Xs ) ) ) ).
% removeAll_filter_not
thf(fact_6319_set__filter,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( set2 @ A @ ( filter2 @ A @ P2 @ Xs ) )
= ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
& ( P2 @ X2 ) ) ) ) ).
% set_filter
thf(fact_6320_sum__list_ONil,axiom,
! [A: $tType] :
( ( monoid_add @ A )
=> ( ( groups8242544230860333062m_list @ A @ ( nil @ A ) )
= ( zero_zero @ A ) ) ) ).
% sum_list.Nil
thf(fact_6321_sum__list__eq__0__iff,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [Ns: list @ A] :
( ( ( groups8242544230860333062m_list @ A @ Ns )
= ( zero_zero @ A ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Ns ) )
=> ( X2
= ( zero_zero @ A ) ) ) ) ) ) ).
% sum_list_eq_0_iff
thf(fact_6322_sum__list_OCons,axiom,
! [A: $tType] :
( ( monoid_add @ A )
=> ! [X: A,Xs: list @ A] :
( ( groups8242544230860333062m_list @ A @ ( cons @ A @ X @ Xs ) )
= ( plus_plus @ A @ X @ ( groups8242544230860333062m_list @ A @ Xs ) ) ) ) ).
% sum_list.Cons
thf(fact_6323_filter__False,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ~ ( P2 @ X5 ) )
=> ( ( filter2 @ A @ P2 @ Xs )
= ( nil @ A ) ) ) ).
% filter_False
thf(fact_6324_sum__list__append,axiom,
! [A: $tType] :
( ( monoid_add @ A )
=> ! [Xs: list @ A,Ys: list @ A] :
( ( groups8242544230860333062m_list @ A @ ( append @ A @ Xs @ Ys ) )
= ( plus_plus @ A @ ( groups8242544230860333062m_list @ A @ Xs ) @ ( groups8242544230860333062m_list @ A @ Ys ) ) ) ) ).
% sum_list_append
thf(fact_6325_sum__list__0,axiom,
! [B: $tType,A: $tType] :
( ( monoid_add @ A )
=> ! [Xs: list @ B] :
( ( groups8242544230860333062m_list @ A
@ ( map @ B @ A
@ ^ [X2: B] : ( zero_zero @ A )
@ Xs ) )
= ( zero_zero @ A ) ) ) ).
% sum_list_0
thf(fact_6326_length__filter__map,axiom,
! [A: $tType,B: $tType,P2: A > $o,F2: B > A,Xs: list @ B] :
( ( size_size @ ( list @ A ) @ ( filter2 @ A @ P2 @ ( map @ B @ A @ F2 @ Xs ) ) )
= ( size_size @ ( list @ B ) @ ( filter2 @ B @ ( comp @ A @ $o @ B @ P2 @ F2 ) @ Xs ) ) ) ).
% length_filter_map
thf(fact_6327_sum__list__upt,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( groups8242544230860333062m_list @ nat @ ( upt @ M @ N2 ) )
= ( groups7311177749621191930dd_sum @ nat @ nat
@ ^ [X2: nat] : X2
@ ( set_or7035219750837199246ssThan @ nat @ M @ N2 ) ) ) ) ).
% sum_list_upt
thf(fact_6328_sum__list__filter__le__nat,axiom,
! [A: $tType,F2: A > nat,P2: A > $o,Xs: list @ A] : ( ord_less_eq @ nat @ ( groups8242544230860333062m_list @ nat @ ( map @ A @ nat @ F2 @ ( filter2 @ A @ P2 @ Xs ) ) ) @ ( groups8242544230860333062m_list @ nat @ ( map @ A @ nat @ F2 @ Xs ) ) ) ).
% sum_list_filter_le_nat
thf(fact_6329_filter__concat,axiom,
! [A: $tType,P4: A > $o,Xs: list @ ( list @ A )] :
( ( filter2 @ A @ P4 @ ( concat @ A @ Xs ) )
= ( concat @ A @ ( map @ ( list @ A ) @ ( list @ A ) @ ( filter2 @ A @ P4 ) @ Xs ) ) ) ).
% filter_concat
thf(fact_6330_sum__list__map__filter_H,axiom,
! [A: $tType,B: $tType] :
( ( monoid_add @ A )
=> ! [F2: B > A,P2: B > $o,Xs: list @ B] :
( ( groups8242544230860333062m_list @ A @ ( map @ B @ A @ F2 @ ( filter2 @ B @ P2 @ Xs ) ) )
= ( groups8242544230860333062m_list @ A
@ ( map @ B @ A
@ ^ [X2: B] : ( if @ A @ ( P2 @ X2 ) @ ( F2 @ X2 ) @ ( zero_zero @ A ) )
@ Xs ) ) ) ) ).
% sum_list_map_filter'
thf(fact_6331_filter__map,axiom,
! [A: $tType,B: $tType,P2: A > $o,F2: B > A,Xs: list @ B] :
( ( filter2 @ A @ P2 @ ( map @ B @ A @ F2 @ Xs ) )
= ( map @ B @ A @ F2 @ ( filter2 @ B @ ( comp @ A @ $o @ B @ P2 @ F2 ) @ Xs ) ) ) ).
% filter_map
thf(fact_6332_distinct__map__filter,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B,P2: B > $o] :
( ( distinct @ A @ ( map @ B @ A @ F2 @ Xs ) )
=> ( distinct @ A @ ( map @ B @ A @ F2 @ ( filter2 @ B @ P2 @ Xs ) ) ) ) ).
% distinct_map_filter
thf(fact_6333_sum__list__map__filter,axiom,
! [A: $tType,B: $tType] :
( ( monoid_add @ A )
=> ! [Xs: list @ B,P2: B > $o,F2: B > A] :
( ! [X5: B] :
( ( member2 @ B @ X5 @ ( set2 @ B @ Xs ) )
=> ( ~ ( P2 @ X5 )
=> ( ( F2 @ X5 )
= ( zero_zero @ A ) ) ) )
=> ( ( groups8242544230860333062m_list @ A @ ( map @ B @ A @ F2 @ ( filter2 @ B @ P2 @ Xs ) ) )
= ( groups8242544230860333062m_list @ A @ ( map @ B @ A @ F2 @ Xs ) ) ) ) ) ).
% sum_list_map_filter
thf(fact_6334_filter__empty__conv,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ( filter2 @ A @ P2 @ Xs )
= ( nil @ A ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ~ ( P2 @ X2 ) ) ) ) ).
% filter_empty_conv
thf(fact_6335_empty__filter__conv,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ( nil @ A )
= ( filter2 @ A @ P2 @ Xs ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ~ ( P2 @ X2 ) ) ) ) ).
% empty_filter_conv
thf(fact_6336_filter__set,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( filter3 @ A @ P2 @ ( set2 @ A @ Xs ) )
= ( set2 @ A @ ( filter2 @ A @ P2 @ Xs ) ) ) ).
% filter_set
thf(fact_6337_filter__id__conv,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ( filter2 @ A @ P2 @ Xs )
= Xs )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X2 ) ) ) ) ).
% filter_id_conv
thf(fact_6338_filter__cong,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,P2: A > $o,Q: A > $o] :
( ( Xs = Ys )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Ys ) )
=> ( ( P2 @ X5 )
= ( Q @ X5 ) ) )
=> ( ( filter2 @ A @ P2 @ Xs )
= ( filter2 @ A @ Q @ Ys ) ) ) ) ).
% filter_cong
thf(fact_6339_inter__set__filter,axiom,
! [A: $tType,A4: set @ A,Xs: list @ A] :
( ( inf_inf @ ( set @ A ) @ A4 @ ( set2 @ A @ Xs ) )
= ( set2 @ A
@ ( filter2 @ A
@ ^ [X2: A] : ( member2 @ A @ X2 @ A4 )
@ Xs ) ) ) ).
% inter_set_filter
thf(fact_6340_sum__length__filter__compl,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( plus_plus @ nat @ ( size_size @ ( list @ A ) @ ( filter2 @ A @ P2 @ Xs ) )
@ ( size_size @ ( list @ A )
@ ( filter2 @ A
@ ^ [X2: A] :
~ ( P2 @ X2 )
@ Xs ) ) )
= ( size_size @ ( list @ A ) @ Xs ) ) ).
% sum_length_filter_compl
thf(fact_6341_replicate__length__filter,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( replicate @ A
@ ( size_size @ ( list @ A )
@ ( filter2 @ A
@ ( ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ X )
@ Xs ) )
@ X )
= ( filter2 @ A
@ ( ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ X )
@ Xs ) ) ).
% replicate_length_filter
thf(fact_6342_member__le__sum__list,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ord_less_eq @ A @ X @ ( groups8242544230860333062m_list @ A @ Xs ) ) ) ) ).
% member_le_sum_list
thf(fact_6343_length__filter__le,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] : ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ ( filter2 @ A @ P2 @ Xs ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ).
% length_filter_le
thf(fact_6344_filter__is__subset,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] : ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ ( filter2 @ A @ P2 @ Xs ) ) @ ( set2 @ A @ Xs ) ) ).
% filter_is_subset
thf(fact_6345_distinct__filter,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ( distinct @ A @ Xs )
=> ( distinct @ A @ ( filter2 @ A @ P2 @ Xs ) ) ) ).
% distinct_filter
thf(fact_6346_remdups__filter,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( remdups @ A @ ( filter2 @ A @ P2 @ Xs ) )
= ( filter2 @ A @ P2 @ ( remdups @ A @ Xs ) ) ) ).
% remdups_filter
thf(fact_6347_filter__replicate,axiom,
! [A: $tType,P2: A > $o,X: A,N2: nat] :
( ( ( P2 @ X )
=> ( ( filter2 @ A @ P2 @ ( replicate @ A @ N2 @ X ) )
= ( replicate @ A @ N2 @ X ) ) )
& ( ~ ( P2 @ X )
=> ( ( filter2 @ A @ P2 @ ( replicate @ A @ N2 @ X ) )
= ( nil @ A ) ) ) ) ).
% filter_replicate
thf(fact_6348_filter_Osimps_I1_J,axiom,
! [A: $tType,P2: A > $o] :
( ( filter2 @ A @ P2 @ ( nil @ A ) )
= ( nil @ A ) ) ).
% filter.simps(1)
thf(fact_6349_filter__shuffles,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A,Ys: list @ A] :
( ( image2 @ ( list @ A ) @ ( list @ A ) @ ( filter2 @ A @ P2 ) @ ( shuffles @ A @ Xs @ Ys ) )
= ( shuffles @ A @ ( filter2 @ A @ P2 @ Xs ) @ ( filter2 @ A @ P2 @ Ys ) ) ) ).
% filter_shuffles
thf(fact_6350_filter_Osimps_I2_J,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A] :
( ( ( P2 @ X )
=> ( ( filter2 @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( cons @ A @ X @ ( filter2 @ A @ P2 @ Xs ) ) ) )
& ( ~ ( P2 @ X )
=> ( ( filter2 @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( filter2 @ A @ P2 @ Xs ) ) ) ) ).
% filter.simps(2)
thf(fact_6351_partition__in__shuffles,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( member2 @ ( list @ A ) @ Xs
@ ( shuffles @ A @ ( filter2 @ A @ P2 @ Xs )
@ ( filter2 @ A
@ ^ [X2: A] :
~ ( P2 @ X2 )
@ Xs ) ) ) ).
% partition_in_shuffles
thf(fact_6352_removeAll__filter__not__eq,axiom,
! [A: $tType] :
( ( removeAll @ A )
= ( ^ [X2: A] :
( filter2 @ A
@ ^ [Y2: A] : ( X2 != Y2 ) ) ) ) ).
% removeAll_filter_not_eq
thf(fact_6353_filter__insort__triv,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [P2: B > $o,X: B,F2: B > A,Xs: list @ B] :
( ~ ( P2 @ X )
=> ( ( filter2 @ B @ P2 @ ( linorder_insort_key @ B @ A @ F2 @ X @ Xs ) )
= ( filter2 @ B @ P2 @ Xs ) ) ) ) ).
% filter_insort_triv
thf(fact_6354_filter__remove1,axiom,
! [A: $tType,Q: A > $o,X: A,Xs: list @ A] :
( ( filter2 @ A @ Q @ ( remove1 @ A @ X @ Xs ) )
= ( remove1 @ A @ X @ ( filter2 @ A @ Q @ Xs ) ) ) ).
% filter_remove1
thf(fact_6355_sum__list__addf,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [F2: B > A,G: B > A,Xs: list @ B] :
( ( groups8242544230860333062m_list @ A
@ ( map @ B @ A
@ ^ [X2: B] : ( plus_plus @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ Xs ) )
= ( plus_plus @ A @ ( groups8242544230860333062m_list @ A @ ( map @ B @ A @ F2 @ Xs ) ) @ ( groups8242544230860333062m_list @ A @ ( map @ B @ A @ G @ Xs ) ) ) ) ) ).
% sum_list_addf
thf(fact_6356_length__filter__less,axiom,
! [A: $tType,X: A,Xs: list @ A,P2: A > $o] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ~ ( P2 @ X )
=> ( ord_less @ nat @ ( size_size @ ( list @ A ) @ ( filter2 @ A @ P2 @ Xs ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ) ) ).
% length_filter_less
thf(fact_6357_Cons__eq__filterD,axiom,
! [A: $tType,X: A,Xs: list @ A,P2: A > $o,Ys: list @ A] :
( ( ( cons @ A @ X @ Xs )
= ( filter2 @ A @ P2 @ Ys ) )
=> ? [Us3: list @ A,Vs3: list @ A] :
( ( Ys
= ( append @ A @ Us3 @ ( cons @ A @ X @ Vs3 ) ) )
& ! [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Us3 ) )
=> ~ ( P2 @ X3 ) )
& ( P2 @ X )
& ( Xs
= ( filter2 @ A @ P2 @ Vs3 ) ) ) ) ).
% Cons_eq_filterD
thf(fact_6358_filter__eq__ConsD,axiom,
! [A: $tType,P2: A > $o,Ys: list @ A,X: A,Xs: list @ A] :
( ( ( filter2 @ A @ P2 @ Ys )
= ( cons @ A @ X @ Xs ) )
=> ? [Us3: list @ A,Vs3: list @ A] :
( ( Ys
= ( append @ A @ Us3 @ ( cons @ A @ X @ Vs3 ) ) )
& ! [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Us3 ) )
=> ~ ( P2 @ X3 ) )
& ( P2 @ X )
& ( Xs
= ( filter2 @ A @ P2 @ Vs3 ) ) ) ) ).
% filter_eq_ConsD
thf(fact_6359_Cons__eq__filter__iff,axiom,
! [A: $tType,X: A,Xs: list @ A,P2: A > $o,Ys: list @ A] :
( ( ( cons @ A @ X @ Xs )
= ( filter2 @ A @ P2 @ Ys ) )
= ( ? [Us2: list @ A,Vs: list @ A] :
( ( Ys
= ( append @ A @ Us2 @ ( cons @ A @ X @ Vs ) ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Us2 ) )
=> ~ ( P2 @ X2 ) )
& ( P2 @ X )
& ( Xs
= ( filter2 @ A @ P2 @ Vs ) ) ) ) ) ).
% Cons_eq_filter_iff
thf(fact_6360_filter__eq__Cons__iff,axiom,
! [A: $tType,P2: A > $o,Ys: list @ A,X: A,Xs: list @ A] :
( ( ( filter2 @ A @ P2 @ Ys )
= ( cons @ A @ X @ Xs ) )
= ( ? [Us2: list @ A,Vs: list @ A] :
( ( Ys
= ( append @ A @ Us2 @ ( cons @ A @ X @ Vs ) ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Us2 ) )
=> ~ ( P2 @ X2 ) )
& ( P2 @ X )
& ( Xs
= ( filter2 @ A @ P2 @ Vs ) ) ) ) ) ).
% filter_eq_Cons_iff
thf(fact_6361_inj__on__filter__key__eq,axiom,
! [B: $tType,A: $tType,F2: A > B,Y: A,Xs: list @ A] :
( ( inj_on @ A @ B @ F2 @ ( insert2 @ A @ Y @ ( set2 @ A @ Xs ) ) )
=> ( ( filter2 @ A
@ ^ [X2: A] :
( ( F2 @ Y )
= ( F2 @ X2 ) )
@ Xs )
= ( filter2 @ A
@ ( ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ Y )
@ Xs ) ) ) ).
% inj_on_filter_key_eq
thf(fact_6362_sum__list__nonpos,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [Xs: list @ A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ord_less_eq @ A @ X5 @ ( zero_zero @ A ) ) )
=> ( ord_less_eq @ A @ ( groups8242544230860333062m_list @ A @ Xs ) @ ( zero_zero @ A ) ) ) ) ).
% sum_list_nonpos
thf(fact_6363_sum__list__nonneg__eq__0__iff,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [Xs: list @ A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ X5 ) )
=> ( ( ( groups8242544230860333062m_list @ A @ Xs )
= ( zero_zero @ A ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ( X2
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% sum_list_nonneg_eq_0_iff
thf(fact_6364_Groups__List_Osum__list__nonneg,axiom,
! [A: $tType] :
( ( ordere6911136660526730532id_add @ A )
=> ! [Xs: list @ A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ X5 ) )
=> ( ord_less_eq @ A @ ( zero_zero @ A ) @ ( groups8242544230860333062m_list @ A @ Xs ) ) ) ) ).
% Groups_List.sum_list_nonneg
thf(fact_6365_sum__list__abs,axiom,
! [A: $tType] :
( ( ordere166539214618696060dd_abs @ A )
=> ! [Xs: list @ A] : ( ord_less_eq @ A @ ( abs_abs @ A @ ( groups8242544230860333062m_list @ A @ Xs ) ) @ ( groups8242544230860333062m_list @ A @ ( map @ A @ A @ ( abs_abs @ A ) @ Xs ) ) ) ) ).
% sum_list_abs
thf(fact_6366_filter__in__nths,axiom,
! [A: $tType,Xs: list @ A,S: set @ nat] :
( ( distinct @ A @ Xs )
=> ( ( filter2 @ A
@ ^ [X2: A] : ( member2 @ A @ X2 @ ( set2 @ A @ ( nths @ A @ Xs @ S ) ) )
@ Xs )
= ( nths @ A @ Xs @ S ) ) ) ).
% filter_in_nths
thf(fact_6367_sum__list__mono,axiom,
! [B: $tType,A: $tType] :
( ( ( monoid_add @ B )
& ( ordere6658533253407199908up_add @ B ) )
=> ! [Xs: list @ A,F2: A > B,G: A > B] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ord_less_eq @ B @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ord_less_eq @ B @ ( groups8242544230860333062m_list @ B @ ( map @ A @ B @ F2 @ Xs ) ) @ ( groups8242544230860333062m_list @ B @ ( map @ A @ B @ G @ Xs ) ) ) ) ) ).
% sum_list_mono
thf(fact_6368_distinct__sum__list__conv__Sum,axiom,
! [A: $tType] :
( ( comm_monoid_add @ A )
=> ! [Xs: list @ A] :
( ( distinct @ A @ Xs )
=> ( ( groups8242544230860333062m_list @ A @ Xs )
= ( groups7311177749621191930dd_sum @ A @ A
@ ^ [X2: A] : X2
@ ( set2 @ A @ Xs ) ) ) ) ) ).
% distinct_sum_list_conv_Sum
thf(fact_6369_set__minus__filter__out,axiom,
! [A: $tType,Xs: list @ A,Y: A] :
( ( minus_minus @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( insert2 @ A @ Y @ ( bot_bot @ ( set @ A ) ) ) )
= ( set2 @ A
@ ( filter2 @ A
@ ^ [X2: A] : ( X2 != Y )
@ Xs ) ) ) ).
% set_minus_filter_out
thf(fact_6370_filter__shuffles__disjoint1_I2_J,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ( ( inf_inf @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ Ys ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ Xs @ Ys ) )
=> ( ( filter2 @ A
@ ^ [X2: A] :
~ ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
@ Zs )
= Ys ) ) ) ).
% filter_shuffles_disjoint1(2)
thf(fact_6371_filter__shuffles__disjoint1_I1_J,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ( ( inf_inf @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ Ys ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ Xs @ Ys ) )
=> ( ( filter2 @ A
@ ^ [X2: A] : ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
@ Zs )
= Xs ) ) ) ).
% filter_shuffles_disjoint1(1)
thf(fact_6372_filter__shuffles__disjoint2_I2_J,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ( ( inf_inf @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ Ys ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ Xs @ Ys ) )
=> ( ( filter2 @ A
@ ^ [X2: A] :
~ ( member2 @ A @ X2 @ ( set2 @ A @ Ys ) )
@ Zs )
= Xs ) ) ) ).
% filter_shuffles_disjoint2(2)
thf(fact_6373_filter__shuffles__disjoint2_I1_J,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ( ( inf_inf @ ( set @ A ) @ ( set2 @ A @ Xs ) @ ( set2 @ A @ Ys ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ Xs @ Ys ) )
=> ( ( filter2 @ A
@ ^ [X2: A] : ( member2 @ A @ X2 @ ( set2 @ A @ Ys ) )
@ Zs )
= Ys ) ) ) ).
% filter_shuffles_disjoint2(1)
thf(fact_6374_filter__eq__nths,axiom,
! [A: $tType] :
( ( filter2 @ A )
= ( ^ [P: A > $o,Xs2: list @ A] :
( nths @ A @ Xs2
@ ( collect @ nat
@ ^ [I5: nat] :
( ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs2 ) )
& ( P @ ( nth @ A @ Xs2 @ I5 ) ) ) ) ) ) ) ).
% filter_eq_nths
thf(fact_6375_length__filter__conv__card,axiom,
! [A: $tType,P4: A > $o,Xs: list @ A] :
( ( size_size @ ( list @ A ) @ ( filter2 @ A @ P4 @ Xs ) )
= ( finite_card @ nat
@ ( collect @ nat
@ ^ [I5: nat] :
( ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs ) )
& ( P4 @ ( nth @ A @ Xs @ I5 ) ) ) ) ) ) ).
% length_filter_conv_card
thf(fact_6376_sum__list__strict__mono,axiom,
! [B: $tType,A: $tType] :
( ( ( monoid_add @ B )
& ( strict9044650504122735259up_add @ B ) )
=> ! [Xs: list @ A,F2: A > B,G: A > B] :
( ( Xs
!= ( nil @ A ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ord_less @ B @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ord_less @ B @ ( groups8242544230860333062m_list @ B @ ( map @ A @ B @ F2 @ Xs ) ) @ ( groups8242544230860333062m_list @ B @ ( map @ A @ B @ G @ Xs ) ) ) ) ) ) ).
% sum_list_strict_mono
thf(fact_6377_elem__le__sum__list,axiom,
! [A: $tType] :
( ( canoni5634975068530333245id_add @ A )
=> ! [K: nat,Ns: list @ A] :
( ( ord_less @ nat @ K @ ( size_size @ ( list @ A ) @ Ns ) )
=> ( ord_less_eq @ A @ ( nth @ A @ Ns @ K ) @ ( groups8242544230860333062m_list @ A @ Ns ) ) ) ) ).
% elem_le_sum_list
thf(fact_6378_sum__list__distinct__conv__sum__set,axiom,
! [C: $tType,B: $tType] :
( ( comm_monoid_add @ C )
=> ! [Xs: list @ B,F2: B > C] :
( ( distinct @ B @ Xs )
=> ( ( groups8242544230860333062m_list @ C @ ( map @ B @ C @ F2 @ Xs ) )
= ( groups7311177749621191930dd_sum @ B @ C @ F2 @ ( set2 @ B @ Xs ) ) ) ) ) ).
% sum_list_distinct_conv_sum_set
thf(fact_6379_sum_Odistinct__set__conv__list,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [Xs: list @ B,G: B > A] :
( ( distinct @ B @ Xs )
=> ( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( set2 @ B @ Xs ) )
= ( groups8242544230860333062m_list @ A @ ( map @ B @ A @ G @ Xs ) ) ) ) ) ).
% sum.distinct_set_conv_list
thf(fact_6380_sum__list__map__remove1,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [X: B,Xs: list @ B,F2: B > A] :
( ( member2 @ B @ X @ ( set2 @ B @ Xs ) )
=> ( ( groups8242544230860333062m_list @ A @ ( map @ B @ A @ F2 @ Xs ) )
= ( plus_plus @ A @ ( F2 @ X ) @ ( groups8242544230860333062m_list @ A @ ( map @ B @ A @ F2 @ ( remove1 @ B @ X @ Xs ) ) ) ) ) ) ) ).
% sum_list_map_remove1
thf(fact_6381_sum__code,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_add @ A )
=> ! [G: B > A,Xs: list @ B] :
( ( groups7311177749621191930dd_sum @ B @ A @ G @ ( set2 @ B @ Xs ) )
= ( groups8242544230860333062m_list @ A @ ( map @ B @ A @ G @ ( remdups @ B @ Xs ) ) ) ) ) ).
% sum_code
thf(fact_6382_size__list__conv__sum__list,axiom,
! [B: $tType] :
( ( size_list @ B )
= ( ^ [F3: B > nat,Xs2: list @ B] : ( plus_plus @ nat @ ( groups8242544230860333062m_list @ nat @ ( map @ B @ nat @ F3 @ Xs2 ) ) @ ( size_size @ ( list @ B ) @ Xs2 ) ) ) ) ).
% size_list_conv_sum_list
thf(fact_6383_sum__list__Suc,axiom,
! [A: $tType,F2: A > nat,Xs: list @ A] :
( ( groups8242544230860333062m_list @ nat
@ ( map @ A @ nat
@ ^ [X2: A] : ( suc @ ( F2 @ X2 ) )
@ Xs ) )
= ( plus_plus @ nat @ ( groups8242544230860333062m_list @ nat @ ( map @ A @ nat @ F2 @ Xs ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ) ).
% sum_list_Suc
thf(fact_6384_distinct__length__filter,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ( distinct @ A @ Xs )
=> ( ( size_size @ ( list @ A ) @ ( filter2 @ A @ P2 @ Xs ) )
= ( finite_card @ A @ ( inf_inf @ ( set @ A ) @ ( collect @ A @ P2 ) @ ( set2 @ A @ Xs ) ) ) ) ) ).
% distinct_length_filter
thf(fact_6385_sum__list__sum__nth,axiom,
! [B: $tType] :
( ( comm_monoid_add @ B )
=> ( ( groups8242544230860333062m_list @ B )
= ( ^ [Xs2: list @ B] : ( groups7311177749621191930dd_sum @ nat @ B @ ( nth @ B @ Xs2 ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( size_size @ ( list @ B ) @ Xs2 ) ) ) ) ) ) ).
% sum_list_sum_nth
thf(fact_6386_card__length__sum__list__rec,axiom,
! [M: nat,N7: nat] :
( ( ord_less_eq @ nat @ ( one_one @ nat ) @ M )
=> ( ( finite_card @ ( list @ nat )
@ ( collect @ ( list @ nat )
@ ^ [L2: list @ nat] :
( ( ( size_size @ ( list @ nat ) @ L2 )
= M )
& ( ( groups8242544230860333062m_list @ nat @ L2 )
= N7 ) ) ) )
= ( plus_plus @ nat
@ ( finite_card @ ( list @ nat )
@ ( collect @ ( list @ nat )
@ ^ [L2: list @ nat] :
( ( ( size_size @ ( list @ nat ) @ L2 )
= ( minus_minus @ nat @ M @ ( one_one @ nat ) ) )
& ( ( groups8242544230860333062m_list @ nat @ L2 )
= N7 ) ) ) )
@ ( finite_card @ ( list @ nat )
@ ( collect @ ( list @ nat )
@ ^ [L2: list @ nat] :
( ( ( size_size @ ( list @ nat ) @ L2 )
= M )
& ( ( plus_plus @ nat @ ( groups8242544230860333062m_list @ nat @ L2 ) @ ( one_one @ nat ) )
= N7 ) ) ) ) ) ) ) ).
% card_length_sum_list_rec
thf(fact_6387_card__length__sum__list,axiom,
! [M: nat,N7: nat] :
( ( finite_card @ ( list @ nat )
@ ( collect @ ( list @ nat )
@ ^ [L2: list @ nat] :
( ( ( size_size @ ( list @ nat ) @ L2 )
= M )
& ( ( groups8242544230860333062m_list @ nat @ L2 )
= N7 ) ) ) )
= ( binomial @ ( minus_minus @ nat @ ( plus_plus @ nat @ N7 @ M ) @ ( one_one @ nat ) ) @ N7 ) ) ).
% card_length_sum_list
thf(fact_6388_sum__list__map__eq__sum__count,axiom,
! [A: $tType,F2: A > nat,Xs: list @ A] :
( ( groups8242544230860333062m_list @ nat @ ( map @ A @ nat @ F2 @ Xs ) )
= ( groups7311177749621191930dd_sum @ A @ nat
@ ^ [X2: A] : ( times_times @ nat @ ( count_list @ A @ Xs @ X2 ) @ ( F2 @ X2 ) )
@ ( set2 @ A @ Xs ) ) ) ).
% sum_list_map_eq_sum_count
thf(fact_6389_sum__list__update,axiom,
! [A: $tType] :
( ( ordere1170586879665033532d_diff @ A )
=> ! [K: nat,Xs: list @ A,X: A] :
( ( ord_less @ nat @ K @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( groups8242544230860333062m_list @ A @ ( list_update @ A @ Xs @ K @ X ) )
= ( minus_minus @ A @ ( plus_plus @ A @ ( groups8242544230860333062m_list @ A @ Xs ) @ X ) @ ( nth @ A @ Xs @ K ) ) ) ) ) ).
% sum_list_update
thf(fact_6390_transpose__aux__filter__head,axiom,
! [A: $tType,Xss: list @ ( list @ A )] :
( ( concat @ A
@ ( map @ ( list @ A ) @ ( list @ A )
@ ( case_list @ ( list @ A ) @ A @ ( nil @ A )
@ ^ [H: A,T3: list @ A] : ( cons @ A @ H @ ( nil @ A ) ) )
@ Xss ) )
= ( map @ ( list @ A ) @ A @ ( hd @ A )
@ ( filter2 @ ( list @ A )
@ ^ [Ys3: list @ A] :
( Ys3
!= ( nil @ A ) )
@ Xss ) ) ) ).
% transpose_aux_filter_head
thf(fact_6391_map__filter__def,axiom,
! [B: $tType,A: $tType] :
( ( map_filter @ A @ B )
= ( ^ [F3: A > ( option @ B ),Xs2: list @ A] :
( map @ A @ B @ ( comp @ ( option @ B ) @ B @ A @ ( the2 @ B ) @ F3 )
@ ( filter2 @ A
@ ^ [X2: A] :
( ( F3 @ X2 )
!= ( none @ B ) )
@ Xs2 ) ) ) ) ).
% map_filter_def
thf(fact_6392_transpose__aux__filter__tail,axiom,
! [A: $tType,Xss: list @ ( list @ A )] :
( ( concat @ ( list @ A )
@ ( map @ ( list @ A ) @ ( list @ ( list @ A ) )
@ ( case_list @ ( list @ ( list @ A ) ) @ A @ ( nil @ ( list @ A ) )
@ ^ [H: A,T3: list @ A] : ( cons @ ( list @ A ) @ T3 @ ( nil @ ( list @ A ) ) ) )
@ Xss ) )
= ( map @ ( list @ A ) @ ( list @ A ) @ ( tl @ A )
@ ( filter2 @ ( list @ A )
@ ^ [Ys3: list @ A] :
( Ys3
!= ( nil @ A ) )
@ Xss ) ) ) ).
% transpose_aux_filter_tail
thf(fact_6393_tl__upt,axiom,
! [M: nat,N2: nat] :
( ( tl @ nat @ ( upt @ M @ N2 ) )
= ( upt @ ( suc @ M ) @ N2 ) ) ).
% tl_upt
thf(fact_6394_tl__append2,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( tl @ A @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ ( tl @ A @ Xs ) @ Ys ) ) ) ).
% tl_append2
thf(fact_6395_remdups__adj__Cons__alt,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( cons @ A @ X @ ( tl @ A @ ( remdups_adj @ A @ ( cons @ A @ X @ Xs ) ) ) )
= ( remdups_adj @ A @ ( cons @ A @ X @ Xs ) ) ) ).
% remdups_adj_Cons_alt
thf(fact_6396_length__tl,axiom,
! [A: $tType,Xs: list @ A] :
( ( size_size @ ( list @ A ) @ ( tl @ A @ Xs ) )
= ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) ) ) ).
% length_tl
thf(fact_6397_hd__Cons__tl,axiom,
! [A: $tType,Xs: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( cons @ A @ ( hd @ A @ Xs ) @ ( tl @ A @ Xs ) )
= Xs ) ) ).
% hd_Cons_tl
thf(fact_6398_list_Ocollapse,axiom,
! [A: $tType,List: list @ A] :
( ( List
!= ( nil @ A ) )
=> ( ( cons @ A @ ( hd @ A @ List ) @ ( tl @ A @ List ) )
= List ) ) ).
% list.collapse
thf(fact_6399_tl__replicate,axiom,
! [A: $tType,N2: nat,X: A] :
( ( tl @ A @ ( replicate @ A @ N2 @ X ) )
= ( replicate @ A @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ X ) ) ).
% tl_replicate
thf(fact_6400_list_Omap__sel_I2_J,axiom,
! [B: $tType,A: $tType,A3: list @ A,F2: A > B] :
( ( A3
!= ( nil @ A ) )
=> ( ( tl @ B @ ( map @ A @ B @ F2 @ A3 ) )
= ( map @ A @ B @ F2 @ ( tl @ A @ A3 ) ) ) ) ).
% list.map_sel(2)
thf(fact_6401_map__tl,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( map @ B @ A @ F2 @ ( tl @ B @ Xs ) )
= ( tl @ A @ ( map @ B @ A @ F2 @ Xs ) ) ) ).
% map_tl
thf(fact_6402_list_Osel_I3_J,axiom,
! [A: $tType,X21: A,X222: list @ A] :
( ( tl @ A @ ( cons @ A @ X21 @ X222 ) )
= X222 ) ).
% list.sel(3)
thf(fact_6403_tl__Nil,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( tl @ A @ Xs )
= ( nil @ A ) )
= ( ( Xs
= ( nil @ A ) )
| ? [X2: A] :
( Xs
= ( cons @ A @ X2 @ ( nil @ A ) ) ) ) ) ).
% tl_Nil
thf(fact_6404_Nil__tl,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( nil @ A )
= ( tl @ A @ Xs ) )
= ( ( Xs
= ( nil @ A ) )
| ? [X2: A] :
( Xs
= ( cons @ A @ X2 @ ( nil @ A ) ) ) ) ) ).
% Nil_tl
thf(fact_6405_list_Osel_I2_J,axiom,
! [A: $tType] :
( ( tl @ A @ ( nil @ A ) )
= ( nil @ A ) ) ).
% list.sel(2)
thf(fact_6406_take__tl,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( take @ A @ N2 @ ( tl @ A @ Xs ) )
= ( tl @ A @ ( take @ A @ ( suc @ N2 ) @ Xs ) ) ) ).
% take_tl
thf(fact_6407_drop__Suc,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( drop @ A @ ( suc @ N2 ) @ Xs )
= ( drop @ A @ N2 @ ( tl @ A @ Xs ) ) ) ).
% drop_Suc
thf(fact_6408_tl__drop,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( tl @ A @ ( drop @ A @ N2 @ Xs ) )
= ( drop @ A @ N2 @ ( tl @ A @ Xs ) ) ) ).
% tl_drop
thf(fact_6409_distinct__tl,axiom,
! [A: $tType,Xs: list @ A] :
( ( distinct @ A @ Xs )
=> ( distinct @ A @ ( tl @ A @ Xs ) ) ) ).
% distinct_tl
thf(fact_6410_list_Oset__sel_I2_J,axiom,
! [A: $tType,A3: list @ A,X: A] :
( ( A3
!= ( nil @ A ) )
=> ( ( member2 @ A @ X @ ( set2 @ A @ ( tl @ A @ A3 ) ) )
=> ( member2 @ A @ X @ ( set2 @ A @ A3 ) ) ) ) ).
% list.set_sel(2)
thf(fact_6411_list_Oexpand,axiom,
! [A: $tType,List: list @ A,List3: list @ A] :
( ( ( List
= ( nil @ A ) )
= ( List3
= ( nil @ A ) ) )
=> ( ( ( List
!= ( nil @ A ) )
=> ( ( List3
!= ( nil @ A ) )
=> ( ( ( hd @ A @ List )
= ( hd @ A @ List3 ) )
& ( ( tl @ A @ List )
= ( tl @ A @ List3 ) ) ) ) )
=> ( List = List3 ) ) ) ).
% list.expand
thf(fact_6412_map__filter__simps_I2_J,axiom,
! [B: $tType,A: $tType,F2: B > ( option @ A )] :
( ( map_filter @ B @ A @ F2 @ ( nil @ B ) )
= ( nil @ A ) ) ).
% map_filter_simps(2)
thf(fact_6413_map__of__filter__in,axiom,
! [B: $tType,A: $tType,Xs: list @ ( product_prod @ B @ A ),K: B,Z: A,P2: B > A > $o] :
( ( ( map_of @ B @ A @ Xs @ K )
= ( some @ A @ Z ) )
=> ( ( P2 @ K @ Z )
=> ( ( map_of @ B @ A @ ( filter2 @ ( product_prod @ B @ A ) @ ( product_case_prod @ B @ A @ $o @ P2 ) @ Xs ) @ K )
= ( some @ A @ Z ) ) ) ) ).
% map_of_filter_in
thf(fact_6414_tl__def,axiom,
! [A: $tType] :
( ( tl @ A )
= ( case_list @ ( list @ A ) @ A @ ( nil @ A )
@ ^ [X213: A,X224: list @ A] : X224 ) ) ).
% tl_def
thf(fact_6415_tl__append,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( tl @ A @ ( append @ A @ Xs @ Ys ) )
= ( case_list @ ( list @ A ) @ A @ ( tl @ A @ Ys )
@ ^ [Z6: A,Zs3: list @ A] : ( append @ A @ Zs3 @ Ys )
@ Xs ) ) ).
% tl_append
thf(fact_6416_list_Oexhaust__sel,axiom,
! [A: $tType,List: list @ A] :
( ( List
!= ( nil @ A ) )
=> ( List
= ( cons @ A @ ( hd @ A @ List ) @ ( tl @ A @ List ) ) ) ) ).
% list.exhaust_sel
thf(fact_6417_map__filter__simps_I1_J,axiom,
! [A: $tType,B: $tType,F2: B > ( option @ A ),X: B,Xs: list @ B] :
( ( map_filter @ B @ A @ F2 @ ( cons @ B @ X @ Xs ) )
= ( case_option @ ( list @ A ) @ A @ ( map_filter @ B @ A @ F2 @ Xs )
@ ^ [Y2: A] : ( cons @ A @ Y2 @ ( map_filter @ B @ A @ F2 @ Xs ) )
@ ( F2 @ X ) ) ) ).
% map_filter_simps(1)
thf(fact_6418_tl__take,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( tl @ A @ ( take @ A @ N2 @ Xs ) )
= ( take @ A @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ ( tl @ A @ Xs ) ) ) ).
% tl_take
thf(fact_6419_list_Ocase__eq__if,axiom,
! [A: $tType,B: $tType] :
( ( case_list @ B @ A )
= ( ^ [F13: B,F23: A > ( list @ A ) > B,List2: list @ A] :
( if @ B
@ ( List2
= ( nil @ A ) )
@ F13
@ ( F23 @ ( hd @ A @ List2 ) @ ( tl @ A @ List2 ) ) ) ) ) ).
% list.case_eq_if
thf(fact_6420_Nitpick_Osize__list__simp_I2_J,axiom,
! [A: $tType] :
( ( size_size @ ( list @ A ) )
= ( ^ [Xs2: list @ A] :
( if @ nat
@ ( Xs2
= ( nil @ A ) )
@ ( zero_zero @ nat )
@ ( suc @ ( size_size @ ( list @ A ) @ ( tl @ A @ Xs2 ) ) ) ) ) ) ).
% Nitpick.size_list_simp(2)
thf(fact_6421_nth__tl,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ ( tl @ A @ Xs ) ) )
=> ( ( nth @ A @ ( tl @ A @ Xs ) @ N2 )
= ( nth @ A @ Xs @ ( suc @ N2 ) ) ) ) ).
% nth_tl
thf(fact_6422_remdups__adj__append,axiom,
! [A: $tType,Xs_1: list @ A,X: A,Xs_2: list @ A] :
( ( remdups_adj @ A @ ( append @ A @ Xs_1 @ ( cons @ A @ X @ Xs_2 ) ) )
= ( append @ A @ ( remdups_adj @ A @ ( append @ A @ Xs_1 @ ( cons @ A @ X @ ( nil @ A ) ) ) ) @ ( tl @ A @ ( remdups_adj @ A @ ( cons @ A @ X @ Xs_2 ) ) ) ) ) ).
% remdups_adj_append
thf(fact_6423_Cons__in__shuffles__iff,axiom,
! [A: $tType,Z: A,Zs: list @ A,Xs: list @ A,Ys: list @ A] :
( ( member2 @ ( list @ A ) @ ( cons @ A @ Z @ Zs ) @ ( shuffles @ A @ Xs @ Ys ) )
= ( ( ( Xs
!= ( nil @ A ) )
& ( ( hd @ A @ Xs )
= Z )
& ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ ( tl @ A @ Xs ) @ Ys ) ) )
| ( ( Ys
!= ( nil @ A ) )
& ( ( hd @ A @ Ys )
= Z )
& ( member2 @ ( list @ A ) @ Zs @ ( shuffles @ A @ Xs @ ( tl @ A @ Ys ) ) ) ) ) ) ).
% Cons_in_shuffles_iff
thf(fact_6424_list_Osplit__sel,axiom,
! [B: $tType,A: $tType,P2: B > $o,F1: B,F22: A > ( list @ A ) > B,List: list @ A] :
( ( P2 @ ( case_list @ B @ A @ F1 @ F22 @ List ) )
= ( ( ( List
= ( nil @ A ) )
=> ( P2 @ F1 ) )
& ( ( List
= ( cons @ A @ ( hd @ A @ List ) @ ( tl @ A @ List ) ) )
=> ( P2 @ ( F22 @ ( hd @ A @ List ) @ ( tl @ A @ List ) ) ) ) ) ) ).
% list.split_sel
thf(fact_6425_list_Osplit__sel__asm,axiom,
! [B: $tType,A: $tType,P2: B > $o,F1: B,F22: A > ( list @ A ) > B,List: list @ A] :
( ( P2 @ ( case_list @ B @ A @ F1 @ F22 @ List ) )
= ( ~ ( ( ( List
= ( nil @ A ) )
& ~ ( P2 @ F1 ) )
| ( ( List
= ( cons @ A @ ( hd @ A @ List ) @ ( tl @ A @ List ) ) )
& ~ ( P2 @ ( F22 @ ( hd @ A @ List ) @ ( tl @ A @ List ) ) ) ) ) ) ) ).
% list.split_sel_asm
thf(fact_6426_nths__shift__lemma__Suc,axiom,
! [A: $tType,P2: nat > $o,Xs: list @ A,Is: list @ nat] :
( ( map @ ( product_prod @ A @ nat ) @ A @ ( product_fst @ A @ nat )
@ ( filter2 @ ( product_prod @ A @ nat )
@ ^ [P6: product_prod @ A @ nat] : ( P2 @ ( suc @ ( product_snd @ A @ nat @ P6 ) ) )
@ ( zip @ A @ nat @ Xs @ Is ) ) )
= ( map @ ( product_prod @ A @ nat ) @ A @ ( product_fst @ A @ nat )
@ ( filter2 @ ( product_prod @ A @ nat )
@ ^ [P6: product_prod @ A @ nat] : ( P2 @ ( product_snd @ A @ nat @ P6 ) )
@ ( zip @ A @ nat @ Xs @ ( map @ nat @ nat @ suc @ Is ) ) ) ) ) ).
% nths_shift_lemma_Suc
thf(fact_6427_take__Suc,axiom,
! [A: $tType,Xs: list @ A,N2: nat] :
( ( Xs
!= ( nil @ A ) )
=> ( ( take @ A @ ( suc @ N2 ) @ Xs )
= ( cons @ A @ ( hd @ A @ Xs ) @ ( take @ A @ N2 @ ( tl @ A @ Xs ) ) ) ) ) ).
% take_Suc
thf(fact_6428_rotate1__hd__tl,axiom,
! [A: $tType,Xs: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( rotate1 @ A @ Xs )
= ( append @ A @ ( tl @ A @ Xs ) @ ( cons @ A @ ( hd @ A @ Xs ) @ ( nil @ A ) ) ) ) ) ).
% rotate1_hd_tl
thf(fact_6429_nths__shift__lemma,axiom,
! [A: $tType,A4: set @ nat,Xs: list @ A,I: nat] :
( ( map @ ( product_prod @ A @ nat ) @ A @ ( product_fst @ A @ nat )
@ ( filter2 @ ( product_prod @ A @ nat )
@ ^ [P6: product_prod @ A @ nat] : ( member2 @ nat @ ( product_snd @ A @ nat @ P6 ) @ A4 )
@ ( zip @ A @ nat @ Xs @ ( upt @ I @ ( plus_plus @ nat @ I @ ( size_size @ ( list @ A ) @ Xs ) ) ) ) ) )
= ( map @ ( product_prod @ A @ nat ) @ A @ ( product_fst @ A @ nat )
@ ( filter2 @ ( product_prod @ A @ nat )
@ ^ [P6: product_prod @ A @ nat] : ( member2 @ nat @ ( plus_plus @ nat @ ( product_snd @ A @ nat @ P6 ) @ I ) @ A4 )
@ ( zip @ A @ nat @ Xs @ ( upt @ ( zero_zero @ nat ) @ ( size_size @ ( list @ A ) @ Xs ) ) ) ) ) ) ).
% nths_shift_lemma
thf(fact_6430_Nitpick_Osize__list__simp_I1_J,axiom,
! [A: $tType] :
( ( size_list @ A )
= ( ^ [F3: A > nat,Xs2: list @ A] :
( if @ nat
@ ( Xs2
= ( nil @ A ) )
@ ( zero_zero @ nat )
@ ( suc @ ( plus_plus @ nat @ ( F3 @ ( hd @ A @ Xs2 ) ) @ ( size_list @ A @ F3 @ ( tl @ A @ Xs2 ) ) ) ) ) ) ) ).
% Nitpick.size_list_simp(1)
thf(fact_6431_nths__def,axiom,
! [A: $tType] :
( ( nths @ A )
= ( ^ [Xs2: list @ A,A6: set @ nat] :
( map @ ( product_prod @ A @ nat ) @ A @ ( product_fst @ A @ nat )
@ ( filter2 @ ( product_prod @ A @ nat )
@ ^ [P6: product_prod @ A @ nat] : ( member2 @ nat @ ( product_snd @ A @ nat @ P6 ) @ A6 )
@ ( zip @ A @ nat @ Xs2 @ ( upt @ ( zero_zero @ nat ) @ ( size_size @ ( list @ A ) @ Xs2 ) ) ) ) ) ) ) ).
% nths_def
thf(fact_6432_map__filter__map__filter,axiom,
! [A: $tType,B: $tType,F2: B > A,P2: B > $o,Xs: list @ B] :
( ( map @ B @ A @ F2 @ ( filter2 @ B @ P2 @ Xs ) )
= ( map_filter @ B @ A
@ ^ [X2: B] : ( if @ ( option @ A ) @ ( P2 @ X2 ) @ ( some @ A @ ( F2 @ X2 ) ) @ ( none @ A ) )
@ Xs ) ) ).
% map_filter_map_filter
thf(fact_6433_transpose__max__length,axiom,
! [A: $tType,Xs: list @ ( list @ A )] :
( ( foldr @ ( list @ A ) @ nat
@ ^ [Xs2: list @ A] : ( ord_max @ nat @ ( size_size @ ( list @ A ) @ Xs2 ) )
@ ( transpose @ A @ Xs )
@ ( zero_zero @ nat ) )
= ( size_size @ ( list @ ( list @ A ) )
@ ( filter2 @ ( list @ A )
@ ^ [X2: list @ A] :
( X2
!= ( nil @ A ) )
@ Xs ) ) ) ).
% transpose_max_length
thf(fact_6434_transpose__aux__max,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Xss: list @ ( list @ B )] :
( ( ord_max @ nat @ ( suc @ ( size_size @ ( list @ A ) @ Xs ) )
@ ( foldr @ ( list @ B ) @ nat
@ ^ [Xs2: list @ B] : ( ord_max @ nat @ ( size_size @ ( list @ B ) @ Xs2 ) )
@ Xss
@ ( zero_zero @ nat ) ) )
= ( suc
@ ( ord_max @ nat @ ( size_size @ ( list @ A ) @ Xs )
@ ( foldr @ ( list @ B ) @ nat
@ ^ [X2: list @ B] : ( ord_max @ nat @ ( minus_minus @ nat @ ( size_size @ ( list @ B ) @ X2 ) @ ( suc @ ( zero_zero @ nat ) ) ) )
@ ( filter2 @ ( list @ B )
@ ^ [Ys3: list @ B] :
( Ys3
!= ( nil @ B ) )
@ Xss )
@ ( zero_zero @ nat ) ) ) ) ) ).
% transpose_aux_max
thf(fact_6435_foldr__append,axiom,
! [B: $tType,A: $tType,F2: B > A > A,Xs: list @ B,Ys: list @ B,A3: A] :
( ( foldr @ B @ A @ F2 @ ( append @ B @ Xs @ Ys ) @ A3 )
= ( foldr @ B @ A @ F2 @ Xs @ ( foldr @ B @ A @ F2 @ Ys @ A3 ) ) ) ).
% foldr_append
thf(fact_6436_foldr__replicate,axiom,
! [A: $tType,B: $tType,F2: B > A > A,N2: nat,X: B] :
( ( foldr @ B @ A @ F2 @ ( replicate @ B @ N2 @ X ) )
= ( compow @ ( A > A ) @ N2 @ ( F2 @ X ) ) ) ).
% foldr_replicate
thf(fact_6437_foldr__cong,axiom,
! [B: $tType,A: $tType,A3: A,B2: A,L: list @ B,K: list @ B,F2: B > A > A,G: B > A > A] :
( ( A3 = B2 )
=> ( ( L = K )
=> ( ! [A7: A,X5: B] :
( ( member2 @ B @ X5 @ ( set2 @ B @ L ) )
=> ( ( F2 @ X5 @ A7 )
= ( G @ X5 @ A7 ) ) )
=> ( ( foldr @ B @ A @ F2 @ L @ A3 )
= ( foldr @ B @ A @ G @ K @ B2 ) ) ) ) ) ).
% foldr_cong
thf(fact_6438_foldr__Cons,axiom,
! [B: $tType,A: $tType,F2: A > B > B,X: A,Xs: list @ A] :
( ( foldr @ A @ B @ F2 @ ( cons @ A @ X @ Xs ) )
= ( comp @ B @ B @ B @ ( F2 @ X ) @ ( foldr @ A @ B @ F2 @ Xs ) ) ) ).
% foldr_Cons
thf(fact_6439_foldr__Nil,axiom,
! [A: $tType,B: $tType,F2: A > B > B] :
( ( foldr @ A @ B @ F2 @ ( nil @ A ) )
= ( id @ B ) ) ).
% foldr_Nil
thf(fact_6440_foldr__map,axiom,
! [C: $tType,B: $tType,A: $tType,G: B > A > A,F2: C > B,Xs: list @ C,A3: A] :
( ( foldr @ B @ A @ G @ ( map @ C @ B @ F2 @ Xs ) @ A3 )
= ( foldr @ C @ A @ ( comp @ B @ ( A > A ) @ C @ G @ F2 ) @ Xs @ A3 ) ) ).
% foldr_map
thf(fact_6441_foldr__filter,axiom,
! [A: $tType,B: $tType,F2: B > A > A,P2: B > $o,Xs: list @ B] :
( ( foldr @ B @ A @ F2 @ ( filter2 @ B @ P2 @ Xs ) )
= ( foldr @ B @ A
@ ^ [X2: B] : ( if @ ( A > A ) @ ( P2 @ X2 ) @ ( F2 @ X2 ) @ ( id @ A ) )
@ Xs ) ) ).
% foldr_filter
thf(fact_6442_sum__list_Oeq__foldr,axiom,
! [A: $tType] :
( ( monoid_add @ A )
=> ( ( groups8242544230860333062m_list @ A )
= ( ^ [Xs2: list @ A] : ( foldr @ A @ A @ ( plus_plus @ A ) @ Xs2 @ ( zero_zero @ A ) ) ) ) ) ).
% sum_list.eq_foldr
thf(fact_6443_horner__sum__foldr,axiom,
! [A: $tType,B: $tType] :
( ( comm_semiring_0 @ A )
=> ( ( groups4207007520872428315er_sum @ B @ A )
= ( ^ [F3: B > A,A5: A,Xs2: list @ B] :
( foldr @ B @ A
@ ^ [X2: B,B4: A] : ( plus_plus @ A @ ( F3 @ X2 ) @ ( times_times @ A @ A5 @ B4 ) )
@ Xs2
@ ( zero_zero @ A ) ) ) ) ) ).
% horner_sum_foldr
thf(fact_6444_length__transpose,axiom,
! [A: $tType,Xs: list @ ( list @ A )] :
( ( size_size @ ( list @ ( list @ A ) ) @ ( transpose @ A @ Xs ) )
= ( foldr @ ( list @ A ) @ nat
@ ^ [Xs2: list @ A] : ( ord_max @ nat @ ( size_size @ ( list @ A ) @ Xs2 ) )
@ Xs
@ ( zero_zero @ nat ) ) ) ).
% length_transpose
thf(fact_6445_sorted__wrt__less__sum__mono__lowerbound,axiom,
! [B: $tType] :
( ( ordere6911136660526730532id_add @ B )
=> ! [F2: nat > B,Ns: list @ nat] :
( ! [X5: nat,Y4: nat] :
( ( ord_less_eq @ nat @ X5 @ Y4 )
=> ( ord_less_eq @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( ( sorted_wrt @ nat @ ( ord_less @ nat ) @ Ns )
=> ( ord_less_eq @ B @ ( groups7311177749621191930dd_sum @ nat @ B @ F2 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( size_size @ ( list @ nat ) @ Ns ) ) ) @ ( groups8242544230860333062m_list @ B @ ( map @ nat @ B @ F2 @ Ns ) ) ) ) ) ) ).
% sorted_wrt_less_sum_mono_lowerbound
thf(fact_6446_refl__on__domain,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( refl_on @ A @ A4 @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ( member2 @ A @ A3 @ A4 )
& ( member2 @ A @ B2 @ A4 ) ) ) ) ).
% refl_on_domain
thf(fact_6447_sorted__wrt__filter,axiom,
! [A: $tType,F2: A > A > $o,Xs: list @ A,P2: A > $o] :
( ( sorted_wrt @ A @ F2 @ Xs )
=> ( sorted_wrt @ A @ F2 @ ( filter2 @ A @ P2 @ Xs ) ) ) ).
% sorted_wrt_filter
thf(fact_6448_sorted__same,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [G: ( list @ A ) > A,Xs: list @ A] :
( sorted_wrt @ A @ ( ord_less_eq @ A )
@ ( filter2 @ A
@ ^ [X2: A] :
( X2
= ( G @ Xs ) )
@ Xs ) ) ) ).
% sorted_same
thf(fact_6449_sorted__tl,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( tl @ A @ Xs ) ) ) ) ).
% sorted_tl
thf(fact_6450_sorted__wrt__map,axiom,
! [A: $tType,B: $tType,R: A > A > $o,F2: B > A,Xs: list @ B] :
( ( sorted_wrt @ A @ R @ ( map @ B @ A @ F2 @ Xs ) )
= ( sorted_wrt @ B
@ ^ [X2: B,Y2: B] : ( R @ ( F2 @ X2 ) @ ( F2 @ Y2 ) )
@ Xs ) ) ).
% sorted_wrt_map
thf(fact_6451_sorted__map,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ Xs ) )
= ( sorted_wrt @ B
@ ^ [X2: B,Y2: B] : ( ord_less_eq @ A @ ( F2 @ X2 ) @ ( F2 @ Y2 ) )
@ Xs ) ) ) ).
% sorted_map
thf(fact_6452_sorted__wrt__upt,axiom,
! [M: nat,N2: nat] : ( sorted_wrt @ nat @ ( ord_less @ nat ) @ ( upt @ M @ N2 ) ) ).
% sorted_wrt_upt
thf(fact_6453_sorted__upt,axiom,
! [M: nat,N2: nat] : ( sorted_wrt @ nat @ ( ord_less_eq @ nat ) @ ( upt @ M @ N2 ) ) ).
% sorted_upt
thf(fact_6454_strict__sorted__imp__sorted,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs ) ) ) ).
% strict_sorted_imp_sorted
thf(fact_6455_sorted__nths,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,I6: set @ nat] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( nths @ A @ Xs @ I6 ) ) ) ) ).
% sorted_nths
thf(fact_6456_sorted__remove1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,A3: A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( remove1 @ A @ A3 @ Xs ) ) ) ) ).
% sorted_remove1
thf(fact_6457_sorted__list__of__set_Osorted__sorted__key__list__of__set,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] : ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( linord4507533701916653071of_set @ A @ A4 ) ) ) ).
% sorted_list_of_set.sorted_sorted_key_list_of_set
thf(fact_6458_sorted__remdups__adj,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( remdups_adj @ A @ Xs ) ) ) ) ).
% sorted_remdups_adj
thf(fact_6459_sorted__replicate,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [N2: nat,X: A] : ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( replicate @ A @ N2 @ X ) ) ) ).
% sorted_replicate
thf(fact_6460_sorted__insort,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A )
@ ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ X
@ Xs ) )
= ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs ) ) ) ).
% sorted_insort
thf(fact_6461_sorted__wrt__true,axiom,
! [A: $tType,Xs: list @ A] :
( sorted_wrt @ A
@ ^ [Uu3: A,Uv3: A] : $true
@ Xs ) ).
% sorted_wrt_true
thf(fact_6462_sorted__list__of__set_Ostrict__sorted__key__list__of__set,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] : ( sorted_wrt @ A @ ( ord_less @ A ) @ ( linord4507533701916653071of_set @ A @ A4 ) ) ) ).
% sorted_list_of_set.strict_sorted_key_list_of_set
thf(fact_6463_sorted2,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Y: A,Zs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( cons @ A @ X @ ( cons @ A @ Y @ Zs ) ) )
= ( ( ord_less_eq @ A @ X @ Y )
& ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( cons @ A @ Y @ Zs ) ) ) ) ) ).
% sorted2
thf(fact_6464_sorted__wrt1,axiom,
! [A: $tType,P2: A > A > $o,X: A] : ( sorted_wrt @ A @ P2 @ ( cons @ A @ X @ ( nil @ A ) ) ) ).
% sorted_wrt1
thf(fact_6465_sorted0,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( nil @ A ) ) ) ).
% sorted0
thf(fact_6466_strict__sorted__simps_I1_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( sorted_wrt @ A @ ( ord_less @ A ) @ ( nil @ A ) ) ) ).
% strict_sorted_simps(1)
thf(fact_6467_sorted__wrt_Osimps_I1_J,axiom,
! [A: $tType,P2: A > A > $o] : ( sorted_wrt @ A @ P2 @ ( nil @ A ) ) ).
% sorted_wrt.simps(1)
thf(fact_6468_sorted__wrt__take,axiom,
! [A: $tType,F2: A > A > $o,Xs: list @ A,N2: nat] :
( ( sorted_wrt @ A @ F2 @ Xs )
=> ( sorted_wrt @ A @ F2 @ ( take @ A @ N2 @ Xs ) ) ) ).
% sorted_wrt_take
thf(fact_6469_sorted__take,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,N2: nat] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( take @ A @ N2 @ Xs ) ) ) ) ).
% sorted_take
thf(fact_6470_sorted__remdups,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( remdups @ A @ Xs ) ) ) ) ).
% sorted_remdups
thf(fact_6471_sorted__wrt__drop,axiom,
! [A: $tType,F2: A > A > $o,Xs: list @ A,N2: nat] :
( ( sorted_wrt @ A @ F2 @ Xs )
=> ( sorted_wrt @ A @ F2 @ ( drop @ A @ N2 @ Xs ) ) ) ).
% sorted_wrt_drop
thf(fact_6472_sorted__drop,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,N2: nat] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( drop @ A @ N2 @ Xs ) ) ) ) ).
% sorted_drop
thf(fact_6473_strict__sorted__equal,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,Ys: list @ A] :
( ( sorted_wrt @ A @ ( ord_less @ A ) @ Xs )
=> ( ( sorted_wrt @ A @ ( ord_less @ A ) @ Ys )
=> ( ( ( set2 @ A @ Ys )
= ( set2 @ A @ Xs ) )
=> ( Ys = Xs ) ) ) ) ) ).
% strict_sorted_equal
thf(fact_6474_sorted__wrt__mono__rel,axiom,
! [A: $tType,Xs: list @ A,P2: A > A > $o,Q: A > A > $o] :
( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( member2 @ A @ Y4 @ ( set2 @ A @ Xs ) )
=> ( ( P2 @ X5 @ Y4 )
=> ( Q @ X5 @ Y4 ) ) ) )
=> ( ( sorted_wrt @ A @ P2 @ Xs )
=> ( sorted_wrt @ A @ Q @ Xs ) ) ) ).
% sorted_wrt_mono_rel
thf(fact_6475_sorted__wrt__append,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A,Ys: list @ A] :
( ( sorted_wrt @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( ( sorted_wrt @ A @ P2 @ Xs )
& ( sorted_wrt @ A @ P2 @ Ys )
& ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ! [Y2: A] :
( ( member2 @ A @ Y2 @ ( set2 @ A @ Ys ) )
=> ( P2 @ X2 @ Y2 ) ) ) ) ) ).
% sorted_wrt_append
thf(fact_6476_sorted1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A] : ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( cons @ A @ X @ ( nil @ A ) ) ) ) ).
% sorted1
thf(fact_6477_sorted__simps_I2_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Ys: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( cons @ A @ X @ Ys ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Ys ) )
=> ( ord_less_eq @ A @ X @ X2 ) )
& ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Ys ) ) ) ) ).
% sorted_simps(2)
thf(fact_6478_strict__sorted__simps_I2_J,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Ys: list @ A] :
( ( sorted_wrt @ A @ ( ord_less @ A ) @ ( cons @ A @ X @ Ys ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Ys ) )
=> ( ord_less @ A @ X @ X2 ) )
& ( sorted_wrt @ A @ ( ord_less @ A ) @ Ys ) ) ) ) ).
% strict_sorted_simps(2)
thf(fact_6479_strict__sorted__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [L: list @ A] :
( ( sorted_wrt @ A @ ( ord_less @ A ) @ L )
= ( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ L )
& ( distinct @ A @ L ) ) ) ) ).
% strict_sorted_iff
thf(fact_6480_sorted__append,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,Ys: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( append @ A @ Xs @ Ys ) )
= ( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
& ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Ys )
& ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ! [Y2: A] :
( ( member2 @ A @ Y2 @ ( set2 @ A @ Ys ) )
=> ( ord_less_eq @ A @ X2 @ Y2 ) ) ) ) ) ) ).
% sorted_append
thf(fact_6481_sorted__wrt_Oelims_I3_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A] :
( ~ ( sorted_wrt @ A @ X @ Xa2 )
=> ~ ! [X5: A,Ys4: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ Ys4 ) )
=> ( ! [Xa4: A] :
( ( member2 @ A @ Xa4 @ ( set2 @ A @ Ys4 ) )
=> ( X @ X5 @ Xa4 ) )
& ( sorted_wrt @ A @ X @ Ys4 ) ) ) ) ).
% sorted_wrt.elims(3)
thf(fact_6482_sorted__wrt_Osimps_I2_J,axiom,
! [A: $tType,P2: A > A > $o,X: A,Ys: list @ A] :
( ( sorted_wrt @ A @ P2 @ ( cons @ A @ X @ Ys ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Ys ) )
=> ( P2 @ X @ X2 ) )
& ( sorted_wrt @ A @ P2 @ Ys ) ) ) ).
% sorted_wrt.simps(2)
thf(fact_6483_sorted__distinct__set__unique,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,Ys: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( ( distinct @ A @ Xs )
=> ( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Ys )
=> ( ( distinct @ A @ Ys )
=> ( ( ( set2 @ A @ Xs )
= ( set2 @ A @ Ys ) )
=> ( Xs = Ys ) ) ) ) ) ) ) ).
% sorted_distinct_set_unique
thf(fact_6484_sorted__wrt__iff__nth__less,axiom,
! [A: $tType] :
( ( sorted_wrt @ A )
= ( ^ [P: A > A > $o,Xs2: list @ A] :
! [I5: nat,J3: nat] :
( ( ord_less @ nat @ I5 @ J3 )
=> ( ( ord_less @ nat @ J3 @ ( size_size @ ( list @ A ) @ Xs2 ) )
=> ( P @ ( nth @ A @ Xs2 @ I5 ) @ ( nth @ A @ Xs2 @ J3 ) ) ) ) ) ) ).
% sorted_wrt_iff_nth_less
thf(fact_6485_sorted__wrt__nth__less,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A,I: nat,J: nat] :
( ( sorted_wrt @ A @ P2 @ Xs )
=> ( ( ord_less @ nat @ I @ J )
=> ( ( ord_less @ nat @ J @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( P2 @ ( nth @ A @ Xs @ I ) @ ( nth @ A @ Xs @ J ) ) ) ) ) ).
% sorted_wrt_nth_less
thf(fact_6486_sorted__wrt01,axiom,
! [A: $tType,Xs: list @ A,P2: A > A > $o] :
( ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) )
=> ( sorted_wrt @ A @ P2 @ Xs ) ) ).
% sorted_wrt01
thf(fact_6487_sorted__filter,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B,P2: B > $o] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ Xs ) )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ ( filter2 @ B @ P2 @ Xs ) ) ) ) ) ).
% sorted_filter
thf(fact_6488_sorted__insort__key,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,X: B,Xs: list @ B] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ ( linorder_insort_key @ B @ A @ F2 @ X @ Xs ) ) )
= ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ Xs ) ) ) ) ).
% sorted_insort_key
thf(fact_6489_sorted__map__remove1,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B,X: B] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ Xs ) )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ ( remove1 @ B @ X @ Xs ) ) ) ) ) ).
% sorted_map_remove1
thf(fact_6490_sorted__map__same,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,G: ( list @ B ) > A,Xs: list @ B] :
( sorted_wrt @ A @ ( ord_less_eq @ A )
@ ( map @ B @ A @ F2
@ ( filter2 @ B
@ ^ [X2: B] :
( ( F2 @ X2 )
= ( G @ Xs ) )
@ Xs ) ) ) ) ).
% sorted_map_same
thf(fact_6491_sorted__iff__nth__mono__less,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
= ( ! [I5: nat,J3: nat] :
( ( ord_less @ nat @ I5 @ J3 )
=> ( ( ord_less @ nat @ J3 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ord_less_eq @ A @ ( nth @ A @ Xs @ I5 ) @ ( nth @ A @ Xs @ J3 ) ) ) ) ) ) ) ).
% sorted_iff_nth_mono_less
thf(fact_6492_sorted01,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs ) ) ) ).
% sorted01
thf(fact_6493_sorted__wrt_Oelims_I1_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A,Y: $o] :
( ( ( sorted_wrt @ A @ X @ Xa2 )
= Y )
=> ( ( ( Xa2
= ( nil @ A ) )
=> ~ Y )
=> ~ ! [X5: A,Ys4: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ Ys4 ) )
=> ( Y
= ( ~ ( ! [Y2: A] :
( ( member2 @ A @ Y2 @ ( set2 @ A @ Ys4 ) )
=> ( X @ X5 @ Y2 ) )
& ( sorted_wrt @ A @ X @ Ys4 ) ) ) ) ) ) ) ).
% sorted_wrt.elims(1)
thf(fact_6494_sorted__wrt_Oelims_I2_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A] :
( ( sorted_wrt @ A @ X @ Xa2 )
=> ( ( Xa2
!= ( nil @ A ) )
=> ~ ! [X5: A,Ys4: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ Ys4 ) )
=> ~ ( ! [Xa: A] :
( ( member2 @ A @ Xa @ ( set2 @ A @ Ys4 ) )
=> ( X @ X5 @ Xa ) )
& ( sorted_wrt @ A @ X @ Ys4 ) ) ) ) ) ).
% sorted_wrt.elims(2)
thf(fact_6495_finite__sorted__distinct__unique,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ? [X5: list @ A] :
( ( ( set2 @ A @ X5 )
= A4 )
& ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ X5 )
& ( distinct @ A @ X5 )
& ! [Y3: list @ A] :
( ( ( ( set2 @ A @ Y3 )
= A4 )
& ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Y3 )
& ( distinct @ A @ Y3 ) )
=> ( Y3 = X5 ) ) ) ) ) ).
% finite_sorted_distinct_unique
thf(fact_6496_sorted__list__of__set_Oidem__if__sorted__distinct,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( ( distinct @ A @ Xs )
=> ( ( linord4507533701916653071of_set @ A @ ( set2 @ A @ Xs ) )
= Xs ) ) ) ) ).
% sorted_list_of_set.idem_if_sorted_distinct
thf(fact_6497_filter__insort,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B,P2: B > $o,X: B] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ Xs ) )
=> ( ( P2 @ X )
=> ( ( filter2 @ B @ P2 @ ( linorder_insort_key @ B @ A @ F2 @ X @ Xs ) )
= ( linorder_insort_key @ B @ A @ F2 @ X @ ( filter2 @ B @ P2 @ Xs ) ) ) ) ) ) ).
% filter_insort
thf(fact_6498_concat__conv__foldr,axiom,
! [A: $tType] :
( ( concat @ A )
= ( ^ [Xss3: list @ ( list @ A )] : ( foldr @ ( list @ A ) @ ( list @ A ) @ ( append @ A ) @ Xss3 @ ( nil @ A ) ) ) ) ).
% concat_conv_foldr
thf(fact_6499_insort__remove1,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A3: A,Xs: list @ A] :
( ( member2 @ A @ A3 @ ( set2 @ A @ Xs ) )
=> ( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ A3
@ ( remove1 @ A @ A3 @ Xs ) )
= Xs ) ) ) ) ).
% insort_remove1
thf(fact_6500_sorted__iff__nth__Suc,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
= ( ! [I5: nat] :
( ( ord_less @ nat @ ( suc @ I5 ) @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ord_less_eq @ A @ ( nth @ A @ Xs @ I5 ) @ ( nth @ A @ Xs @ ( suc @ I5 ) ) ) ) ) ) ) ).
% sorted_iff_nth_Suc
thf(fact_6501_sorted__list__of__set_Ofinite__set__strict__sorted,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ~ ! [L4: list @ A] :
( ( sorted_wrt @ A @ ( ord_less @ A ) @ L4 )
=> ( ( ( set2 @ A @ L4 )
= A4 )
=> ( ( size_size @ ( list @ A ) @ L4 )
!= ( finite_card @ A @ A4 ) ) ) ) ) ) ).
% sorted_list_of_set.finite_set_strict_sorted
thf(fact_6502_sorted__iff__nth__mono,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
= ( ! [I5: nat,J3: nat] :
( ( ord_less_eq @ nat @ I5 @ J3 )
=> ( ( ord_less @ nat @ J3 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ord_less_eq @ A @ ( nth @ A @ Xs @ I5 ) @ ( nth @ A @ Xs @ J3 ) ) ) ) ) ) ) ).
% sorted_iff_nth_mono
thf(fact_6503_sorted__nth__mono,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,I: nat,J: nat] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( ( ord_less_eq @ nat @ I @ J )
=> ( ( ord_less @ nat @ J @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ord_less_eq @ A @ ( nth @ A @ Xs @ I ) @ ( nth @ A @ Xs @ J ) ) ) ) ) ) ).
% sorted_nth_mono
thf(fact_6504_sorted__wrt__less__idx,axiom,
! [Ns: list @ nat,I: nat] :
( ( sorted_wrt @ nat @ ( ord_less @ nat ) @ Ns )
=> ( ( ord_less @ nat @ I @ ( size_size @ ( list @ nat ) @ Ns ) )
=> ( ord_less_eq @ nat @ I @ ( nth @ nat @ Ns @ I ) ) ) ) ).
% sorted_wrt_less_idx
thf(fact_6505_sorted__find__Min,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,P2: A > $o] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( ? [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Xs ) )
& ( P2 @ X3 ) )
=> ( ( find @ A @ P2 @ Xs )
= ( some @ A
@ ( lattic643756798350308766er_Min @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
& ( P2 @ X2 ) ) ) ) ) ) ) ) ) ).
% sorted_find_Min
thf(fact_6506_sorted__enumerate,axiom,
! [A: $tType,N2: nat,Xs: list @ A] : ( sorted_wrt @ nat @ ( ord_less_eq @ nat ) @ ( map @ ( product_prod @ nat @ A ) @ nat @ ( product_fst @ nat @ A ) @ ( enumerate @ A @ N2 @ Xs ) ) ) ).
% sorted_enumerate
thf(fact_6507_map__sorted__distinct__set__unique,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B,Ys: list @ B] :
( ( inj_on @ B @ A @ F2 @ ( sup_sup @ ( set @ B ) @ ( set2 @ B @ Xs ) @ ( set2 @ B @ Ys ) ) )
=> ( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ Xs ) )
=> ( ( distinct @ A @ ( map @ B @ A @ F2 @ Xs ) )
=> ( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ Ys ) )
=> ( ( distinct @ A @ ( map @ B @ A @ F2 @ Ys ) )
=> ( ( ( set2 @ B @ Xs )
= ( set2 @ B @ Ys ) )
=> ( Xs = Ys ) ) ) ) ) ) ) ) ).
% map_sorted_distinct_set_unique
thf(fact_6508_sorted__list__of__set_Osorted__key__list__of__set__unique,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A,L: list @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( ( sorted_wrt @ A @ ( ord_less @ A ) @ L )
& ( ( set2 @ A @ L )
= A4 )
& ( ( size_size @ ( list @ A ) @ L )
= ( finite_card @ A @ A4 ) ) )
= ( ( linord4507533701916653071of_set @ A @ A4 )
= L ) ) ) ) ).
% sorted_list_of_set.sorted_key_list_of_set_unique
thf(fact_6509_sorted__insort__is__snoc,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,A3: A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ord_less_eq @ A @ X5 @ A3 ) )
=> ( ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ A3
@ Xs )
= ( append @ A @ Xs @ ( cons @ A @ A3 @ ( nil @ A ) ) ) ) ) ) ) ).
% sorted_insort_is_snoc
thf(fact_6510_insort__key__remove1,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [A3: B,Xs: list @ B,F2: B > A] :
( ( member2 @ B @ A3 @ ( set2 @ B @ Xs ) )
=> ( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ Xs ) )
=> ( ( ( hd @ B
@ ( filter2 @ B
@ ^ [X2: B] :
( ( F2 @ A3 )
= ( F2 @ X2 ) )
@ Xs ) )
= A3 )
=> ( ( linorder_insort_key @ B @ A @ F2 @ A3 @ ( remove1 @ B @ A3 @ Xs ) )
= Xs ) ) ) ) ) ).
% insort_key_remove1
thf(fact_6511_nth__nth__transpose__sorted,axiom,
! [A: $tType,Xs: list @ ( list @ A ),I: nat,J: nat] :
( ( sorted_wrt @ nat @ ( ord_less_eq @ nat ) @ ( rev @ nat @ ( map @ ( list @ A ) @ nat @ ( size_size @ ( list @ A ) ) @ Xs ) ) )
=> ( ( ord_less @ nat @ I @ ( size_size @ ( list @ ( list @ A ) ) @ ( transpose @ A @ Xs ) ) )
=> ( ( ord_less @ nat @ J
@ ( size_size @ ( list @ ( list @ A ) )
@ ( filter2 @ ( list @ A )
@ ^ [Ys3: list @ A] : ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Ys3 ) )
@ Xs ) ) )
=> ( ( nth @ A @ ( nth @ ( list @ A ) @ ( transpose @ A @ Xs ) @ I ) @ J )
= ( nth @ A @ ( nth @ ( list @ A ) @ Xs @ J ) @ I ) ) ) ) ) ).
% nth_nth_transpose_sorted
thf(fact_6512_transpose__column,axiom,
! [A: $tType,Xs: list @ ( list @ A ),I: nat] :
( ( sorted_wrt @ nat @ ( ord_less_eq @ nat ) @ ( rev @ nat @ ( map @ ( list @ A ) @ nat @ ( size_size @ ( list @ A ) ) @ Xs ) ) )
=> ( ( ord_less @ nat @ I @ ( size_size @ ( list @ ( list @ A ) ) @ Xs ) )
=> ( ( map @ ( list @ A ) @ A
@ ^ [Ys3: list @ A] : ( nth @ A @ Ys3 @ I )
@ ( filter2 @ ( list @ A )
@ ^ [Ys3: list @ A] : ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Ys3 ) )
@ ( transpose @ A @ Xs ) ) )
= ( nth @ ( list @ A ) @ Xs @ I ) ) ) ) ).
% transpose_column
thf(fact_6513_rev__rev__ident,axiom,
! [A: $tType,Xs: list @ A] :
( ( rev @ A @ ( rev @ A @ Xs ) )
= Xs ) ).
% rev_rev_ident
thf(fact_6514_rev__is__rev__conv,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( rev @ A @ Xs )
= ( rev @ A @ Ys ) )
= ( Xs = Ys ) ) ).
% rev_is_rev_conv
thf(fact_6515_rev__is__Nil__conv,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( rev @ A @ Xs )
= ( nil @ A ) )
= ( Xs
= ( nil @ A ) ) ) ).
% rev_is_Nil_conv
thf(fact_6516_Nil__is__rev__conv,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( nil @ A )
= ( rev @ A @ Xs ) )
= ( Xs
= ( nil @ A ) ) ) ).
% Nil_is_rev_conv
thf(fact_6517_set__rev,axiom,
! [A: $tType,Xs: list @ A] :
( ( set2 @ A @ ( rev @ A @ Xs ) )
= ( set2 @ A @ Xs ) ) ).
% set_rev
thf(fact_6518_length__rev,axiom,
! [A: $tType,Xs: list @ A] :
( ( size_size @ ( list @ A ) @ ( rev @ A @ Xs ) )
= ( size_size @ ( list @ A ) @ Xs ) ) ).
% length_rev
thf(fact_6519_rev__append,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( rev @ A @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ ( rev @ A @ Ys ) @ ( rev @ A @ Xs ) ) ) ).
% rev_append
thf(fact_6520_distinct__rev,axiom,
! [A: $tType,Xs: list @ A] :
( ( distinct @ A @ ( rev @ A @ Xs ) )
= ( distinct @ A @ Xs ) ) ).
% distinct_rev
thf(fact_6521_rev__replicate,axiom,
! [A: $tType,N2: nat,X: A] :
( ( rev @ A @ ( replicate @ A @ N2 @ X ) )
= ( replicate @ A @ N2 @ X ) ) ).
% rev_replicate
thf(fact_6522_remdups__adj__rev,axiom,
! [A: $tType,Xs: list @ A] :
( ( remdups_adj @ A @ ( rev @ A @ Xs ) )
= ( rev @ A @ ( remdups_adj @ A @ Xs ) ) ) ).
% remdups_adj_rev
thf(fact_6523_inj__on__rev,axiom,
! [A: $tType,A4: set @ ( list @ A )] : ( inj_on @ ( list @ A ) @ ( list @ A ) @ ( rev @ A ) @ A4 ) ).
% inj_on_rev
thf(fact_6524_rev__singleton__conv,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( ( rev @ A @ Xs )
= ( cons @ A @ X @ ( nil @ A ) ) )
= ( Xs
= ( cons @ A @ X @ ( nil @ A ) ) ) ) ).
% rev_singleton_conv
thf(fact_6525_singleton__rev__conv,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( ( cons @ A @ X @ ( nil @ A ) )
= ( rev @ A @ Xs ) )
= ( ( cons @ A @ X @ ( nil @ A ) )
= Xs ) ) ).
% singleton_rev_conv
thf(fact_6526_rev__eq__Cons__iff,axiom,
! [A: $tType,Xs: list @ A,Y: A,Ys: list @ A] :
( ( ( rev @ A @ Xs )
= ( cons @ A @ Y @ Ys ) )
= ( Xs
= ( append @ A @ ( rev @ A @ Ys ) @ ( cons @ A @ Y @ ( nil @ A ) ) ) ) ) ).
% rev_eq_Cons_iff
thf(fact_6527_sorted__wrt__rev,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A] :
( ( sorted_wrt @ A @ P2 @ ( rev @ A @ Xs ) )
= ( sorted_wrt @ A
@ ^ [X2: A,Y2: A] : ( P2 @ Y2 @ X2 )
@ Xs ) ) ).
% sorted_wrt_rev
thf(fact_6528_sorted__wrt__upto,axiom,
! [I: int,J: int] : ( sorted_wrt @ int @ ( ord_less @ int ) @ ( upto @ I @ J ) ) ).
% sorted_wrt_upto
thf(fact_6529_sorted__upto,axiom,
! [M: int,N2: int] : ( sorted_wrt @ int @ ( ord_less_eq @ int ) @ ( upto @ M @ N2 ) ) ).
% sorted_upto
thf(fact_6530_rev_Osimps_I1_J,axiom,
! [A: $tType] :
( ( rev @ A @ ( nil @ A ) )
= ( nil @ A ) ) ).
% rev.simps(1)
thf(fact_6531_rev__swap,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( rev @ A @ Xs )
= Ys )
= ( Xs
= ( rev @ A @ Ys ) ) ) ).
% rev_swap
thf(fact_6532_rev__concat,axiom,
! [A: $tType,Xs: list @ ( list @ A )] :
( ( rev @ A @ ( concat @ A @ Xs ) )
= ( concat @ A @ ( map @ ( list @ A ) @ ( list @ A ) @ ( rev @ A ) @ ( rev @ ( list @ A ) @ Xs ) ) ) ) ).
% rev_concat
thf(fact_6533_rev__map,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( rev @ A @ ( map @ B @ A @ F2 @ Xs ) )
= ( map @ B @ A @ F2 @ ( rev @ B @ Xs ) ) ) ).
% rev_map
thf(fact_6534_zip__rev,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( zip @ A @ B @ ( rev @ A @ Xs ) @ ( rev @ B @ Ys ) )
= ( rev @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) ) ) ) ).
% zip_rev
thf(fact_6535_rev__filter,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( rev @ A @ ( filter2 @ A @ P2 @ Xs ) )
= ( filter2 @ A @ P2 @ ( rev @ A @ Xs ) ) ) ).
% rev_filter
thf(fact_6536_foldl__conv__foldr,axiom,
! [B: $tType,A: $tType] :
( ( foldl @ A @ B )
= ( ^ [F3: A > B > A,A5: A,Xs2: list @ B] :
( foldr @ B @ A
@ ^ [X2: B,Y2: A] : ( F3 @ Y2 @ X2 )
@ ( rev @ B @ Xs2 )
@ A5 ) ) ) ).
% foldl_conv_foldr
thf(fact_6537_foldr__conv__foldl,axiom,
! [A: $tType,B: $tType] :
( ( foldr @ B @ A )
= ( ^ [F3: B > A > A,Xs2: list @ B,A5: A] :
( foldl @ A @ B
@ ^ [X2: A,Y2: B] : ( F3 @ Y2 @ X2 )
@ A5
@ ( rev @ B @ Xs2 ) ) ) ) ).
% foldr_conv_foldl
thf(fact_6538_rev_Osimps_I2_J,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( rev @ A @ ( cons @ A @ X @ Xs ) )
= ( append @ A @ ( rev @ A @ Xs ) @ ( cons @ A @ X @ ( nil @ A ) ) ) ) ).
% rev.simps(2)
thf(fact_6539_take__rev,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( take @ A @ N2 @ ( rev @ A @ Xs ) )
= ( rev @ A @ ( drop @ A @ ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 ) @ Xs ) ) ) ).
% take_rev
thf(fact_6540_rev__take,axiom,
! [A: $tType,I: nat,Xs: list @ A] :
( ( rev @ A @ ( take @ A @ I @ Xs ) )
= ( drop @ A @ ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ I ) @ ( rev @ A @ Xs ) ) ) ).
% rev_take
thf(fact_6541_rev__drop,axiom,
! [A: $tType,I: nat,Xs: list @ A] :
( ( rev @ A @ ( drop @ A @ I @ Xs ) )
= ( take @ A @ ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ I ) @ ( rev @ A @ Xs ) ) ) ).
% rev_drop
thf(fact_6542_drop__rev,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( drop @ A @ N2 @ ( rev @ A @ Xs ) )
= ( rev @ A @ ( take @ A @ ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 ) @ Xs ) ) ) ).
% drop_rev
thf(fact_6543_sorted__transpose,axiom,
! [A: $tType,Xs: list @ ( list @ A )] : ( sorted_wrt @ nat @ ( ord_less_eq @ nat ) @ ( rev @ nat @ ( map @ ( list @ A ) @ nat @ ( size_size @ ( list @ A ) ) @ ( transpose @ A @ Xs ) ) ) ) ).
% sorted_transpose
thf(fact_6544_rev__nth,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ A @ ( rev @ A @ Xs ) @ N2 )
= ( nth @ A @ Xs @ ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( suc @ N2 ) ) ) ) ) ).
% rev_nth
thf(fact_6545_rev__update,axiom,
! [A: $tType,K: nat,Xs: list @ A,Y: A] :
( ( ord_less @ nat @ K @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( rev @ A @ ( list_update @ A @ Xs @ K @ Y ) )
= ( list_update @ A @ ( rev @ A @ Xs ) @ ( minus_minus @ nat @ ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ K ) @ ( one_one @ nat ) ) @ Y ) ) ) ).
% rev_update
thf(fact_6546_sorted__rev__iff__nth__Suc,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( rev @ A @ Xs ) )
= ( ! [I5: nat] :
( ( ord_less @ nat @ ( suc @ I5 ) @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ord_less_eq @ A @ ( nth @ A @ Xs @ ( suc @ I5 ) ) @ ( nth @ A @ Xs @ I5 ) ) ) ) ) ) ).
% sorted_rev_iff_nth_Suc
thf(fact_6547_sorted__rev__nth__mono,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,I: nat,J: nat] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( rev @ A @ Xs ) )
=> ( ( ord_less_eq @ nat @ I @ J )
=> ( ( ord_less @ nat @ J @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ord_less_eq @ A @ ( nth @ A @ Xs @ J ) @ ( nth @ A @ Xs @ I ) ) ) ) ) ) ).
% sorted_rev_nth_mono
thf(fact_6548_sorted__rev__iff__nth__mono,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( rev @ A @ Xs ) )
= ( ! [I5: nat,J3: nat] :
( ( ord_less_eq @ nat @ I5 @ J3 )
=> ( ( ord_less @ nat @ J3 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ord_less_eq @ A @ ( nth @ A @ Xs @ J3 ) @ ( nth @ A @ Xs @ I5 ) ) ) ) ) ) ) ).
% sorted_rev_iff_nth_mono
thf(fact_6549_foldr__max__sorted,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,Y: A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( rev @ A @ Xs ) )
=> ( ( ( Xs
= ( nil @ A ) )
=> ( ( foldr @ A @ A @ ( ord_max @ A ) @ Xs @ Y )
= Y ) )
& ( ( Xs
!= ( nil @ A ) )
=> ( ( foldr @ A @ A @ ( ord_max @ A ) @ Xs @ Y )
= ( ord_max @ A @ ( nth @ A @ Xs @ ( zero_zero @ nat ) ) @ Y ) ) ) ) ) ) ).
% foldr_max_sorted
thf(fact_6550_length__transpose__sorted,axiom,
! [A: $tType,Xs: list @ ( list @ A )] :
( ( sorted_wrt @ nat @ ( ord_less_eq @ nat ) @ ( rev @ nat @ ( map @ ( list @ A ) @ nat @ ( size_size @ ( list @ A ) ) @ Xs ) ) )
=> ( ( ( Xs
= ( nil @ ( list @ A ) ) )
=> ( ( size_size @ ( list @ ( list @ A ) ) @ ( transpose @ A @ Xs ) )
= ( zero_zero @ nat ) ) )
& ( ( Xs
!= ( nil @ ( list @ A ) ) )
=> ( ( size_size @ ( list @ ( list @ A ) ) @ ( transpose @ A @ Xs ) )
= ( size_size @ ( list @ A ) @ ( nth @ ( list @ A ) @ Xs @ ( zero_zero @ nat ) ) ) ) ) ) ) ).
% length_transpose_sorted
thf(fact_6551_transpose__column__length,axiom,
! [A: $tType,Xs: list @ ( list @ A ),I: nat] :
( ( sorted_wrt @ nat @ ( ord_less_eq @ nat ) @ ( rev @ nat @ ( map @ ( list @ A ) @ nat @ ( size_size @ ( list @ A ) ) @ Xs ) ) )
=> ( ( ord_less @ nat @ I @ ( size_size @ ( list @ ( list @ A ) ) @ Xs ) )
=> ( ( size_size @ ( list @ ( list @ A ) )
@ ( filter2 @ ( list @ A )
@ ^ [Ys3: list @ A] : ( ord_less @ nat @ I @ ( size_size @ ( list @ A ) @ Ys3 ) )
@ ( transpose @ A @ Xs ) ) )
= ( size_size @ ( list @ A ) @ ( nth @ ( list @ A ) @ Xs @ I ) ) ) ) ) ).
% transpose_column_length
thf(fact_6552_folding__insort__key_Ofinite__set__strict__sorted,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,A4: set @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ S3 )
=> ( ( finite_finite @ B @ A4 )
=> ~ ! [L4: list @ B] :
( ( sorted_wrt @ A @ Less @ ( map @ B @ A @ F2 @ L4 ) )
=> ( ( ( set2 @ B @ L4 )
= A4 )
=> ( ( size_size @ ( list @ B ) @ L4 )
!= ( finite_card @ B @ A4 ) ) ) ) ) ) ) ).
% folding_insort_key.finite_set_strict_sorted
thf(fact_6553_transpose__transpose,axiom,
! [A: $tType,Xs: list @ ( list @ A )] :
( ( sorted_wrt @ nat @ ( ord_less_eq @ nat ) @ ( rev @ nat @ ( map @ ( list @ A ) @ nat @ ( size_size @ ( list @ A ) ) @ Xs ) ) )
=> ( ( transpose @ A @ ( transpose @ A @ Xs ) )
= ( takeWhile @ ( list @ A )
@ ^ [X2: list @ A] :
( X2
!= ( nil @ A ) )
@ Xs ) ) ) ).
% transpose_transpose
thf(fact_6554_takeWhile__idem,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( takeWhile @ A @ P2 @ ( takeWhile @ A @ P2 @ Xs ) )
= ( takeWhile @ A @ P2 @ Xs ) ) ).
% takeWhile_idem
thf(fact_6555_takeWhile__eq__all__conv,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ( takeWhile @ A @ P2 @ Xs )
= Xs )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X2 ) ) ) ) ).
% takeWhile_eq_all_conv
thf(fact_6556_takeWhile__append1,axiom,
! [A: $tType,X: A,Xs: list @ A,P2: A > $o,Ys: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ~ ( P2 @ X )
=> ( ( takeWhile @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( takeWhile @ A @ P2 @ Xs ) ) ) ) ).
% takeWhile_append1
thf(fact_6557_takeWhile__append2,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o,Ys: list @ A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X5 ) )
=> ( ( takeWhile @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ Xs @ ( takeWhile @ A @ P2 @ Ys ) ) ) ) ).
% takeWhile_append2
thf(fact_6558_takeWhile__replicate,axiom,
! [A: $tType,P2: A > $o,X: A,N2: nat] :
( ( ( P2 @ X )
=> ( ( takeWhile @ A @ P2 @ ( replicate @ A @ N2 @ X ) )
= ( replicate @ A @ N2 @ X ) ) )
& ( ~ ( P2 @ X )
=> ( ( takeWhile @ A @ P2 @ ( replicate @ A @ N2 @ X ) )
= ( nil @ A ) ) ) ) ).
% takeWhile_replicate
thf(fact_6559_length__concat__rev,axiom,
! [A: $tType,Xs: list @ ( list @ A )] :
( ( size_size @ ( list @ A ) @ ( concat @ A @ ( rev @ ( list @ A ) @ Xs ) ) )
= ( size_size @ ( list @ A ) @ ( concat @ A @ Xs ) ) ) ).
% length_concat_rev
thf(fact_6560_sorted__takeWhile,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,P2: A > $o] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( takeWhile @ A @ P2 @ Xs ) ) ) ) ).
% sorted_takeWhile
thf(fact_6561_takeWhile__map,axiom,
! [A: $tType,B: $tType,P2: A > $o,F2: B > A,Xs: list @ B] :
( ( takeWhile @ A @ P2 @ ( map @ B @ A @ F2 @ Xs ) )
= ( map @ B @ A @ F2 @ ( takeWhile @ B @ ( comp @ A @ $o @ B @ P2 @ F2 ) @ Xs ) ) ) ).
% takeWhile_map
thf(fact_6562_zip__takeWhile__fst,axiom,
! [A: $tType,B: $tType,P2: A > $o,Xs: list @ A,Ys: list @ B] :
( ( zip @ A @ B @ ( takeWhile @ A @ P2 @ Xs ) @ Ys )
= ( takeWhile @ ( product_prod @ A @ B ) @ ( comp @ A @ $o @ ( product_prod @ A @ B ) @ P2 @ ( product_fst @ A @ B ) ) @ ( zip @ A @ B @ Xs @ Ys ) ) ) ).
% zip_takeWhile_fst
thf(fact_6563_zip__takeWhile__snd,axiom,
! [A: $tType,B: $tType,Xs: list @ A,P2: B > $o,Ys: list @ B] :
( ( zip @ A @ B @ Xs @ ( takeWhile @ B @ P2 @ Ys ) )
= ( takeWhile @ ( product_prod @ A @ B ) @ ( comp @ B @ $o @ ( product_prod @ A @ B ) @ P2 @ ( product_snd @ A @ B ) ) @ ( zip @ A @ B @ Xs @ Ys ) ) ) ).
% zip_takeWhile_snd
thf(fact_6564_takeWhile__tail,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A,L: list @ A] :
( ~ ( P2 @ X )
=> ( ( takeWhile @ A @ P2 @ ( append @ A @ Xs @ ( cons @ A @ X @ L ) ) )
= ( takeWhile @ A @ P2 @ Xs ) ) ) ).
% takeWhile_tail
thf(fact_6565_folding__insort__key_Oinj__on,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( inj_on @ B @ A @ F2 @ S3 ) ) ).
% folding_insort_key.inj_on
thf(fact_6566_takeWhile_Osimps_I2_J,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A] :
( ( ( P2 @ X )
=> ( ( takeWhile @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( cons @ A @ X @ ( takeWhile @ A @ P2 @ Xs ) ) ) )
& ( ~ ( P2 @ X )
=> ( ( takeWhile @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( nil @ A ) ) ) ) ).
% takeWhile.simps(2)
thf(fact_6567_takeWhile_Osimps_I1_J,axiom,
! [A: $tType,P2: A > $o] :
( ( takeWhile @ A @ P2 @ ( nil @ A ) )
= ( nil @ A ) ) ).
% takeWhile.simps(1)
thf(fact_6568_distinct__takeWhile,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ( distinct @ A @ Xs )
=> ( distinct @ A @ ( takeWhile @ A @ P2 @ Xs ) ) ) ).
% distinct_takeWhile
thf(fact_6569_length__takeWhile__le,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] : ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ ( takeWhile @ A @ P2 @ Xs ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ).
% length_takeWhile_le
thf(fact_6570_takeWhile__eq__take,axiom,
! [A: $tType] :
( ( takeWhile @ A )
= ( ^ [P: A > $o,Xs2: list @ A] : ( take @ A @ ( size_size @ ( list @ A ) @ ( takeWhile @ A @ P @ Xs2 ) ) @ Xs2 ) ) ) ).
% takeWhile_eq_take
thf(fact_6571_set__takeWhileD,axiom,
! [A: $tType,X: A,P2: A > $o,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ ( takeWhile @ A @ P2 @ Xs ) ) )
=> ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
& ( P2 @ X ) ) ) ).
% set_takeWhileD
thf(fact_6572_takeWhile__cong,axiom,
! [A: $tType,L: list @ A,K: list @ A,P2: A > $o,Q: A > $o] :
( ( L = K )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ L ) )
=> ( ( P2 @ X5 )
= ( Q @ X5 ) ) )
=> ( ( takeWhile @ A @ P2 @ L )
= ( takeWhile @ A @ Q @ K ) ) ) ) ).
% takeWhile_cong
thf(fact_6573_takeWhile__eq__Nil__iff,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ( takeWhile @ A @ P2 @ Xs )
= ( nil @ A ) )
= ( ( Xs
= ( nil @ A ) )
| ~ ( P2 @ ( hd @ A @ Xs ) ) ) ) ).
% takeWhile_eq_Nil_iff
thf(fact_6574_folding__insort__key_Odistinct__if__distinct__map,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,Xs: list @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( distinct @ A @ ( map @ B @ A @ F2 @ Xs ) )
=> ( distinct @ B @ Xs ) ) ) ).
% folding_insort_key.distinct_if_distinct_map
thf(fact_6575_nth__length__takeWhile,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ord_less @ nat @ ( size_size @ ( list @ A ) @ ( takeWhile @ A @ P2 @ Xs ) ) @ ( size_size @ ( list @ A ) @ Xs ) )
=> ~ ( P2 @ ( nth @ A @ Xs @ ( size_size @ ( list @ A ) @ ( takeWhile @ A @ P2 @ Xs ) ) ) ) ) ).
% nth_length_takeWhile
thf(fact_6576_takeWhile__nth,axiom,
! [A: $tType,J: nat,P2: A > $o,Xs: list @ A] :
( ( ord_less @ nat @ J @ ( size_size @ ( list @ A ) @ ( takeWhile @ A @ P2 @ Xs ) ) )
=> ( ( nth @ A @ ( takeWhile @ A @ P2 @ Xs ) @ J )
= ( nth @ A @ Xs @ J ) ) ) ).
% takeWhile_nth
thf(fact_6577_takeWhile__append,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o,Ys: list @ A] :
( ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X5 ) )
=> ( ( takeWhile @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ Xs @ ( takeWhile @ A @ P2 @ Ys ) ) ) )
& ( ~ ! [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X3 ) )
=> ( ( takeWhile @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( takeWhile @ A @ P2 @ Xs ) ) ) ) ).
% takeWhile_append
thf(fact_6578_length__takeWhile__less__P__nth,axiom,
! [A: $tType,J: nat,P2: A > $o,Xs: list @ A] :
( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ J )
=> ( P2 @ ( nth @ A @ Xs @ I3 ) ) )
=> ( ( ord_less_eq @ nat @ J @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ord_less_eq @ nat @ J @ ( size_size @ ( list @ A ) @ ( takeWhile @ A @ P2 @ Xs ) ) ) ) ) ).
% length_takeWhile_less_P_nth
thf(fact_6579_takeWhile__eq__take__P__nth,axiom,
! [A: $tType,N2: nat,Xs: list @ A,P2: A > $o] :
( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ N2 )
=> ( ( ord_less @ nat @ I3 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( P2 @ ( nth @ A @ Xs @ I3 ) ) ) )
=> ( ( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ~ ( P2 @ ( nth @ A @ Xs @ N2 ) ) )
=> ( ( takeWhile @ A @ P2 @ Xs )
= ( take @ A @ N2 @ Xs ) ) ) ) ).
% takeWhile_eq_take_P_nth
thf(fact_6580_sorted__list__of__set_Ofolding__insort__key__axioms,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( folding_insort_key @ A @ A @ ( ord_less_eq @ A ) @ ( ord_less @ A ) @ ( top_top @ ( set @ A ) )
@ ^ [X2: A] : X2 ) ) ).
% sorted_list_of_set.folding_insort_key_axioms
thf(fact_6581_filter__equals__takeWhile__sorted__rev,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B,T2: A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( rev @ A @ ( map @ B @ A @ F2 @ Xs ) ) )
=> ( ( filter2 @ B
@ ^ [X2: B] : ( ord_less @ A @ T2 @ ( F2 @ X2 ) )
@ Xs )
= ( takeWhile @ B
@ ^ [X2: B] : ( ord_less @ A @ T2 @ ( F2 @ X2 ) )
@ Xs ) ) ) ) ).
% filter_equals_takeWhile_sorted_rev
thf(fact_6582_folding__insort__key_Osorted__key__list__of__set__unique,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,A4: set @ B,L: list @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ S3 )
=> ( ( finite_finite @ B @ A4 )
=> ( ( ( sorted_wrt @ A @ Less @ ( map @ B @ A @ F2 @ L ) )
& ( ( set2 @ B @ L )
= A4 )
& ( ( size_size @ ( list @ B ) @ L )
= ( finite_card @ B @ A4 ) ) )
= ( ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ A4 )
= L ) ) ) ) ) ).
% folding_insort_key.sorted_key_list_of_set_unique
thf(fact_6583_folding__insort__key_Osorted__key__list__of__set__remove,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,X: B,A4: set @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( insert2 @ B @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ B @ A4 )
=> ( ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ ( minus_minus @ ( set @ B ) @ A4 @ ( insert2 @ B @ X @ ( bot_bot @ ( set @ B ) ) ) ) )
= ( remove1 @ B @ X @ ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ A4 ) ) ) ) ) ) ).
% folding_insort_key.sorted_key_list_of_set_remove
thf(fact_6584_linorder_Osorted__key__list__of__set_Ocong,axiom,
! [B: $tType,A: $tType] :
( ( sorted8670434370408473282of_set @ A @ B )
= ( sorted8670434370408473282of_set @ A @ B ) ) ).
% linorder.sorted_key_list_of_set.cong
thf(fact_6585_folding__insort__key_Osorted__key__list__of__set__inject,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,A4: set @ B,B3: set @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ S3 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ S3 )
=> ( ( ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ A4 )
= ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ B3 ) )
=> ( ( finite_finite @ B @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( A4 = B3 ) ) ) ) ) ) ) ).
% folding_insort_key.sorted_key_list_of_set_inject
thf(fact_6586_folding__insort__key_Osorted__key__list__of__set__empty,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ ( bot_bot @ ( set @ B ) ) )
= ( nil @ B ) ) ) ).
% folding_insort_key.sorted_key_list_of_set_empty
thf(fact_6587_folding__insort__key_Oset__sorted__key__list__of__set,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,A4: set @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ S3 )
=> ( ( finite_finite @ B @ A4 )
=> ( ( set2 @ B @ ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ A4 ) )
= A4 ) ) ) ) ).
% folding_insort_key.set_sorted_key_list_of_set
thf(fact_6588_folding__insort__key_Olength__sorted__key__list__of__set,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,A4: set @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ S3 )
=> ( ( size_size @ ( list @ B ) @ ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ A4 ) )
= ( finite_card @ B @ A4 ) ) ) ) ).
% folding_insort_key.length_sorted_key_list_of_set
thf(fact_6589_folding__insort__key_Odistinct__sorted__key__list__of__set,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,A4: set @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ S3 )
=> ( distinct @ A @ ( map @ B @ A @ F2 @ ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ A4 ) ) ) ) ) ).
% folding_insort_key.distinct_sorted_key_list_of_set
thf(fact_6590_folding__insort__key_Ostrict__sorted__key__list__of__set,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,A4: set @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ S3 )
=> ( sorted_wrt @ A @ Less @ ( map @ B @ A @ F2 @ ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ A4 ) ) ) ) ) ).
% folding_insort_key.strict_sorted_key_list_of_set
thf(fact_6591_folding__insort__key_Osorted__sorted__key__list__of__set,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,A4: set @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ S3 )
=> ( sorted_wrt @ A @ Less_eq @ ( map @ B @ A @ F2 @ ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ A4 ) ) ) ) ) ).
% folding_insort_key.sorted_sorted_key_list_of_set
thf(fact_6592_folding__insort__key_Osorted__key__list__of__set__eq__Nil__iff,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,A4: set @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ S3 )
=> ( ( finite_finite @ B @ A4 )
=> ( ( ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ A4 )
= ( nil @ B ) )
= ( A4
= ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ).
% folding_insort_key.sorted_key_list_of_set_eq_Nil_iff
thf(fact_6593_folding__insort__key_Oidem__if__sorted__distinct,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,Xs: list @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( set2 @ B @ Xs ) @ S3 )
=> ( ( sorted_wrt @ A @ Less_eq @ ( map @ B @ A @ F2 @ Xs ) )
=> ( ( distinct @ B @ Xs )
=> ( ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ ( set2 @ B @ Xs ) )
= Xs ) ) ) ) ) ).
% folding_insort_key.idem_if_sorted_distinct
thf(fact_6594_folding__insort__key_Osorted__key__list__of__set__insert__remove,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,X: B,A4: set @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( insert2 @ B @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ B @ A4 )
=> ( ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ ( insert2 @ B @ X @ A4 ) )
= ( insort_key @ A @ B @ Less_eq @ F2 @ X @ ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ ( minus_minus @ ( set @ B ) @ A4 @ ( insert2 @ B @ X @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ) ) ) ).
% folding_insort_key.sorted_key_list_of_set_insert_remove
thf(fact_6595_folding__insort__key_Osorted__key__list__of__set__insert,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,X: B,A4: set @ B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( insert2 @ B @ X @ A4 ) @ S3 )
=> ( ( finite_finite @ B @ A4 )
=> ( ~ ( member2 @ B @ X @ A4 )
=> ( ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ ( insert2 @ B @ X @ A4 ) )
= ( insort_key @ A @ B @ Less_eq @ F2 @ X @ ( sorted8670434370408473282of_set @ A @ B @ Less_eq @ F2 @ A4 ) ) ) ) ) ) ) ).
% folding_insort_key.sorted_key_list_of_set_insert
thf(fact_6596_linorder_Oinsort__key_Ocong,axiom,
! [B: $tType,A: $tType] :
( ( insort_key @ A @ B )
= ( insort_key @ A @ B ) ) ).
% linorder.insort_key.cong
thf(fact_6597_folding__insort__key_Oinsort__key__commute,axiom,
! [A: $tType,B: $tType,Less_eq: A > A > $o,Less: A > A > $o,S3: set @ B,F2: B > A,X: B,Y: B] :
( ( folding_insort_key @ A @ B @ Less_eq @ Less @ S3 @ F2 )
=> ( ( member2 @ B @ X @ S3 )
=> ( ( member2 @ B @ Y @ S3 )
=> ( ( comp @ ( list @ B ) @ ( list @ B ) @ ( list @ B ) @ ( insort_key @ A @ B @ Less_eq @ F2 @ Y ) @ ( insort_key @ A @ B @ Less_eq @ F2 @ X ) )
= ( comp @ ( list @ B ) @ ( list @ B ) @ ( list @ B ) @ ( insort_key @ A @ B @ Less_eq @ F2 @ X ) @ ( insort_key @ A @ B @ Less_eq @ F2 @ Y ) ) ) ) ) ) ).
% folding_insort_key.insort_key_commute
thf(fact_6598_extract__def,axiom,
! [A: $tType] :
( ( extract @ A )
= ( ^ [P: A > $o,Xs2: list @ A] :
( case_list @ ( option @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) ) @ A @ ( none @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) )
@ ^ [Y2: A,Ys3: list @ A] : ( some @ ( product_prod @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) ) @ ( product_Pair @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) @ ( takeWhile @ A @ ( comp @ $o @ $o @ A @ (~) @ P ) @ Xs2 ) @ ( product_Pair @ A @ ( list @ A ) @ Y2 @ Ys3 ) ) )
@ ( dropWhile @ A @ ( comp @ $o @ $o @ A @ (~) @ P ) @ Xs2 ) ) ) ) ).
% extract_def
thf(fact_6599_linear__order__on__singleton,axiom,
! [A: $tType,X: A] : ( order_679001287576687338der_on @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) @ ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ X ) @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ) ).
% linear_order_on_singleton
thf(fact_6600_dropWhile__idem,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( dropWhile @ A @ P2 @ ( dropWhile @ A @ P2 @ Xs ) )
= ( dropWhile @ A @ P2 @ Xs ) ) ).
% dropWhile_idem
thf(fact_6601_dropWhile__eq__Nil__conv,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ( dropWhile @ A @ P2 @ Xs )
= ( nil @ A ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X2 ) ) ) ) ).
% dropWhile_eq_Nil_conv
thf(fact_6602_dropWhile__append2,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o,Ys: list @ A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X5 ) )
=> ( ( dropWhile @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( dropWhile @ A @ P2 @ Ys ) ) ) ).
% dropWhile_append2
thf(fact_6603_dropWhile__append1,axiom,
! [A: $tType,X: A,Xs: list @ A,P2: A > $o,Ys: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ~ ( P2 @ X )
=> ( ( dropWhile @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ ( dropWhile @ A @ P2 @ Xs ) @ Ys ) ) ) ) ).
% dropWhile_append1
thf(fact_6604_dropWhile__replicate,axiom,
! [A: $tType,P2: A > $o,X: A,N2: nat] :
( ( ( P2 @ X )
=> ( ( dropWhile @ A @ P2 @ ( replicate @ A @ N2 @ X ) )
= ( nil @ A ) ) )
& ( ~ ( P2 @ X )
=> ( ( dropWhile @ A @ P2 @ ( replicate @ A @ N2 @ X ) )
= ( replicate @ A @ N2 @ X ) ) ) ) ).
% dropWhile_replicate
thf(fact_6605_takeWhile__dropWhile__id,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( append @ A @ ( takeWhile @ A @ P2 @ Xs ) @ ( dropWhile @ A @ P2 @ Xs ) )
= Xs ) ).
% takeWhile_dropWhile_id
thf(fact_6606_sorted__dropWhile,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,P2: A > $o] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( dropWhile @ A @ P2 @ Xs ) ) ) ) ).
% sorted_dropWhile
thf(fact_6607_hd__dropWhile,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ( dropWhile @ A @ P2 @ Xs )
!= ( nil @ A ) )
=> ~ ( P2 @ ( hd @ A @ ( dropWhile @ A @ P2 @ Xs ) ) ) ) ).
% hd_dropWhile
thf(fact_6608_dropWhile__eq__self__iff,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( ( dropWhile @ A @ P2 @ Xs )
= Xs )
= ( ( Xs
= ( nil @ A ) )
| ~ ( P2 @ ( hd @ A @ Xs ) ) ) ) ).
% dropWhile_eq_self_iff
thf(fact_6609_dropWhile__cong,axiom,
! [A: $tType,L: list @ A,K: list @ A,P2: A > $o,Q: A > $o] :
( ( L = K )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ L ) )
=> ( ( P2 @ X5 )
= ( Q @ X5 ) ) )
=> ( ( dropWhile @ A @ P2 @ L )
= ( dropWhile @ A @ Q @ K ) ) ) ) ).
% dropWhile_cong
thf(fact_6610_set__dropWhileD,axiom,
! [A: $tType,X: A,P2: A > $o,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ ( dropWhile @ A @ P2 @ Xs ) ) )
=> ( member2 @ A @ X @ ( set2 @ A @ Xs ) ) ) ).
% set_dropWhileD
thf(fact_6611_distinct__dropWhile,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ( distinct @ A @ Xs )
=> ( distinct @ A @ ( dropWhile @ A @ P2 @ Xs ) ) ) ).
% distinct_dropWhile
thf(fact_6612_length__dropWhile__le,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] : ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ ( dropWhile @ A @ P2 @ Xs ) ) @ ( size_size @ ( list @ A ) @ Xs ) ) ).
% length_dropWhile_le
thf(fact_6613_dropWhile_Osimps_I1_J,axiom,
! [A: $tType,P2: A > $o] :
( ( dropWhile @ A @ P2 @ ( nil @ A ) )
= ( nil @ A ) ) ).
% dropWhile.simps(1)
thf(fact_6614_dropWhile_Osimps_I2_J,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A] :
( ( ( P2 @ X )
=> ( ( dropWhile @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( dropWhile @ A @ P2 @ Xs ) ) )
& ( ~ ( P2 @ X )
=> ( ( dropWhile @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( cons @ A @ X @ Xs ) ) ) ) ).
% dropWhile.simps(2)
thf(fact_6615_dropWhile__append3,axiom,
! [A: $tType,P2: A > $o,Y: A,Xs: list @ A,Ys: list @ A] :
( ~ ( P2 @ Y )
=> ( ( dropWhile @ A @ P2 @ ( append @ A @ Xs @ ( cons @ A @ Y @ Ys ) ) )
= ( append @ A @ ( dropWhile @ A @ P2 @ Xs ) @ ( cons @ A @ Y @ Ys ) ) ) ) ).
% dropWhile_append3
thf(fact_6616_dropWhile__map,axiom,
! [A: $tType,B: $tType,P2: A > $o,F2: B > A,Xs: list @ B] :
( ( dropWhile @ A @ P2 @ ( map @ B @ A @ F2 @ Xs ) )
= ( map @ B @ A @ F2 @ ( dropWhile @ B @ ( comp @ A @ $o @ B @ P2 @ F2 ) @ Xs ) ) ) ).
% dropWhile_map
thf(fact_6617_remdups__adj__Cons_H,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( remdups_adj @ A @ ( cons @ A @ X @ Xs ) )
= ( cons @ A @ X
@ ( remdups_adj @ A
@ ( dropWhile @ A
@ ^ [Y2: A] : ( Y2 = X )
@ Xs ) ) ) ) ).
% remdups_adj_Cons'
thf(fact_6618_lnear__order__on__empty,axiom,
! [A: $tType] : ( order_679001287576687338der_on @ A @ ( bot_bot @ ( set @ A ) ) @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ).
% lnear_order_on_empty
thf(fact_6619_dropWhile__eq__Cons__conv,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A,Y: A,Ys: list @ A] :
( ( ( dropWhile @ A @ P2 @ Xs )
= ( cons @ A @ Y @ Ys ) )
= ( ( Xs
= ( append @ A @ ( takeWhile @ A @ P2 @ Xs ) @ ( cons @ A @ Y @ Ys ) ) )
& ~ ( P2 @ Y ) ) ) ).
% dropWhile_eq_Cons_conv
thf(fact_6620_takeWhile__eq__filter,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ ( dropWhile @ A @ P2 @ Xs ) ) )
=> ~ ( P2 @ X5 ) )
=> ( ( takeWhile @ A @ P2 @ Xs )
= ( filter2 @ A @ P2 @ Xs ) ) ) ).
% takeWhile_eq_filter
thf(fact_6621_dropWhile__eq__drop,axiom,
! [A: $tType] :
( ( dropWhile @ A )
= ( ^ [P: A > $o,Xs2: list @ A] : ( drop @ A @ ( size_size @ ( list @ A ) @ ( takeWhile @ A @ P @ Xs2 ) ) @ Xs2 ) ) ) ).
% dropWhile_eq_drop
thf(fact_6622_dropWhile__append,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o,Ys: list @ A] :
( ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X5 ) )
=> ( ( dropWhile @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( dropWhile @ A @ P2 @ Ys ) ) )
& ( ~ ! [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X3 ) )
=> ( ( dropWhile @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ ( dropWhile @ A @ P2 @ Xs ) @ Ys ) ) ) ) ).
% dropWhile_append
thf(fact_6623_find__dropWhile,axiom,
! [A: $tType] :
( ( find @ A )
= ( ^ [P: A > $o,Xs2: list @ A] :
( case_list @ ( option @ A ) @ A @ ( none @ A )
@ ^ [X2: A,Xa3: list @ A] : ( some @ A @ X2 )
@ ( dropWhile @ A @ ( comp @ $o @ $o @ A @ (~) @ P ) @ Xs2 ) ) ) ) ).
% find_dropWhile
thf(fact_6624_remdups__adj__append__dropWhile,axiom,
! [A: $tType,Xs: list @ A,Y: A,Ys: list @ A] :
( ( remdups_adj @ A @ ( append @ A @ Xs @ ( cons @ A @ Y @ Ys ) ) )
= ( append @ A @ ( remdups_adj @ A @ ( append @ A @ Xs @ ( cons @ A @ Y @ ( nil @ A ) ) ) )
@ ( remdups_adj @ A
@ ( dropWhile @ A
@ ^ [X2: A] : ( X2 = Y )
@ Ys ) ) ) ) ).
% remdups_adj_append_dropWhile
thf(fact_6625_tl__remdups__adj,axiom,
! [A: $tType,Ys: list @ A] :
( ( Ys
!= ( nil @ A ) )
=> ( ( tl @ A @ ( remdups_adj @ A @ Ys ) )
= ( remdups_adj @ A
@ ( dropWhile @ A
@ ^ [X2: A] :
( X2
= ( hd @ A @ Ys ) )
@ ( tl @ A @ Ys ) ) ) ) ) ).
% tl_remdups_adj
thf(fact_6626_dropWhile__nth,axiom,
! [A: $tType,J: nat,P2: A > $o,Xs: list @ A] :
( ( ord_less @ nat @ J @ ( size_size @ ( list @ A ) @ ( dropWhile @ A @ P2 @ Xs ) ) )
=> ( ( nth @ A @ ( dropWhile @ A @ P2 @ Xs ) @ J )
= ( nth @ A @ Xs @ ( plus_plus @ nat @ J @ ( size_size @ ( list @ A ) @ ( takeWhile @ A @ P2 @ Xs ) ) ) ) ) ) ).
% dropWhile_nth
thf(fact_6627_dropWhile__neq__rev,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( distinct @ A @ Xs )
=> ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( dropWhile @ A
@ ^ [Y2: A] : ( Y2 != X )
@ ( rev @ A @ Xs ) )
= ( cons @ A @ X
@ ( rev @ A
@ ( takeWhile @ A
@ ^ [Y2: A] : ( Y2 != X )
@ Xs ) ) ) ) ) ) ).
% dropWhile_neq_rev
thf(fact_6628_takeWhile__neq__rev,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( distinct @ A @ Xs )
=> ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( takeWhile @ A
@ ^ [Y2: A] : ( Y2 != X )
@ ( rev @ A @ Xs ) )
= ( rev @ A
@ ( tl @ A
@ ( dropWhile @ A
@ ^ [Y2: A] : ( Y2 != X )
@ Xs ) ) ) ) ) ) ).
% takeWhile_neq_rev
thf(fact_6629_partition__filter__conv,axiom,
! [A: $tType] :
( ( partition @ A )
= ( ^ [F3: A > $o,Xs2: list @ A] : ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( filter2 @ A @ F3 @ Xs2 ) @ ( filter2 @ A @ ( comp @ $o @ $o @ A @ (~) @ F3 ) @ Xs2 ) ) ) ) ).
% partition_filter_conv
thf(fact_6630_lenlex__append2,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A ),Us: list @ A,Xs: list @ A,Ys: list @ A] :
( ( irrefl @ A @ R )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ Us @ Xs ) @ ( append @ A @ Us @ Ys ) ) @ ( lenlex @ A @ R ) )
= ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( lenlex @ A @ R ) ) ) ) ).
% lenlex_append2
thf(fact_6631_lexord__same__pref__if__irrefl,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ( irrefl @ A @ R2 )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( append @ A @ Xs @ Ys ) @ ( append @ A @ Xs @ Zs ) ) @ ( lexord @ A @ R2 ) )
= ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Ys @ Zs ) @ ( lexord @ A @ R2 ) ) ) ) ).
% lexord_same_pref_if_irrefl
thf(fact_6632_partition__filter1,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( product_fst @ ( list @ A ) @ ( list @ A ) @ ( partition @ A @ P2 @ Xs ) )
= ( filter2 @ A @ P2 @ Xs ) ) ).
% partition_filter1
thf(fact_6633_irrefl__lex,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( irrefl @ A @ R2 )
=> ( irrefl @ ( list @ A ) @ ( lex @ A @ R2 ) ) ) ).
% irrefl_lex
thf(fact_6634_lexord__irrefl,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A )] :
( ( irrefl @ A @ R )
=> ( irrefl @ ( list @ A ) @ ( lexord @ A @ R ) ) ) ).
% lexord_irrefl
thf(fact_6635_irreflI,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A )] :
( ! [A7: A] :
~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A7 @ A7 ) @ R )
=> ( irrefl @ A @ R ) ) ).
% irreflI
thf(fact_6636_irrefl__def,axiom,
! [A: $tType] :
( ( irrefl @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
! [A5: A] :
~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A5 @ A5 ) @ R4 ) ) ) ).
% irrefl_def
thf(fact_6637_partition_Osimps_I1_J,axiom,
! [A: $tType,P2: A > $o] :
( ( partition @ A @ P2 @ ( nil @ A ) )
= ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ ( nil @ A ) ) ) ).
% partition.simps(1)
thf(fact_6638_partition__P,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A,Yes: list @ A,No4: list @ A] :
( ( ( partition @ A @ P2 @ Xs )
= ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Yes @ No4 ) )
=> ( ! [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Yes ) )
=> ( P2 @ X3 ) )
& ! [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ No4 ) )
=> ~ ( P2 @ X3 ) ) ) ) ).
% partition_P
thf(fact_6639_lexl__not__refl,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),X: list @ A] :
( ( irrefl @ A @ R2 )
=> ~ ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ X ) @ ( lex @ A @ R2 ) ) ) ).
% lexl_not_refl
thf(fact_6640_partition_Osimps_I2_J,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A] :
( ( partition @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( product_case_prod @ ( list @ A ) @ ( list @ A ) @ ( product_prod @ ( list @ A ) @ ( list @ A ) )
@ ^ [Yes2: list @ A,No: list @ A] : ( if @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( P2 @ X ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X @ Yes2 ) @ No ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Yes2 @ ( cons @ A @ X @ No ) ) )
@ ( partition @ A @ P2 @ Xs ) ) ) ).
% partition.simps(2)
thf(fact_6641_partition__filter2,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( product_snd @ ( list @ A ) @ ( list @ A ) @ ( partition @ A @ P2 @ Xs ) )
= ( filter2 @ A @ ( comp @ $o @ $o @ A @ (~) @ P2 ) @ Xs ) ) ).
% partition_filter2
thf(fact_6642_partition__set,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A,Yes: list @ A,No4: list @ A] :
( ( ( partition @ A @ P2 @ Xs )
= ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Yes @ No4 ) )
=> ( ( sup_sup @ ( set @ A ) @ ( set2 @ A @ Yes ) @ ( set2 @ A @ No4 ) )
= ( set2 @ A @ Xs ) ) ) ).
% partition_set
thf(fact_6643_min__list_Oelims,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [X: list @ A,Y: A] :
( ( ( min_list @ A @ X )
= Y )
=> ( ! [X5: A,Xs3: list @ A] :
( ( X
= ( cons @ A @ X5 @ Xs3 ) )
=> ( Y
!= ( case_list @ A @ A @ X5
@ ^ [A5: A,List2: list @ A] : ( ord_min @ A @ X5 @ ( min_list @ A @ Xs3 ) )
@ Xs3 ) ) )
=> ~ ( ( X
= ( nil @ A ) )
=> ( Y
!= ( undefined @ A ) ) ) ) ) ) ).
% min_list.elims
thf(fact_6644_lists__length__Suc__eq,axiom,
! [A: $tType,A4: set @ A,N2: nat] :
( ( collect @ ( list @ A )
@ ^ [Xs2: list @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs2 ) @ A4 )
& ( ( size_size @ ( list @ A ) @ Xs2 )
= ( suc @ N2 ) ) ) )
= ( image2 @ ( product_prod @ ( list @ A ) @ A ) @ ( list @ A )
@ ( product_case_prod @ ( list @ A ) @ A @ ( list @ A )
@ ^ [Xs2: list @ A,N: A] : ( cons @ A @ N @ Xs2 ) )
@ ( product_Sigma @ ( list @ A ) @ A
@ ( collect @ ( list @ A )
@ ^ [Xs2: list @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs2 ) @ A4 )
& ( ( size_size @ ( list @ A ) @ Xs2 )
= N2 ) ) )
@ ^ [Uu3: list @ A] : A4 ) ) ) ).
% lists_length_Suc_eq
thf(fact_6645_SigmaI,axiom,
! [B: $tType,A: $tType,A3: A,A4: set @ A,B2: B,B3: A > ( set @ B )] :
( ( member2 @ A @ A3 @ A4 )
=> ( ( member2 @ B @ B2 @ ( B3 @ A3 ) )
=> ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ ( product_Sigma @ A @ B @ A4 @ B3 ) ) ) ) ).
% SigmaI
thf(fact_6646_mem__Sigma__iff,axiom,
! [B: $tType,A: $tType,A3: A,B2: B,A4: set @ A,B3: A > ( set @ B )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ ( product_Sigma @ A @ B @ A4 @ B3 ) )
= ( ( member2 @ A @ A3 @ A4 )
& ( member2 @ B @ B2 @ ( B3 @ A3 ) ) ) ) ).
% mem_Sigma_iff
thf(fact_6647_Sigma__empty1,axiom,
! [B: $tType,A: $tType,B3: A > ( set @ B )] :
( ( product_Sigma @ A @ B @ ( bot_bot @ ( set @ A ) ) @ B3 )
= ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) ) ).
% Sigma_empty1
thf(fact_6648_Sigma__empty2,axiom,
! [B: $tType,A: $tType,A4: set @ A] :
( ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : ( bot_bot @ ( set @ B ) ) )
= ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) ) ).
% Sigma_empty2
thf(fact_6649_Times__empty,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ( ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 )
= ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) )
= ( ( A4
= ( bot_bot @ ( set @ A ) ) )
| ( B3
= ( bot_bot @ ( set @ B ) ) ) ) ) ).
% Times_empty
thf(fact_6650_fst__image__times,axiom,
! [B: $tType,A: $tType,B3: set @ B,A4: set @ A] :
( ( ( B3
= ( bot_bot @ ( set @ B ) ) )
=> ( ( image2 @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) )
= ( bot_bot @ ( set @ A ) ) ) )
& ( ( B3
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( image2 @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) )
= A4 ) ) ) ).
% fst_image_times
thf(fact_6651_snd__image__times,axiom,
! [B: $tType,A: $tType,A4: set @ B,B3: set @ A] :
( ( ( A4
= ( bot_bot @ ( set @ B ) ) )
=> ( ( image2 @ ( product_prod @ B @ A ) @ A @ ( product_snd @ B @ A )
@ ( product_Sigma @ B @ A @ A4
@ ^ [Uu3: B] : B3 ) )
= ( bot_bot @ ( set @ A ) ) ) )
& ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( image2 @ ( product_prod @ B @ A ) @ A @ ( product_snd @ B @ A )
@ ( product_Sigma @ B @ A @ A4
@ ^ [Uu3: B] : B3 ) )
= B3 ) ) ) ).
% snd_image_times
thf(fact_6652_set__product,axiom,
! [B: $tType,A: $tType,Xs: list @ A,Ys: list @ B] :
( ( set2 @ ( product_prod @ A @ B ) @ ( product @ A @ B @ Xs @ Ys ) )
= ( product_Sigma @ A @ B @ ( set2 @ A @ Xs )
@ ^ [Uu3: A] : ( set2 @ B @ Ys ) ) ) ).
% set_product
thf(fact_6653_insert__Times__insert,axiom,
! [B: $tType,A: $tType,A3: A,A4: set @ A,B2: B,B3: set @ B] :
( ( product_Sigma @ A @ B @ ( insert2 @ A @ A3 @ A4 )
@ ^ [Uu3: A] : ( insert2 @ B @ B2 @ B3 ) )
= ( insert2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 )
@ ( sup_sup @ ( set @ ( product_prod @ A @ B ) )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : ( insert2 @ B @ B2 @ B3 ) )
@ ( product_Sigma @ A @ B @ ( insert2 @ A @ A3 @ A4 )
@ ^ [Uu3: A] : B3 ) ) ) ) ).
% insert_Times_insert
thf(fact_6654_SigmaE,axiom,
! [A: $tType,B: $tType,C2: product_prod @ A @ B,A4: set @ A,B3: A > ( set @ B )] :
( ( member2 @ ( product_prod @ A @ B ) @ C2 @ ( product_Sigma @ A @ B @ A4 @ B3 ) )
=> ~ ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ! [Y4: B] :
( ( member2 @ B @ Y4 @ ( B3 @ X5 ) )
=> ( C2
!= ( product_Pair @ A @ B @ X5 @ Y4 ) ) ) ) ) ).
% SigmaE
thf(fact_6655_SigmaD1,axiom,
! [B: $tType,A: $tType,A3: A,B2: B,A4: set @ A,B3: A > ( set @ B )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ ( product_Sigma @ A @ B @ A4 @ B3 ) )
=> ( member2 @ A @ A3 @ A4 ) ) ).
% SigmaD1
thf(fact_6656_SigmaD2,axiom,
! [B: $tType,A: $tType,A3: A,B2: B,A4: set @ A,B3: A > ( set @ B )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ ( product_Sigma @ A @ B @ A4 @ B3 ) )
=> ( member2 @ B @ B2 @ ( B3 @ A3 ) ) ) ).
% SigmaD2
thf(fact_6657_SigmaE2,axiom,
! [B: $tType,A: $tType,A3: A,B2: B,A4: set @ A,B3: A > ( set @ B )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ ( product_Sigma @ A @ B @ A4 @ B3 ) )
=> ~ ( ( member2 @ A @ A3 @ A4 )
=> ~ ( member2 @ B @ B2 @ ( B3 @ A3 ) ) ) ) ).
% SigmaE2
thf(fact_6658_times__eq__iff,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B,C5: set @ A,D6: set @ B] :
( ( ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 )
= ( product_Sigma @ A @ B @ C5
@ ^ [Uu3: A] : D6 ) )
= ( ( ( A4 = C5 )
& ( B3 = D6 ) )
| ( ( ( A4
= ( bot_bot @ ( set @ A ) ) )
| ( B3
= ( bot_bot @ ( set @ B ) ) ) )
& ( ( C5
= ( bot_bot @ ( set @ A ) ) )
| ( D6
= ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ).
% times_eq_iff
thf(fact_6659_Sigma__empty__iff,axiom,
! [B: $tType,A: $tType,I6: set @ A,X7: A > ( set @ B )] :
( ( ( product_Sigma @ A @ B @ I6 @ X7 )
= ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ I6 )
=> ( ( X7 @ X2 )
= ( bot_bot @ ( set @ B ) ) ) ) ) ) ).
% Sigma_empty_iff
thf(fact_6660_Times__subset__cancel2,axiom,
! [A: $tType,B: $tType,X: A,C5: set @ A,A4: set @ B,B3: set @ B] :
( ( member2 @ A @ X @ C5 )
=> ( ( ord_less_eq @ ( set @ ( product_prod @ B @ A ) )
@ ( product_Sigma @ B @ A @ A4
@ ^ [Uu3: B] : C5 )
@ ( product_Sigma @ B @ A @ B3
@ ^ [Uu3: B] : C5 ) )
= ( ord_less_eq @ ( set @ B ) @ A4 @ B3 ) ) ) ).
% Times_subset_cancel2
thf(fact_6661_Sigma__mono,axiom,
! [B: $tType,A: $tType,A4: set @ A,C5: set @ A,B3: A > ( set @ B ),D6: A > ( set @ B )] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ C5 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ ( set @ B ) @ ( B3 @ X5 ) @ ( D6 @ X5 ) ) )
=> ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) ) @ ( product_Sigma @ A @ B @ A4 @ B3 ) @ ( product_Sigma @ A @ B @ C5 @ D6 ) ) ) ) ).
% Sigma_mono
thf(fact_6662_Restr__subset,axiom,
! [A: $tType,A4: set @ A,B3: set @ A,R2: set @ ( product_prod @ A @ A )] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( inf_inf @ ( set @ ( product_prod @ A @ A ) )
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ B3
@ ^ [Uu3: A] : B3 ) )
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : A4 ) )
= ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : A4 ) ) ) ) ).
% Restr_subset
thf(fact_6663_swap__product,axiom,
! [B: $tType,A: $tType,A4: set @ B,B3: set @ A] :
( ( image2 @ ( product_prod @ B @ A ) @ ( product_prod @ A @ B )
@ ( product_case_prod @ B @ A @ ( product_prod @ A @ B )
@ ^ [I5: B,J3: A] : ( product_Pair @ A @ B @ J3 @ I5 ) )
@ ( product_Sigma @ B @ A @ A4
@ ^ [Uu3: B] : B3 ) )
= ( product_Sigma @ A @ B @ B3
@ ^ [Uu3: A] : A4 ) ) ).
% swap_product
thf(fact_6664_times__subset__iff,axiom,
! [A: $tType,B: $tType,A4: set @ A,C5: set @ B,B3: set @ A,D6: set @ B] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : C5 )
@ ( product_Sigma @ A @ B @ B3
@ ^ [Uu3: A] : D6 ) )
= ( ( A4
= ( bot_bot @ ( set @ A ) ) )
| ( C5
= ( bot_bot @ ( set @ B ) ) )
| ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
& ( ord_less_eq @ ( set @ B ) @ C5 @ D6 ) ) ) ) ).
% times_subset_iff
thf(fact_6665_image__paired__Times,axiom,
! [C: $tType,D: $tType,B: $tType,A: $tType,F2: C > A,G: D > B,A4: set @ C,B3: set @ D] :
( ( image2 @ ( product_prod @ C @ D ) @ ( product_prod @ A @ B )
@ ( product_case_prod @ C @ D @ ( product_prod @ A @ B )
@ ^ [X2: C,Y2: D] : ( product_Pair @ A @ B @ ( F2 @ X2 ) @ ( G @ Y2 ) ) )
@ ( product_Sigma @ C @ D @ A4
@ ^ [Uu3: C] : B3 ) )
= ( product_Sigma @ A @ B @ ( image2 @ C @ A @ F2 @ A4 )
@ ^ [Uu3: A] : ( image2 @ D @ B @ G @ B3 ) ) ) ).
% image_paired_Times
thf(fact_6666_hd__def,axiom,
! [A: $tType] :
( ( hd @ A )
= ( case_list @ A @ A @ ( undefined @ A )
@ ^ [X213: A,X224: list @ A] : X213 ) ) ).
% hd_def
thf(fact_6667_trancl__subset__Sigma__aux,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A ),A4: set @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : A4 ) )
=> ( ( A3 = B2 )
| ( member2 @ A @ A3 @ A4 ) ) ) ) ).
% trancl_subset_Sigma_aux
thf(fact_6668_finite__cartesian__product__iff,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ( finite_finite @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) )
= ( ( A4
= ( bot_bot @ ( set @ A ) ) )
| ( B3
= ( bot_bot @ ( set @ B ) ) )
| ( ( finite_finite @ A @ A4 )
& ( finite_finite @ B @ B3 ) ) ) ) ).
% finite_cartesian_product_iff
thf(fact_6669_finite__cartesian__productD2,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ( finite_finite @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( finite_finite @ B @ B3 ) ) ) ).
% finite_cartesian_productD2
thf(fact_6670_finite__cartesian__productD1,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B] :
( ( finite_finite @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) )
=> ( ( B3
!= ( bot_bot @ ( set @ B ) ) )
=> ( finite_finite @ A @ A4 ) ) ) ).
% finite_cartesian_productD1
thf(fact_6671_finite__SigmaI2,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: A > ( set @ B )] :
( ( finite_finite @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( ( B3 @ X2 )
!= ( bot_bot @ ( set @ B ) ) ) ) ) )
=> ( ! [A7: A] :
( ( member2 @ A @ A7 @ A4 )
=> ( finite_finite @ B @ ( B3 @ A7 ) ) )
=> ( finite_finite @ ( product_prod @ A @ B ) @ ( product_Sigma @ A @ B @ A4 @ B3 ) ) ) ) ).
% finite_SigmaI2
thf(fact_6672_fst__image__Sigma,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: A > ( set @ B )] :
( ( image2 @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ ( product_Sigma @ A @ B @ A4 @ B3 ) )
= ( collect @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( ( B3 @ X2 )
!= ( bot_bot @ ( set @ B ) ) ) ) ) ) ).
% fst_image_Sigma
thf(fact_6673_refl__on__def,axiom,
! [A: $tType] :
( ( refl_on @ A )
= ( ^ [A6: set @ A,R4: set @ ( product_prod @ A @ A )] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R4
@ ( product_Sigma @ A @ A @ A6
@ ^ [Uu3: A] : A6 ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ X2 ) @ R4 ) ) ) ) ) ).
% refl_on_def
thf(fact_6674_refl__onI,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : A4 ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ X5 ) @ R2 ) )
=> ( refl_on @ A @ A4 @ R2 ) ) ) ).
% refl_onI
thf(fact_6675_subset__fst__imageI,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B,S3: set @ ( product_prod @ A @ B ),Y: B] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 )
@ S3 )
=> ( ( member2 @ B @ Y @ B3 )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ ( image2 @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ S3 ) ) ) ) ).
% subset_fst_imageI
thf(fact_6676_subset__snd__imageI,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B,S3: set @ ( product_prod @ A @ B ),X: A] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 )
@ S3 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ ( set @ B ) @ B3 @ ( image2 @ ( product_prod @ A @ B ) @ B @ ( product_snd @ A @ B ) @ S3 ) ) ) ) ).
% subset_snd_imageI
thf(fact_6677_card__cartesian__product__singleton,axiom,
! [A: $tType,B: $tType,X: A,A4: set @ B] :
( ( finite_card @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) )
@ ^ [Uu3: A] : A4 ) )
= ( finite_card @ B @ A4 ) ) ).
% card_cartesian_product_singleton
thf(fact_6678_Sigma__interval__disjoint,axiom,
! [A: $tType,B: $tType] :
( ( order @ A )
=> ! [A4: set @ B,V2: B > A,W2: A] :
( ( inf_inf @ ( set @ ( product_prod @ B @ A ) )
@ ( product_Sigma @ B @ A @ A4
@ ^ [I5: B] : ( set_ord_atMost @ A @ ( V2 @ I5 ) ) )
@ ( product_Sigma @ B @ A @ A4
@ ^ [I5: B] : ( set_or3652927894154168847AtMost @ A @ ( V2 @ I5 ) @ W2 ) ) )
= ( bot_bot @ ( set @ ( product_prod @ B @ A ) ) ) ) ) ).
% Sigma_interval_disjoint
thf(fact_6679_Func__empty,axiom,
! [B: $tType,A: $tType,B3: set @ B] :
( ( bNF_Wellorder_Func @ A @ B @ ( bot_bot @ ( set @ A ) ) @ B3 )
= ( insert2 @ ( A > B )
@ ^ [X2: A] : ( undefined @ B )
@ ( bot_bot @ ( set @ ( A > B ) ) ) ) ) ).
% Func_empty
thf(fact_6680_Sigma__def,axiom,
! [B: $tType,A: $tType] :
( ( product_Sigma @ A @ B )
= ( ^ [A6: set @ A,B6: A > ( set @ B )] :
( complete_Sup_Sup @ ( set @ ( product_prod @ A @ B ) )
@ ( image2 @ A @ ( set @ ( product_prod @ A @ B ) )
@ ^ [X2: A] :
( complete_Sup_Sup @ ( set @ ( product_prod @ A @ B ) )
@ ( image2 @ B @ ( set @ ( product_prod @ A @ B ) )
@ ^ [Y2: B] : ( insert2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) )
@ ( B6 @ X2 ) ) )
@ A6 ) ) ) ) ).
% Sigma_def
thf(fact_6681_product__fold,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 )
= ( finite_fold @ A @ ( set @ ( product_prod @ A @ B ) )
@ ^ [X2: A,Z6: set @ ( product_prod @ A @ B )] :
( finite_fold @ B @ ( set @ ( product_prod @ A @ B ) )
@ ^ [Y2: B] : ( insert2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) )
@ Z6
@ B3 )
@ ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) )
@ A4 ) ) ) ) ).
% product_fold
thf(fact_6682_arg__min__list_Oelims,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ! [X: A > B,Xa2: list @ A,Y: A] :
( ( ( arg_min_list @ A @ B @ X @ Xa2 )
= Y )
=> ( ! [X5: A] :
( ( Xa2
= ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ( Y != X5 ) )
=> ( ! [X5: A,Y4: A,Zs2: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Zs2 ) ) )
=> ( Y
!= ( if @ A @ ( ord_less_eq @ B @ ( X @ X5 ) @ ( X @ ( arg_min_list @ A @ B @ X @ ( cons @ A @ Y4 @ Zs2 ) ) ) ) @ X5 @ ( arg_min_list @ A @ B @ X @ ( cons @ A @ Y4 @ Zs2 ) ) ) ) )
=> ~ ( ( Xa2
= ( nil @ A ) )
=> ( Y
!= ( undefined @ A ) ) ) ) ) ) ) ).
% arg_min_list.elims
thf(fact_6683_min__list_Opelims,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [X: list @ A,Y: A] :
( ( ( min_list @ A @ X )
= Y )
=> ( ( accp @ ( list @ A ) @ ( min_list_rel @ A ) @ X )
=> ( ! [X5: A,Xs3: list @ A] :
( ( X
= ( cons @ A @ X5 @ Xs3 ) )
=> ( ( Y
= ( case_list @ A @ A @ X5
@ ^ [A5: A,List2: list @ A] : ( ord_min @ A @ X5 @ ( min_list @ A @ Xs3 ) )
@ Xs3 ) )
=> ~ ( accp @ ( list @ A ) @ ( min_list_rel @ A ) @ ( cons @ A @ X5 @ Xs3 ) ) ) )
=> ~ ( ( X
= ( nil @ A ) )
=> ( ( Y
= ( undefined @ A ) )
=> ~ ( accp @ ( list @ A ) @ ( min_list_rel @ A ) @ ( nil @ A ) ) ) ) ) ) ) ) ).
% min_list.pelims
thf(fact_6684_Gr__incl,axiom,
! [A: $tType,B: $tType,A4: set @ A,F2: A > B,B3: set @ B] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) ) @ ( bNF_Gr @ A @ B @ A4 @ F2 )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) )
= ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ B3 ) ) ).
% Gr_incl
thf(fact_6685_GrD1,axiom,
! [B: $tType,A: $tType,X: A,Fx: B,A4: set @ A,F2: A > B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Fx ) @ ( bNF_Gr @ A @ B @ A4 @ F2 ) )
=> ( member2 @ A @ X @ A4 ) ) ).
% GrD1
thf(fact_6686_GrD2,axiom,
! [A: $tType,B: $tType,X: A,Fx: B,A4: set @ A,F2: A > B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Fx ) @ ( bNF_Gr @ A @ B @ A4 @ F2 ) )
=> ( ( F2 @ X )
= Fx ) ) ).
% GrD2
thf(fact_6687_Gr__def,axiom,
! [B: $tType,A: $tType] :
( ( bNF_Gr @ A @ B )
= ( ^ [A6: set @ A,F3: A > B] :
( collect @ ( product_prod @ A @ B )
@ ^ [Uu3: product_prod @ A @ B] :
? [A5: A] :
( ( Uu3
= ( product_Pair @ A @ B @ A5 @ ( F3 @ A5 ) ) )
& ( member2 @ A @ A5 @ A6 ) ) ) ) ) ).
% Gr_def
thf(fact_6688_pairs__le__eq__Sigma,axiom,
! [M: nat] :
( ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [I5: nat,J3: nat] : ( ord_less_eq @ nat @ ( plus_plus @ nat @ I5 @ J3 ) @ M ) ) )
= ( product_Sigma @ nat @ nat @ ( set_ord_atMost @ nat @ M )
@ ^ [R4: nat] : ( set_ord_atMost @ nat @ ( minus_minus @ nat @ M @ R4 ) ) ) ) ).
% pairs_le_eq_Sigma
thf(fact_6689_rotate__drop__take,axiom,
! [A: $tType] :
( ( rotate @ A )
= ( ^ [N: nat,Xs2: list @ A] : ( append @ A @ ( drop @ A @ ( modulo_modulo @ nat @ N @ ( size_size @ ( list @ A ) @ Xs2 ) ) @ Xs2 ) @ ( take @ A @ ( modulo_modulo @ nat @ N @ ( size_size @ ( list @ A ) @ Xs2 ) ) @ Xs2 ) ) ) ) ).
% rotate_drop_take
thf(fact_6690_image__split__eq__Sigma,axiom,
! [C: $tType,B: $tType,A: $tType,F2: C > A,G: C > B,A4: set @ C] :
( ( image2 @ C @ ( product_prod @ A @ B )
@ ^ [X2: C] : ( product_Pair @ A @ B @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ A4 )
= ( product_Sigma @ A @ B @ ( image2 @ C @ A @ F2 @ A4 )
@ ^ [X2: A] : ( image2 @ C @ B @ G @ ( inf_inf @ ( set @ C ) @ ( vimage @ C @ A @ F2 @ ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) ) @ A4 ) ) ) ) ).
% image_split_eq_Sigma
thf(fact_6691_vimage__empty,axiom,
! [B: $tType,A: $tType,F2: A > B] :
( ( vimage @ A @ B @ F2 @ ( bot_bot @ ( set @ B ) ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% vimage_empty
thf(fact_6692_rotate__is__Nil__conv,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ( rotate @ A @ N2 @ Xs )
= ( nil @ A ) )
= ( Xs
= ( nil @ A ) ) ) ).
% rotate_is_Nil_conv
thf(fact_6693_set__rotate,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( set2 @ A @ ( rotate @ A @ N2 @ Xs ) )
= ( set2 @ A @ Xs ) ) ).
% set_rotate
thf(fact_6694_length__rotate,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( size_size @ ( list @ A ) @ ( rotate @ A @ N2 @ Xs ) )
= ( size_size @ ( list @ A ) @ Xs ) ) ).
% length_rotate
thf(fact_6695_distinct__rotate,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( distinct @ A @ ( rotate @ A @ N2 @ Xs ) )
= ( distinct @ A @ Xs ) ) ).
% distinct_rotate
thf(fact_6696_vimage__const,axiom,
! [B: $tType,A: $tType,C2: B,A4: set @ B] :
( ( ( member2 @ B @ C2 @ A4 )
=> ( ( vimage @ A @ B
@ ^ [X2: A] : C2
@ A4 )
= ( top_top @ ( set @ A ) ) ) )
& ( ~ ( member2 @ B @ C2 @ A4 )
=> ( ( vimage @ A @ B
@ ^ [X2: A] : C2
@ A4 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% vimage_const
thf(fact_6697_rotate__Suc,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( rotate @ A @ ( suc @ N2 ) @ Xs )
= ( rotate1 @ A @ ( rotate @ A @ N2 @ Xs ) ) ) ).
% rotate_Suc
thf(fact_6698_rotate0,axiom,
! [A: $tType] :
( ( rotate @ A @ ( zero_zero @ nat ) )
= ( id @ ( list @ A ) ) ) ).
% rotate0
thf(fact_6699_rotate__length01,axiom,
! [A: $tType,Xs: list @ A,N2: nat] :
( ( ord_less_eq @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) )
=> ( ( rotate @ A @ N2 @ Xs )
= Xs ) ) ).
% rotate_length01
thf(fact_6700_rotate__id,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ( modulo_modulo @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
= ( zero_zero @ nat ) )
=> ( ( rotate @ A @ N2 @ Xs )
= Xs ) ) ).
% rotate_id
thf(fact_6701_vimage__if,axiom,
! [B: $tType,A: $tType,C2: B,A4: set @ B,D2: B,B3: set @ A] :
( ( ( member2 @ B @ C2 @ A4 )
=> ( ( ( member2 @ B @ D2 @ A4 )
=> ( ( vimage @ A @ B
@ ^ [X2: A] : ( if @ B @ ( member2 @ A @ X2 @ B3 ) @ C2 @ D2 )
@ A4 )
= ( top_top @ ( set @ A ) ) ) )
& ( ~ ( member2 @ B @ D2 @ A4 )
=> ( ( vimage @ A @ B
@ ^ [X2: A] : ( if @ B @ ( member2 @ A @ X2 @ B3 ) @ C2 @ D2 )
@ A4 )
= B3 ) ) ) )
& ( ~ ( member2 @ B @ C2 @ A4 )
=> ( ( ( member2 @ B @ D2 @ A4 )
=> ( ( vimage @ A @ B
@ ^ [X2: A] : ( if @ B @ ( member2 @ A @ X2 @ B3 ) @ C2 @ D2 )
@ A4 )
= ( uminus_uminus @ ( set @ A ) @ B3 ) ) )
& ( ~ ( member2 @ B @ D2 @ A4 )
=> ( ( vimage @ A @ B
@ ^ [X2: A] : ( if @ B @ ( member2 @ A @ X2 @ B3 ) @ C2 @ D2 )
@ A4 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% vimage_if
thf(fact_6702_surj__vimage__empty,axiom,
! [B: $tType,A: $tType,F2: B > A,A4: set @ A] :
( ( ( image2 @ B @ A @ F2 @ ( top_top @ ( set @ B ) ) )
= ( top_top @ ( set @ A ) ) )
=> ( ( ( vimage @ B @ A @ F2 @ A4 )
= ( bot_bot @ ( set @ B ) ) )
= ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% surj_vimage_empty
thf(fact_6703_image__subset__iff__subset__vimage,axiom,
! [B: $tType,A: $tType,F2: B > A,A4: set @ B,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ F2 @ A4 ) @ B3 )
= ( ord_less_eq @ ( set @ B ) @ A4 @ ( vimage @ B @ A @ F2 @ B3 ) ) ) ).
% image_subset_iff_subset_vimage
thf(fact_6704_image__vimage__subset,axiom,
! [B: $tType,A: $tType,F2: B > A,A4: set @ A] : ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ F2 @ ( vimage @ B @ A @ F2 @ A4 ) ) @ A4 ) ).
% image_vimage_subset
thf(fact_6705_vimage__subsetD,axiom,
! [A: $tType,B: $tType,F2: B > A,B3: set @ A,A4: set @ B] :
( ( ( image2 @ B @ A @ F2 @ ( top_top @ ( set @ B ) ) )
= ( top_top @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ B ) @ ( vimage @ B @ A @ F2 @ B3 ) @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ B3 @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ).
% vimage_subsetD
thf(fact_6706_vimage__Suc__insert__Suc,axiom,
! [N2: nat,A4: set @ nat] :
( ( vimage @ nat @ nat @ suc @ ( insert2 @ nat @ ( suc @ N2 ) @ A4 ) )
= ( insert2 @ nat @ N2 @ ( vimage @ nat @ nat @ suc @ A4 ) ) ) ).
% vimage_Suc_insert_Suc
thf(fact_6707_vimage__singleton__eq,axiom,
! [A: $tType,B: $tType,A3: A,F2: A > B,B2: B] :
( ( member2 @ A @ A3 @ ( vimage @ A @ B @ F2 @ ( insert2 @ B @ B2 @ ( bot_bot @ ( set @ B ) ) ) ) )
= ( ( F2 @ A3 )
= B2 ) ) ).
% vimage_singleton_eq
thf(fact_6708_rotate__rotate,axiom,
! [A: $tType,M: nat,N2: nat,Xs: list @ A] :
( ( rotate @ A @ M @ ( rotate @ A @ N2 @ Xs ) )
= ( rotate @ A @ ( plus_plus @ nat @ M @ N2 ) @ Xs ) ) ).
% rotate_rotate
thf(fact_6709_rotate1__rotate__swap,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( rotate1 @ A @ ( rotate @ A @ N2 @ Xs ) )
= ( rotate @ A @ N2 @ ( rotate1 @ A @ Xs ) ) ) ).
% rotate1_rotate_swap
thf(fact_6710_finite__vimage__Suc__iff,axiom,
! [F5: set @ nat] :
( ( finite_finite @ nat @ ( vimage @ nat @ nat @ suc @ F5 ) )
= ( finite_finite @ nat @ F5 ) ) ).
% finite_vimage_Suc_iff
thf(fact_6711_rotate__def,axiom,
! [A: $tType] :
( ( rotate @ A )
= ( ^ [N: nat] : ( compow @ ( ( list @ A ) > ( list @ A ) ) @ N @ ( rotate1 @ A ) ) ) ) ).
% rotate_def
thf(fact_6712_subset__vimage__iff,axiom,
! [B: $tType,A: $tType,A4: set @ A,F2: A > B,B3: set @ B] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ ( vimage @ A @ B @ F2 @ B3 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( member2 @ B @ ( F2 @ X2 ) @ B3 ) ) ) ) ).
% subset_vimage_iff
thf(fact_6713_vimage__mono,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ A,F2: B > A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ ( set @ B ) @ ( vimage @ B @ A @ F2 @ A4 ) @ ( vimage @ B @ A @ F2 @ B3 ) ) ) ).
% vimage_mono
thf(fact_6714_rotate__map,axiom,
! [A: $tType,B: $tType,N2: nat,F2: B > A,Xs: list @ B] :
( ( rotate @ A @ N2 @ ( map @ B @ A @ F2 @ Xs ) )
= ( map @ B @ A @ F2 @ ( rotate @ B @ N2 @ Xs ) ) ) ).
% rotate_map
thf(fact_6715_Pair__vimage__Sigma,axiom,
! [B: $tType,A: $tType,X: B,A4: set @ B,F2: B > ( set @ A )] :
( ( ( member2 @ B @ X @ A4 )
=> ( ( vimage @ A @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ X ) @ ( product_Sigma @ B @ A @ A4 @ F2 ) )
= ( F2 @ X ) ) )
& ( ~ ( member2 @ B @ X @ A4 )
=> ( ( vimage @ A @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ X ) @ ( product_Sigma @ B @ A @ A4 @ F2 ) )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% Pair_vimage_Sigma
thf(fact_6716_vimage__insert,axiom,
! [A: $tType,B: $tType,F2: A > B,A3: B,B3: set @ B] :
( ( vimage @ A @ B @ F2 @ ( insert2 @ B @ A3 @ B3 ) )
= ( sup_sup @ ( set @ A ) @ ( vimage @ A @ B @ F2 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) @ ( vimage @ A @ B @ F2 @ B3 ) ) ) ).
% vimage_insert
thf(fact_6717_rotate__append,axiom,
! [A: $tType,L: list @ A,Q2: list @ A] :
( ( rotate @ A @ ( size_size @ ( list @ A ) @ L ) @ ( append @ A @ L @ Q2 ) )
= ( append @ A @ Q2 @ L ) ) ).
% rotate_append
thf(fact_6718_rotate__conv__mod,axiom,
! [A: $tType] :
( ( rotate @ A )
= ( ^ [N: nat,Xs2: list @ A] : ( rotate @ A @ ( modulo_modulo @ nat @ N @ ( size_size @ ( list @ A ) @ Xs2 ) ) @ Xs2 ) ) ) ).
% rotate_conv_mod
thf(fact_6719_continuous__imp__open__vimage,axiom,
! [A: $tType,B: $tType] :
( ( ( topolo4958980785337419405_space @ B )
& ( topolo4958980785337419405_space @ A ) )
=> ! [S: set @ A,F2: A > B,B3: set @ B] :
( ( topolo81223032696312382ous_on @ A @ B @ S @ F2 )
=> ( ( topolo1002775350975398744n_open @ A @ S )
=> ( ( topolo1002775350975398744n_open @ B @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( vimage @ A @ B @ F2 @ B3 ) @ S )
=> ( topolo1002775350975398744n_open @ A @ ( vimage @ A @ B @ F2 @ B3 ) ) ) ) ) ) ) ).
% continuous_imp_open_vimage
thf(fact_6720_vimage__Suc__insert__0,axiom,
! [A4: set @ nat] :
( ( vimage @ nat @ nat @ suc @ ( insert2 @ nat @ ( zero_zero @ nat ) @ A4 ) )
= ( vimage @ nat @ nat @ suc @ A4 ) ) ).
% vimage_Suc_insert_0
thf(fact_6721_rotate__add,axiom,
! [A: $tType,M: nat,N2: nat] :
( ( rotate @ A @ ( plus_plus @ nat @ M @ N2 ) )
= ( comp @ ( list @ A ) @ ( list @ A ) @ ( list @ A ) @ ( rotate @ A @ M ) @ ( rotate @ A @ N2 ) ) ) ).
% rotate_add
thf(fact_6722_finite__vimageD_H,axiom,
! [A: $tType,B: $tType,F2: A > B,A4: set @ B] :
( ( finite_finite @ A @ ( vimage @ A @ B @ F2 @ A4 ) )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ ( image2 @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) ) )
=> ( finite_finite @ B @ A4 ) ) ) ).
% finite_vimageD'
thf(fact_6723_inf__img__fin__dom,axiom,
! [B: $tType,A: $tType,F2: B > A,A4: set @ B] :
( ( finite_finite @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ~ ( finite_finite @ B @ A4 )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ ( image2 @ B @ A @ F2 @ A4 ) )
& ~ ( finite_finite @ B @ ( vimage @ B @ A @ F2 @ ( insert2 @ A @ X5 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% inf_img_fin_dom
thf(fact_6724_inf__img__fin__domE,axiom,
! [B: $tType,A: $tType,F2: B > A,A4: set @ B] :
( ( finite_finite @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ~ ( finite_finite @ B @ A4 )
=> ~ ! [Y4: A] :
( ( member2 @ A @ Y4 @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( finite_finite @ B @ ( vimage @ B @ A @ F2 @ ( insert2 @ A @ Y4 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% inf_img_fin_domE
thf(fact_6725_vimage__subsetI,axiom,
! [B: $tType,A: $tType,F2: A > B,B3: set @ B,A4: set @ A] :
( ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ ( image2 @ A @ B @ F2 @ A4 ) )
=> ( ord_less_eq @ ( set @ A ) @ ( vimage @ A @ B @ F2 @ B3 ) @ A4 ) ) ) ).
% vimage_subsetI
thf(fact_6726_finite__finite__vimage__IntI,axiom,
! [A: $tType,B: $tType,F5: set @ A,H2: B > A,A4: set @ B] :
( ( finite_finite @ A @ F5 )
=> ( ! [Y4: A] :
( ( member2 @ A @ Y4 @ F5 )
=> ( finite_finite @ B @ ( inf_inf @ ( set @ B ) @ ( vimage @ B @ A @ H2 @ ( insert2 @ A @ Y4 @ ( bot_bot @ ( set @ A ) ) ) ) @ A4 ) ) )
=> ( finite_finite @ B @ ( inf_inf @ ( set @ B ) @ ( vimage @ B @ A @ H2 @ F5 ) @ A4 ) ) ) ) ).
% finite_finite_vimage_IntI
thf(fact_6727_vimage__eq__UN,axiom,
! [B: $tType,A: $tType] :
( ( vimage @ A @ B )
= ( ^ [F3: A > B,B6: set @ B] :
( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [Y2: B] : ( vimage @ A @ B @ F3 @ ( insert2 @ B @ Y2 @ ( bot_bot @ ( set @ B ) ) ) )
@ B6 ) ) ) ) ).
% vimage_eq_UN
thf(fact_6728_inf__img__fin__dom_H,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B] :
( ( finite_finite @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ~ ( finite_finite @ B @ A4 )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ ( image2 @ B @ A @ F2 @ A4 ) )
& ~ ( finite_finite @ B @ ( inf_inf @ ( set @ B ) @ ( vimage @ B @ A @ F2 @ ( insert2 @ A @ X5 @ ( bot_bot @ ( set @ A ) ) ) ) @ A4 ) ) ) ) ) ).
% inf_img_fin_dom'
thf(fact_6729_inf__img__fin__domE_H,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B] :
( ( finite_finite @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( ~ ( finite_finite @ B @ A4 )
=> ~ ! [Y4: A] :
( ( member2 @ A @ Y4 @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( finite_finite @ B @ ( inf_inf @ ( set @ B ) @ ( vimage @ B @ A @ F2 @ ( insert2 @ A @ Y4 @ ( bot_bot @ ( set @ A ) ) ) ) @ A4 ) ) ) ) ) ).
% inf_img_fin_domE'
thf(fact_6730_card__vimage__inj,axiom,
! [A: $tType,B: $tType,F2: A > B,A4: set @ B] :
( ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ ( image2 @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) ) )
=> ( ( finite_card @ A @ ( vimage @ A @ B @ F2 @ A4 ) )
= ( finite_card @ B @ A4 ) ) ) ) ).
% card_vimage_inj
thf(fact_6731_card__vimage__inj__on__le,axiom,
! [A: $tType,B: $tType,F2: A > B,D6: set @ A,A4: set @ B] :
( ( inj_on @ A @ B @ F2 @ D6 )
=> ( ( finite_finite @ B @ A4 )
=> ( ord_less_eq @ nat @ ( finite_card @ A @ ( inf_inf @ ( set @ A ) @ ( vimage @ A @ B @ F2 @ A4 ) @ D6 ) ) @ ( finite_card @ B @ A4 ) ) ) ) ).
% card_vimage_inj_on_le
thf(fact_6732_rotate__rev,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( rotate @ A @ N2 @ ( rev @ A @ Xs ) )
= ( rev @ A @ ( rotate @ A @ ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( modulo_modulo @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) ) ) @ Xs ) ) ) ).
% rotate_rev
thf(fact_6733_set__decode__div__2,axiom,
! [X: nat] :
( ( nat_set_decode @ ( divide_divide @ nat @ X @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) )
= ( vimage @ nat @ nat @ suc @ ( nat_set_decode @ X ) ) ) ).
% set_decode_div_2
thf(fact_6734_set__encode__vimage__Suc,axiom,
! [A4: set @ nat] :
( ( nat_set_encode @ ( vimage @ nat @ nat @ suc @ A4 ) )
= ( divide_divide @ nat @ ( nat_set_encode @ A4 ) @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ).
% set_encode_vimage_Suc
thf(fact_6735_inv__image__partition,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o,Ys: list @ A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X5 ) )
=> ( ! [Y4: A] :
( ( member2 @ A @ Y4 @ ( set2 @ A @ Ys ) )
=> ~ ( P2 @ Y4 ) )
=> ( ( vimage @ ( list @ A ) @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( partition @ A @ P2 ) @ ( insert2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ Ys ) @ ( bot_bot @ ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) ) ) )
= ( shuffles @ A @ Xs @ Ys ) ) ) ) ).
% inv_image_partition
thf(fact_6736_nth__rotate,axiom,
! [A: $tType,N2: nat,Xs: list @ A,M: nat] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( nth @ A @ ( rotate @ A @ M @ Xs ) @ N2 )
= ( nth @ A @ Xs @ ( modulo_modulo @ nat @ ( plus_plus @ nat @ M @ N2 ) @ ( size_size @ ( list @ A ) @ Xs ) ) ) ) ) ).
% nth_rotate
thf(fact_6737_hd__rotate__conv__nth,axiom,
! [A: $tType,Xs: list @ A,N2: nat] :
( ( Xs
!= ( nil @ A ) )
=> ( ( hd @ A @ ( rotate @ A @ N2 @ Xs ) )
= ( nth @ A @ Xs @ ( modulo_modulo @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) ) ) ) ) ).
% hd_rotate_conv_nth
thf(fact_6738_inj__on__vimage__singleton,axiom,
! [B: $tType,A: $tType,F2: A > B,A4: set @ A,A3: B] :
( ( inj_on @ A @ B @ F2 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ ( vimage @ A @ B @ F2 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) @ A4 )
@ ( insert2 @ A
@ ( the @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ A4 )
& ( ( F2 @ X2 )
= A3 ) ) )
@ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% inj_on_vimage_singleton
thf(fact_6739_inj__vimage__singleton,axiom,
! [B: $tType,A: $tType,F2: A > B,A3: B] :
( ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
=> ( ord_less_eq @ ( set @ A ) @ ( vimage @ A @ B @ F2 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) )
@ ( insert2 @ A
@ ( the @ A
@ ^ [X2: A] :
( ( F2 @ X2 )
= A3 ) )
@ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% inj_vimage_singleton
thf(fact_6740_The__split__eq,axiom,
! [A: $tType,B: $tType,X: A,Y: B] :
( ( the @ ( product_prod @ A @ B )
@ ( product_case_prod @ A @ B @ $o
@ ^ [X10: A,Y7: B] :
( ( X = X10 )
& ( Y = Y7 ) ) ) )
= ( product_Pair @ A @ B @ X @ Y ) ) ).
% The_split_eq
thf(fact_6741_the__elem__def,axiom,
! [A: $tType] :
( ( the_elem @ A )
= ( ^ [X8: set @ A] :
( the @ A
@ ^ [X2: A] :
( X8
= ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% the_elem_def
thf(fact_6742_old_Orec__nat__def,axiom,
! [T: $tType] :
( ( rec_nat @ T )
= ( ^ [F13: T,F23: nat > T > T,X2: nat] : ( the @ T @ ( rec_set_nat @ T @ F13 @ F23 @ X2 ) ) ) ) ).
% old.rec_nat_def
thf(fact_6743_Greatest__def,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( order_Greatest @ A )
= ( ^ [P: A > $o] :
( the @ A
@ ^ [X2: A] :
( ( P @ X2 )
& ! [Y2: A] :
( ( P @ Y2 )
=> ( ord_less_eq @ A @ Y2 @ X2 ) ) ) ) ) ) ) ).
% Greatest_def
thf(fact_6744_GreatestI__nat,axiom,
! [P2: nat > $o,K: nat,B2: nat] :
( ( P2 @ K )
=> ( ! [Y4: nat] :
( ( P2 @ Y4 )
=> ( ord_less_eq @ nat @ Y4 @ B2 ) )
=> ( P2 @ ( order_Greatest @ nat @ P2 ) ) ) ) ).
% GreatestI_nat
thf(fact_6745_Greatest__le__nat,axiom,
! [P2: nat > $o,K: nat,B2: nat] :
( ( P2 @ K )
=> ( ! [Y4: nat] :
( ( P2 @ Y4 )
=> ( ord_less_eq @ nat @ Y4 @ B2 ) )
=> ( ord_less_eq @ nat @ K @ ( order_Greatest @ nat @ P2 ) ) ) ) ).
% Greatest_le_nat
thf(fact_6746_GreatestI__ex__nat,axiom,
! [P2: nat > $o,B2: nat] :
( ? [X_1: nat] : ( P2 @ X_1 )
=> ( ! [Y4: nat] :
( ( P2 @ Y4 )
=> ( ord_less_eq @ nat @ Y4 @ B2 ) )
=> ( P2 @ ( order_Greatest @ nat @ P2 ) ) ) ) ).
% GreatestI_ex_nat
thf(fact_6747_Greatest__equality,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [P2: A > $o,X: A] :
( ( P2 @ X )
=> ( ! [Y4: A] :
( ( P2 @ Y4 )
=> ( ord_less_eq @ A @ Y4 @ X ) )
=> ( ( order_Greatest @ A @ P2 )
= X ) ) ) ) ).
% Greatest_equality
thf(fact_6748_GreatestI2__order,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [P2: A > $o,X: A,Q: A > $o] :
( ( P2 @ X )
=> ( ! [Y4: A] :
( ( P2 @ Y4 )
=> ( ord_less_eq @ A @ Y4 @ X ) )
=> ( ! [X5: A] :
( ( P2 @ X5 )
=> ( ! [Y3: A] :
( ( P2 @ Y3 )
=> ( ord_less_eq @ A @ Y3 @ X5 ) )
=> ( Q @ X5 ) ) )
=> ( Q @ ( order_Greatest @ A @ P2 ) ) ) ) ) ) ).
% GreatestI2_order
thf(fact_6749_flat__lub__def,axiom,
! [A: $tType] :
( ( partial_flat_lub @ A )
= ( ^ [B4: A,A6: set @ A] :
( if @ A @ ( ord_less_eq @ ( set @ A ) @ A6 @ ( insert2 @ A @ B4 @ ( bot_bot @ ( set @ A ) ) ) ) @ B4
@ ( the @ A
@ ^ [X2: A] : ( member2 @ A @ X2 @ ( minus_minus @ ( set @ A ) @ A6 @ ( insert2 @ A @ B4 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ).
% flat_lub_def
thf(fact_6750_total__on__singleton,axiom,
! [A: $tType,X: A] : ( total_on @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) @ ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ X ) @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ) ).
% total_on_singleton
thf(fact_6751_total__lenlex,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( total_on @ A @ ( top_top @ ( set @ A ) ) @ R2 )
=> ( total_on @ ( list @ A ) @ ( top_top @ ( set @ ( list @ A ) ) ) @ ( lenlex @ A @ R2 ) ) ) ).
% total_lenlex
thf(fact_6752_total__lexord,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( total_on @ A @ ( top_top @ ( set @ A ) ) @ R2 )
=> ( total_on @ ( list @ A ) @ ( top_top @ ( set @ ( list @ A ) ) ) @ ( lexord @ A @ R2 ) ) ) ).
% total_lexord
thf(fact_6753_total__on__empty,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] : ( total_on @ A @ ( bot_bot @ ( set @ A ) ) @ R2 ) ).
% total_on_empty
thf(fact_6754_total__on__def,axiom,
! [A: $tType] :
( ( total_on @ A )
= ( ^ [A6: set @ A,R4: set @ ( product_prod @ A @ A )] :
! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ! [Y2: A] :
( ( member2 @ A @ Y2 @ A6 )
=> ( ( X2 != Y2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R4 )
| ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y2 @ X2 ) @ R4 ) ) ) ) ) ) ) ).
% total_on_def
thf(fact_6755_total__onI,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A )] :
( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ( member2 @ A @ Y4 @ A4 )
=> ( ( X5 != Y4 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Y4 ) @ R2 )
| ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ X5 ) @ R2 ) ) ) ) )
=> ( total_on @ A @ A4 @ R2 ) ) ).
% total_onI
thf(fact_6756_Total__subset__Id,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( total_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R2 @ ( id2 @ A ) )
=> ( ( R2
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
| ? [A7: A] :
( R2
= ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A7 @ A7 ) @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ) ) ) ) ).
% Total_subset_Id
thf(fact_6757_slice__eq__mask,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [N2: nat,M: nat,A3: A] :
( ( bit_se4730199178511100633sh_bit @ A @ N2 @ ( bit_se2584673776208193580ke_bit @ A @ M @ ( bit_se4197421643247451524op_bit @ A @ N2 @ A3 ) ) )
= ( bit_se5824344872417868541ns_and @ A @ A3 @ ( bit_se5824344872417868541ns_and @ A @ ( bit_se2239418461657761734s_mask @ A @ ( plus_plus @ nat @ M @ N2 ) ) @ ( bit_ri4277139882892585799ns_not @ A @ ( bit_se2239418461657761734s_mask @ A @ N2 ) ) ) ) ) ) ).
% slice_eq_mask
thf(fact_6758_bit_Oconj__cancel__right,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [X: A] :
( ( bit_se5824344872417868541ns_and @ A @ X @ ( bit_ri4277139882892585799ns_not @ A @ X ) )
= ( zero_zero @ A ) ) ) ).
% bit.conj_cancel_right
thf(fact_6759_bit_Oconj__cancel__left,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [X: A] :
( ( bit_se5824344872417868541ns_and @ A @ ( bit_ri4277139882892585799ns_not @ A @ X ) @ X )
= ( zero_zero @ A ) ) ) ).
% bit.conj_cancel_left
thf(fact_6760_Field__empty,axiom,
! [A: $tType] :
( ( field2 @ A @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% Field_empty
thf(fact_6761_bit_Ocompl__zero,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ( ( bit_ri4277139882892585799ns_not @ A @ ( zero_zero @ A ) )
= ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% bit.compl_zero
thf(fact_6762_bit_Ocompl__one,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ( ( bit_ri4277139882892585799ns_not @ A @ ( uminus_uminus @ A @ ( one_one @ A ) ) )
= ( zero_zero @ A ) ) ) ).
% bit.compl_one
thf(fact_6763_Field__insert,axiom,
! [A: $tType,A3: A,B2: A,R2: set @ ( product_prod @ A @ A )] :
( ( field2 @ A @ ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 ) )
= ( sup_sup @ ( set @ A ) @ ( insert2 @ A @ A3 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) @ ( field2 @ A @ R2 ) ) ) ).
% Field_insert
thf(fact_6764_FieldI1,axiom,
! [A: $tType,I: A,J: A,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ I @ J ) @ R )
=> ( member2 @ A @ I @ ( field2 @ A @ R ) ) ) ).
% FieldI1
thf(fact_6765_FieldI2,axiom,
! [A: $tType,I: A,J: A,R: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ I @ J ) @ R )
=> ( member2 @ A @ J @ ( field2 @ A @ R ) ) ) ).
% FieldI2
thf(fact_6766_not__add__distrib,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [A3: A,B2: A] :
( ( bit_ri4277139882892585799ns_not @ A @ ( plus_plus @ A @ A3 @ B2 ) )
= ( minus_minus @ A @ ( bit_ri4277139882892585799ns_not @ A @ A3 ) @ B2 ) ) ) ).
% not_add_distrib
thf(fact_6767_not__diff__distrib,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [A3: A,B2: A] :
( ( bit_ri4277139882892585799ns_not @ A @ ( minus_minus @ A @ A3 @ B2 ) )
= ( plus_plus @ A @ ( bit_ri4277139882892585799ns_not @ A @ A3 ) @ B2 ) ) ) ).
% not_diff_distrib
thf(fact_6768_mono__Field,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),S: set @ ( product_prod @ A @ A )] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R2 @ S )
=> ( ord_less_eq @ ( set @ A ) @ ( field2 @ A @ R2 ) @ ( field2 @ A @ S ) ) ) ).
% mono_Field
thf(fact_6769_minus__eq__not__plus__1,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ( ( uminus_uminus @ A )
= ( ^ [A5: A] : ( plus_plus @ A @ ( bit_ri4277139882892585799ns_not @ A @ A5 ) @ ( one_one @ A ) ) ) ) ) ).
% minus_eq_not_plus_1
thf(fact_6770_Linear__order__in__diff__Id,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( order_679001287576687338der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ B2 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
= ( ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ A3 ) @ ( minus_minus @ ( set @ ( product_prod @ A @ A ) ) @ R2 @ ( id2 @ A ) ) ) ) ) ) ) ) ).
% Linear_order_in_diff_Id
thf(fact_6771_Field__Restr__subset,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A] :
( ord_less_eq @ ( set @ A )
@ ( field2 @ A
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : A4 ) ) )
@ A4 ) ).
% Field_Restr_subset
thf(fact_6772_take__bit__not__mask__eq__0,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( bit_se2584673776208193580ke_bit @ A @ M @ ( bit_ri4277139882892585799ns_not @ A @ ( bit_se2239418461657761734s_mask @ A @ N2 ) ) )
= ( zero_zero @ A ) ) ) ) ).
% take_bit_not_mask_eq_0
thf(fact_6773_push__bit__mask__eq,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [M: nat,N2: nat] :
( ( bit_se4730199178511100633sh_bit @ A @ M @ ( bit_se2239418461657761734s_mask @ A @ N2 ) )
= ( bit_se5824344872417868541ns_and @ A @ ( bit_se2239418461657761734s_mask @ A @ ( plus_plus @ nat @ N2 @ M ) ) @ ( bit_ri4277139882892585799ns_not @ A @ ( bit_se2239418461657761734s_mask @ A @ M ) ) ) ) ) ).
% push_bit_mask_eq
thf(fact_6774_Refl__Field__Restr2,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A] :
( ( refl_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( field2 @ A @ R2 ) )
=> ( ( field2 @ A
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : A4 ) ) )
= A4 ) ) ) ).
% Refl_Field_Restr2
thf(fact_6775_bit_Ocompl__unique,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [X: A,Y: A] :
( ( ( bit_se5824344872417868541ns_and @ A @ X @ Y )
= ( zero_zero @ A ) )
=> ( ( ( bit_se1065995026697491101ons_or @ A @ X @ Y )
= ( uminus_uminus @ A @ ( one_one @ A ) ) )
=> ( ( bit_ri4277139882892585799ns_not @ A @ X )
= Y ) ) ) ) ).
% bit.compl_unique
thf(fact_6776_bit__not__iff__eq,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [A3: A,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( bit_ri4277139882892585799ns_not @ A @ A3 ) @ N2 )
= ( ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 )
!= ( zero_zero @ A ) )
& ~ ( bit_se5641148757651400278ts_bit @ A @ A3 @ N2 ) ) ) ) ).
% bit_not_iff_eq
thf(fact_6777_Under__def,axiom,
! [A: $tType] :
( ( order_Under @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A ),A6: set @ A] :
( collect @ A
@ ^ [B4: A] :
( ( member2 @ A @ B4 @ ( field2 @ A @ R4 ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B4 @ X2 ) @ R4 ) ) ) ) ) ) ).
% Under_def
thf(fact_6778_UnderS__def,axiom,
! [A: $tType] :
( ( order_UnderS @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A ),A6: set @ A] :
( collect @ A
@ ^ [B4: A] :
( ( member2 @ A @ B4 @ ( field2 @ A @ R4 ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( ( B4 != X2 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B4 @ X2 ) @ R4 ) ) ) ) ) ) ) ).
% UnderS_def
thf(fact_6779_Above__def,axiom,
! [A: $tType] :
( ( order_Above @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A ),A6: set @ A] :
( collect @ A
@ ^ [B4: A] :
( ( member2 @ A @ B4 @ ( field2 @ A @ R4 ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ B4 ) @ R4 ) ) ) ) ) ) ).
% Above_def
thf(fact_6780_Field__natLeq__on,axiom,
! [N2: nat] :
( ( field2 @ nat
@ ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [X2: nat,Y2: nat] :
( ( ord_less @ nat @ X2 @ N2 )
& ( ord_less @ nat @ Y2 @ N2 )
& ( ord_less_eq @ nat @ X2 @ Y2 ) ) ) ) )
= ( collect @ nat
@ ^ [X2: nat] : ( ord_less @ nat @ X2 @ N2 ) ) ) ).
% Field_natLeq_on
thf(fact_6781_relChain__def,axiom,
! [B: $tType,A: $tType] :
( ( ord @ B )
=> ( ( bNF_Ca3754400796208372196lChain @ A @ B )
= ( ^ [R4: set @ ( product_prod @ A @ A ),As4: A > B] :
! [I5: A,J3: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ I5 @ J3 ) @ R4 )
=> ( ord_less_eq @ B @ ( As4 @ I5 ) @ ( As4 @ J3 ) ) ) ) ) ) ).
% relChain_def
thf(fact_6782_natLess__def,axiom,
( bNF_Ca8459412986667044542atLess
= ( collect @ ( product_prod @ nat @ nat ) @ ( product_case_prod @ nat @ nat @ $o @ ( ord_less @ nat ) ) ) ) ).
% natLess_def
thf(fact_6783_bit_Oabstract__boolean__algebra__sym__diff__axioms,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ( boolea3799213064322606851m_diff @ A @ ( bit_se5824344872417868541ns_and @ A ) @ ( bit_se1065995026697491101ons_or @ A ) @ ( bit_ri4277139882892585799ns_not @ A ) @ ( zero_zero @ A ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) @ ( bit_se5824344971392196577ns_xor @ A ) ) ) ).
% bit.abstract_boolean_algebra_sym_diff_axioms
thf(fact_6784_cofinal__def,axiom,
! [A: $tType] :
( ( bNF_Ca7293521722713021262ofinal @ A )
= ( ^ [A6: set @ A,R4: set @ ( product_prod @ A @ A )] :
! [X2: A] :
( ( member2 @ A @ X2 @ ( field2 @ A @ R4 ) )
=> ? [Y2: A] :
( ( member2 @ A @ Y2 @ A6 )
& ( X2 != Y2 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R4 ) ) ) ) ) ).
% cofinal_def
thf(fact_6785_bsqr__def,axiom,
! [A: $tType] :
( ( bNF_Wellorder_bsqr @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
( collect @ ( product_prod @ ( product_prod @ A @ A ) @ ( product_prod @ A @ A ) )
@ ( product_case_prod @ ( product_prod @ A @ A ) @ ( product_prod @ A @ A ) @ $o
@ ( product_case_prod @ A @ A @ ( ( product_prod @ A @ A ) > $o )
@ ^ [A1: A,A22: A] :
( product_case_prod @ A @ A @ $o
@ ^ [B13: A,B23: A] :
( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ A1 @ ( insert2 @ A @ A22 @ ( insert2 @ A @ B13 @ ( insert2 @ A @ B23 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) @ ( field2 @ A @ R4 ) )
& ( ( ( A1 = B13 )
& ( A22 = B23 ) )
| ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ ( bNF_We1388413361240627857o_max2 @ A @ R4 @ A1 @ A22 ) @ ( bNF_We1388413361240627857o_max2 @ A @ R4 @ B13 @ B23 ) ) @ ( minus_minus @ ( set @ ( product_prod @ A @ A ) ) @ R4 @ ( id2 @ A ) ) )
| ( ( ( bNF_We1388413361240627857o_max2 @ A @ R4 @ A1 @ A22 )
= ( bNF_We1388413361240627857o_max2 @ A @ R4 @ B13 @ B23 ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A1 @ B13 ) @ ( minus_minus @ ( set @ ( product_prod @ A @ A ) ) @ R4 @ ( id2 @ A ) ) ) )
| ( ( ( bNF_We1388413361240627857o_max2 @ A @ R4 @ A1 @ A22 )
= ( bNF_We1388413361240627857o_max2 @ A @ R4 @ B13 @ B23 ) )
& ( A1 = B13 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A22 @ B23 ) @ ( minus_minus @ ( set @ ( product_prod @ A @ A ) ) @ R4 @ ( id2 @ A ) ) ) ) ) ) ) ) ) ) ) ) ).
% bsqr_def
thf(fact_6786_bit_Oabstract__boolean__algebra__axioms,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ( boolea2506097494486148201lgebra @ A @ ( bit_se5824344872417868541ns_and @ A ) @ ( bit_se1065995026697491101ons_or @ A ) @ ( bit_ri4277139882892585799ns_not @ A ) @ ( zero_zero @ A ) @ ( uminus_uminus @ A @ ( one_one @ A ) ) ) ) ).
% bit.abstract_boolean_algebra_axioms
thf(fact_6787_boolean__algebra_Oabstract__boolean__algebra__axioms,axiom,
! [A: $tType] :
( ( boolea8198339166811842893lgebra @ A )
=> ( boolea2506097494486148201lgebra @ A @ ( inf_inf @ A ) @ ( sup_sup @ A ) @ ( uminus_uminus @ A ) @ ( bot_bot @ A ) @ ( top_top @ A ) ) ) ).
% boolean_algebra.abstract_boolean_algebra_axioms
thf(fact_6788_Linear__order__wf__diff__Id,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( order_679001287576687338der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( wf @ A @ ( minus_minus @ ( set @ ( product_prod @ A @ A ) ) @ R2 @ ( id2 @ A ) ) )
= ( ! [A6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A6 @ ( field2 @ A @ R2 ) )
=> ( ( A6
!= ( bot_bot @ ( set @ A ) ) )
=> ? [X2: A] :
( ( member2 @ A @ X2 @ A6 )
& ! [Y2: A] :
( ( member2 @ A @ Y2 @ A6 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R2 ) ) ) ) ) ) ) ) ).
% Linear_order_wf_diff_Id
thf(fact_6789_Restr__natLeq,axiom,
! [N2: nat] :
( ( inf_inf @ ( set @ ( product_prod @ nat @ nat ) ) @ bNF_Ca8665028551170535155natLeq
@ ( product_Sigma @ nat @ nat
@ ( collect @ nat
@ ^ [X2: nat] : ( ord_less @ nat @ X2 @ N2 ) )
@ ^ [Uu3: nat] :
( collect @ nat
@ ^ [X2: nat] : ( ord_less @ nat @ X2 @ N2 ) ) ) )
= ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [X2: nat,Y2: nat] :
( ( ord_less @ nat @ X2 @ N2 )
& ( ord_less @ nat @ Y2 @ N2 )
& ( ord_less_eq @ nat @ X2 @ Y2 ) ) ) ) ) ).
% Restr_natLeq
thf(fact_6790_wf__empty,axiom,
! [A: $tType] : ( wf @ A @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ).
% wf_empty
thf(fact_6791_wf__listrel1__iff,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( wf @ ( list @ A ) @ ( listrel1 @ A @ R2 ) )
= ( wf @ A @ R2 ) ) ).
% wf_listrel1_iff
thf(fact_6792_wf__lex,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( wf @ A @ R2 )
=> ( wf @ ( list @ A ) @ ( lex @ A @ R2 ) ) ) ).
% wf_lex
thf(fact_6793_wf__lenlex,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( wf @ A @ R2 )
=> ( wf @ ( list @ A ) @ ( lenlex @ A @ R2 ) ) ) ).
% wf_lenlex
thf(fact_6794_wf__insert,axiom,
! [A: $tType,Y: A,X: A,R2: set @ ( product_prod @ A @ A )] :
( ( wf @ A @ ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ X ) @ R2 ) )
= ( ( wf @ A @ R2 )
& ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ).
% wf_insert
thf(fact_6795_wf__induct__rule,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),P2: A > $o,A3: A] :
( ( wf @ A @ R2 )
=> ( ! [X5: A] :
( ! [Y3: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y3 @ X5 ) @ R2 )
=> ( P2 @ Y3 ) )
=> ( P2 @ X5 ) )
=> ( P2 @ A3 ) ) ) ).
% wf_induct_rule
thf(fact_6796_wf__eq__minimal,axiom,
! [A: $tType] :
( ( wf @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
! [Q6: set @ A] :
( ? [X2: A] : ( member2 @ A @ X2 @ Q6 )
=> ? [X2: A] :
( ( member2 @ A @ X2 @ Q6 )
& ! [Y2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y2 @ X2 ) @ R4 )
=> ~ ( member2 @ A @ Y2 @ Q6 ) ) ) ) ) ) ).
% wf_eq_minimal
thf(fact_6797_wf__not__refl,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A] :
( ( wf @ A @ R2 )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ A3 ) @ R2 ) ) ).
% wf_not_refl
thf(fact_6798_wf__not__sym,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,X: A] :
( ( wf @ A @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ X ) @ R2 )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ A3 ) @ R2 ) ) ) ).
% wf_not_sym
thf(fact_6799_wf__irrefl,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A] :
( ( wf @ A @ R2 )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ A3 ) @ R2 ) ) ).
% wf_irrefl
thf(fact_6800_wf__induct,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),P2: A > $o,A3: A] :
( ( wf @ A @ R2 )
=> ( ! [X5: A] :
( ! [Y3: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y3 @ X5 ) @ R2 )
=> ( P2 @ Y3 ) )
=> ( P2 @ X5 ) )
=> ( P2 @ A3 ) ) ) ).
% wf_induct
thf(fact_6801_wf__asym,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,X: A] :
( ( wf @ A @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ X ) @ R2 )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ A3 ) @ R2 ) ) ) ).
% wf_asym
thf(fact_6802_wfUNIVI,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ! [P8: A > $o,X5: A] :
( ! [Xa: A] :
( ! [Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Xa ) @ R2 )
=> ( P8 @ Y4 ) )
=> ( P8 @ Xa ) )
=> ( P8 @ X5 ) )
=> ( wf @ A @ R2 ) ) ).
% wfUNIVI
thf(fact_6803_wfI__min,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A )] :
( ! [X5: A,Q7: set @ A] :
( ( member2 @ A @ X5 @ Q7 )
=> ? [Xa: A] :
( ( member2 @ A @ Xa @ Q7 )
& ! [Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Xa ) @ R )
=> ~ ( member2 @ A @ Y4 @ Q7 ) ) ) )
=> ( wf @ A @ R ) ) ).
% wfI_min
thf(fact_6804_wfE__min,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A ),X: A,Q: set @ A] :
( ( wf @ A @ R )
=> ( ( member2 @ A @ X @ Q )
=> ~ ! [Z2: A] :
( ( member2 @ A @ Z2 @ Q )
=> ~ ! [Y3: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y3 @ Z2 ) @ R )
=> ~ ( member2 @ A @ Y3 @ Q ) ) ) ) ) ).
% wfE_min
thf(fact_6805_wf__def,axiom,
! [A: $tType] :
( ( wf @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
! [P: A > $o] :
( ! [X2: A] :
( ! [Y2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y2 @ X2 ) @ R4 )
=> ( P @ Y2 ) )
=> ( P @ X2 ) )
=> ! [X8: A] : ( P @ X8 ) ) ) ) ).
% wf_def
thf(fact_6806_wf__no__infinite__down__chainE,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),F2: nat > A] :
( ( wf @ A @ R2 )
=> ~ ! [K3: nat] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ ( F2 @ ( suc @ K3 ) ) @ ( F2 @ K3 ) ) @ R2 ) ) ).
% wf_no_infinite_down_chainE
thf(fact_6807_wf__iff__no__infinite__down__chain,axiom,
! [A: $tType] :
( ( wf @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
~ ? [F3: nat > A] :
! [I5: nat] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ ( F3 @ ( suc @ I5 ) ) @ ( F3 @ I5 ) ) @ R4 ) ) ) ).
% wf_iff_no_infinite_down_chain
thf(fact_6808_wfE__min_H,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A ),Q: set @ A] :
( ( wf @ A @ R )
=> ( ( Q
!= ( bot_bot @ ( set @ A ) ) )
=> ~ ! [Z2: A] :
( ( member2 @ A @ Z2 @ Q )
=> ~ ! [Y3: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y3 @ Z2 ) @ R )
=> ~ ( member2 @ A @ Y3 @ Q ) ) ) ) ) ).
% wfE_min'
thf(fact_6809_wf__no__loop,axiom,
! [B: $tType,R: set @ ( product_prod @ B @ B )] :
( ( ( relcomp @ B @ B @ B @ R @ R )
= ( bot_bot @ ( set @ ( product_prod @ B @ B ) ) ) )
=> ( wf @ B @ R ) ) ).
% wf_no_loop
thf(fact_6810_wf__int__ge__less__than2,axiom,
! [D2: int] : ( wf @ int @ ( int_ge_less_than2 @ D2 ) ) ).
% wf_int_ge_less_than2
thf(fact_6811_wf__int__ge__less__than,axiom,
! [D2: int] : ( wf @ int @ ( int_ge_less_than @ D2 ) ) ).
% wf_int_ge_less_than
thf(fact_6812_wf__lexn,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),N2: nat] :
( ( wf @ A @ R2 )
=> ( wf @ ( list @ A ) @ ( lexn @ A @ R2 @ N2 ) ) ) ).
% wf_lexn
thf(fact_6813_wf__less,axiom,
wf @ nat @ ( collect @ ( product_prod @ nat @ nat ) @ ( product_case_prod @ nat @ nat @ $o @ ( ord_less @ nat ) ) ) ).
% wf_less
thf(fact_6814_wf__if__measure,axiom,
! [A: $tType,P2: A > $o,F2: A > nat,G: A > A] :
( ! [X5: A] :
( ( P2 @ X5 )
=> ( ord_less @ nat @ ( F2 @ ( G @ X5 ) ) @ ( F2 @ X5 ) ) )
=> ( wf @ A
@ ( collect @ ( product_prod @ A @ A )
@ ( product_case_prod @ A @ A @ $o
@ ^ [Y2: A,X2: A] :
( ( P2 @ X2 )
& ( Y2
= ( G @ X2 ) ) ) ) ) ) ) ).
% wf_if_measure
thf(fact_6815_wf,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ( wf @ A @ ( collect @ ( product_prod @ A @ A ) @ ( product_case_prod @ A @ A @ $o @ ( ord_less @ A ) ) ) ) ) ).
% wf
thf(fact_6816_wf__bounded__measure,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),Ub: A > nat,F2: A > nat] :
( ! [A7: A,B5: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B5 @ A7 ) @ R2 )
=> ( ( ord_less_eq @ nat @ ( Ub @ B5 ) @ ( Ub @ A7 ) )
& ( ord_less_eq @ nat @ ( F2 @ B5 ) @ ( Ub @ A7 ) )
& ( ord_less @ nat @ ( F2 @ A7 ) @ ( F2 @ B5 ) ) ) )
=> ( wf @ A @ R2 ) ) ).
% wf_bounded_measure
thf(fact_6817_wf__linord__ex__has__least,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A ),P2: B > $o,K: B,M: B > A] :
( ( wf @ A @ R2 )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Y4 ) @ ( transitive_trancl @ A @ R2 ) )
= ( ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ X5 ) @ ( transitive_rtrancl @ A @ R2 ) ) ) )
=> ( ( P2 @ K )
=> ? [X5: B] :
( ( P2 @ X5 )
& ! [Y3: B] :
( ( P2 @ Y3 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ ( M @ X5 ) @ ( M @ Y3 ) ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ) ) ) ).
% wf_linord_ex_has_least
thf(fact_6818_wfI,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : B3 ) )
=> ( ! [X5: A,P8: A > $o] :
( ! [Xa: A] :
( ! [Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Xa ) @ R2 )
=> ( P8 @ Y4 ) )
=> ( P8 @ Xa ) )
=> ( ( member2 @ A @ X5 @ A4 )
=> ( ( member2 @ A @ X5 @ B3 )
=> ( P8 @ X5 ) ) ) )
=> ( wf @ A @ R2 ) ) ) ).
% wfI
thf(fact_6819_natLeq__def,axiom,
( bNF_Ca8665028551170535155natLeq
= ( collect @ ( product_prod @ nat @ nat ) @ ( product_case_prod @ nat @ nat @ $o @ ( ord_less_eq @ nat ) ) ) ) ).
% natLeq_def
thf(fact_6820_wf__eq__minimal2,axiom,
! [A: $tType] :
( ( wf @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
! [A6: set @ A] :
( ( ( ord_less_eq @ ( set @ A ) @ A6 @ ( field2 @ A @ R4 ) )
& ( A6
!= ( bot_bot @ ( set @ A ) ) ) )
=> ? [X2: A] :
( ( member2 @ A @ X2 @ A6 )
& ! [Y2: A] :
( ( member2 @ A @ Y2 @ A6 )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y2 @ X2 ) @ R4 ) ) ) ) ) ) ).
% wf_eq_minimal2
thf(fact_6821_wf__bounded__set,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A ),Ub: A > ( set @ B ),F2: A > ( set @ B )] :
( ! [A7: A,B5: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B5 @ A7 ) @ R2 )
=> ( ( finite_finite @ B @ ( Ub @ A7 ) )
& ( ord_less_eq @ ( set @ B ) @ ( Ub @ B5 ) @ ( Ub @ A7 ) )
& ( ord_less_eq @ ( set @ B ) @ ( F2 @ B5 ) @ ( Ub @ A7 ) )
& ( ord_less @ ( set @ B ) @ ( F2 @ A7 ) @ ( F2 @ B5 ) ) ) )
=> ( wf @ A @ R2 ) ) ).
% wf_bounded_set
thf(fact_6822_finite__subset__wf,axiom,
! [A: $tType,A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( wf @ ( set @ A )
@ ( collect @ ( product_prod @ ( set @ A ) @ ( set @ A ) )
@ ( product_case_prod @ ( set @ A ) @ ( set @ A ) @ $o
@ ^ [X8: set @ A,Y9: set @ A] :
( ( ord_less @ ( set @ A ) @ X8 @ Y9 )
& ( ord_less_eq @ ( set @ A ) @ Y9 @ A4 ) ) ) ) ) ) ).
% finite_subset_wf
thf(fact_6823_Restr__natLeq2,axiom,
! [N2: nat] :
( ( inf_inf @ ( set @ ( product_prod @ nat @ nat ) ) @ bNF_Ca8665028551170535155natLeq
@ ( product_Sigma @ nat @ nat @ ( order_underS @ nat @ bNF_Ca8665028551170535155natLeq @ N2 )
@ ^ [Uu3: nat] : ( order_underS @ nat @ bNF_Ca8665028551170535155natLeq @ N2 ) ) )
= ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [X2: nat,Y2: nat] :
( ( ord_less @ nat @ X2 @ N2 )
& ( ord_less @ nat @ Y2 @ N2 )
& ( ord_less_eq @ nat @ X2 @ Y2 ) ) ) ) ) ).
% Restr_natLeq2
thf(fact_6824_dependent__wf__choice,axiom,
! [B: $tType,A: $tType,R: set @ ( product_prod @ A @ A ),P2: ( A > B ) > A > B > $o] :
( ( wf @ A @ R )
=> ( ! [F4: A > B,G4: A > B,X5: A,R3: B] :
( ! [Z4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Z4 @ X5 ) @ R )
=> ( ( F4 @ Z4 )
= ( G4 @ Z4 ) ) )
=> ( ( P2 @ F4 @ X5 @ R3 )
= ( P2 @ G4 @ X5 @ R3 ) ) )
=> ( ! [X5: A,F4: A > B] :
( ! [Y3: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y3 @ X5 ) @ R )
=> ( P2 @ F4 @ Y3 @ ( F4 @ Y3 ) ) )
=> ? [X_1: B] : ( P2 @ F4 @ X5 @ X_1 ) )
=> ? [F4: A > B] :
! [X3: A] : ( P2 @ F4 @ X3 @ ( F4 @ X3 ) ) ) ) ) ).
% dependent_wf_choice
thf(fact_6825_underS__empty,axiom,
! [A: $tType,A3: A,R2: set @ ( product_prod @ A @ A )] :
( ~ ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( order_underS @ A @ R2 @ A3 )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% underS_empty
thf(fact_6826_Order__Relation_OunderS__Field,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A] : ( ord_less_eq @ ( set @ A ) @ ( order_underS @ A @ R2 @ A3 ) @ ( field2 @ A @ R2 ) ) ).
% Order_Relation.underS_Field
thf(fact_6827_underS__I,axiom,
! [A: $tType,I: A,J: A,R: set @ ( product_prod @ A @ A )] :
( ( I != J )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ I @ J ) @ R )
=> ( member2 @ A @ I @ ( order_underS @ A @ R @ J ) ) ) ) ).
% underS_I
thf(fact_6828_underS__E,axiom,
! [A: $tType,I: A,R: set @ ( product_prod @ A @ A ),J: A] :
( ( member2 @ A @ I @ ( order_underS @ A @ R @ J ) )
=> ( ( I != J )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ I @ J ) @ R ) ) ) ).
% underS_E
thf(fact_6829_underS__def,axiom,
! [A: $tType] :
( ( order_underS @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A ),A5: A] :
( collect @ A
@ ^ [B4: A] :
( ( B4 != A5 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B4 @ A5 ) @ R4 ) ) ) ) ) ).
% underS_def
thf(fact_6830_natLeq__underS__less,axiom,
! [N2: nat] :
( ( order_underS @ nat @ bNF_Ca8665028551170535155natLeq @ N2 )
= ( collect @ nat
@ ^ [X2: nat] : ( ord_less @ nat @ X2 @ N2 ) ) ) ).
% natLeq_underS_less
thf(fact_6831_dependent__wellorder__choice,axiom,
! [B: $tType,A: $tType] :
( ( wellorder @ A )
=> ! [P2: ( A > B ) > A > B > $o] :
( ! [R3: B,F4: A > B,G4: A > B,X5: A] :
( ! [Y3: A] :
( ( ord_less @ A @ Y3 @ X5 )
=> ( ( F4 @ Y3 )
= ( G4 @ Y3 ) ) )
=> ( ( P2 @ F4 @ X5 @ R3 )
= ( P2 @ G4 @ X5 @ R3 ) ) )
=> ( ! [X5: A,F4: A > B] :
( ! [Y3: A] :
( ( ord_less @ A @ Y3 @ X5 )
=> ( P2 @ F4 @ Y3 @ ( F4 @ Y3 ) ) )
=> ? [X_1: B] : ( P2 @ F4 @ X5 @ X_1 ) )
=> ? [F4: A > B] :
! [X3: A] : ( P2 @ F4 @ X3 @ ( F4 @ X3 ) ) ) ) ) ).
% dependent_wellorder_choice
thf(fact_6832_underS__Field3,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A] :
( ( ( field2 @ A @ R2 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ord_less @ ( set @ A ) @ ( order_underS @ A @ R2 @ A3 ) @ ( field2 @ A @ R2 ) ) ) ).
% underS_Field3
thf(fact_6833_underS__incl__iff,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( order_679001287576687338der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ B2 @ ( field2 @ A @ R2 ) )
=> ( ( ord_less_eq @ ( set @ A ) @ ( order_underS @ A @ R2 @ A3 ) @ ( order_underS @ A @ R2 @ B2 ) )
= ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 ) ) ) ) ) ).
% underS_incl_iff
thf(fact_6834_chains__extend,axiom,
! [A: $tType,C2: set @ ( set @ A ),S3: set @ ( set @ A ),Z: set @ A] :
( ( member2 @ ( set @ ( set @ A ) ) @ C2 @ ( chains2 @ A @ S3 ) )
=> ( ( member2 @ ( set @ A ) @ Z @ S3 )
=> ( ! [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ C2 )
=> ( ord_less_eq @ ( set @ A ) @ X5 @ Z ) )
=> ( member2 @ ( set @ ( set @ A ) ) @ ( sup_sup @ ( set @ ( set @ A ) ) @ ( insert2 @ ( set @ A ) @ Z @ ( bot_bot @ ( set @ ( set @ A ) ) ) ) @ C2 ) @ ( chains2 @ A @ S3 ) ) ) ) ) ).
% chains_extend
thf(fact_6835_Refl__under__underS,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A] :
( ( refl_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( order_under @ A @ R2 @ A3 )
= ( sup_sup @ ( set @ A ) @ ( order_underS @ A @ R2 @ A3 ) @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% Refl_under_underS
thf(fact_6836_chainsD,axiom,
! [A: $tType,C2: set @ ( set @ A ),S3: set @ ( set @ A ),X: set @ A,Y: set @ A] :
( ( member2 @ ( set @ ( set @ A ) ) @ C2 @ ( chains2 @ A @ S3 ) )
=> ( ( member2 @ ( set @ A ) @ X @ C2 )
=> ( ( member2 @ ( set @ A ) @ Y @ C2 )
=> ( ( ord_less_eq @ ( set @ A ) @ X @ Y )
| ( ord_less_eq @ ( set @ A ) @ Y @ X ) ) ) ) ) ).
% chainsD
thf(fact_6837_Zorn__Lemma2,axiom,
! [A: $tType,A4: set @ ( set @ A )] :
( ! [X5: set @ ( set @ A )] :
( ( member2 @ ( set @ ( set @ A ) ) @ X5 @ ( chains2 @ A @ A4 ) )
=> ? [Xa: set @ A] :
( ( member2 @ ( set @ A ) @ Xa @ A4 )
& ! [Xb2: set @ A] :
( ( member2 @ ( set @ A ) @ Xb2 @ X5 )
=> ( ord_less_eq @ ( set @ A ) @ Xb2 @ Xa ) ) ) )
=> ? [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ A4 )
& ! [Xa: set @ A] :
( ( member2 @ ( set @ A ) @ Xa @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ X5 @ Xa )
=> ( Xa = X5 ) ) ) ) ) ).
% Zorn_Lemma2
thf(fact_6838_under__def,axiom,
! [A: $tType] :
( ( order_under @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A ),A5: A] :
( collect @ A
@ ^ [B4: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B4 @ A5 ) @ R4 ) ) ) ) ).
% under_def
thf(fact_6839_under__Field,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A] : ( ord_less_eq @ ( set @ A ) @ ( order_under @ A @ R2 @ A3 ) @ ( field2 @ A @ R2 ) ) ).
% under_Field
thf(fact_6840_underS__subset__under,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A] : ( ord_less_eq @ ( set @ A ) @ ( order_underS @ A @ R2 @ A3 ) @ ( order_under @ A @ R2 @ A3 ) ) ).
% underS_subset_under
thf(fact_6841_Zorn__Lemma,axiom,
! [A: $tType,A4: set @ ( set @ A )] :
( ! [X5: set @ ( set @ A )] :
( ( member2 @ ( set @ ( set @ A ) ) @ X5 @ ( chains2 @ A @ A4 ) )
=> ( member2 @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ X5 ) @ A4 ) )
=> ? [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ A4 )
& ! [Xa: set @ A] :
( ( member2 @ ( set @ A ) @ Xa @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ X5 @ Xa )
=> ( Xa = X5 ) ) ) ) ) ).
% Zorn_Lemma
thf(fact_6842_max__ext__eq,axiom,
! [A: $tType] :
( ( max_ext @ A )
= ( ^ [R5: set @ ( product_prod @ A @ A )] :
( collect @ ( product_prod @ ( set @ A ) @ ( set @ A ) )
@ ( product_case_prod @ ( set @ A ) @ ( set @ A ) @ $o
@ ^ [X8: set @ A,Y9: set @ A] :
( ( finite_finite @ A @ X8 )
& ( finite_finite @ A @ Y9 )
& ( Y9
!= ( bot_bot @ ( set @ A ) ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ X8 )
=> ? [Y2: A] :
( ( member2 @ A @ Y2 @ Y9 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R5 ) ) ) ) ) ) ) ) ).
% max_ext_eq
thf(fact_6843_prod_Oset__conv__list,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [G: B > A,Xs: list @ B] :
( ( groups7121269368397514597t_prod @ B @ A @ G @ ( set2 @ B @ Xs ) )
= ( groups5270119922927024881d_list @ A @ ( map @ B @ A @ G @ ( remdups @ B @ Xs ) ) ) ) ) ).
% prod.set_conv_list
thf(fact_6844_bex__empty,axiom,
! [A: $tType,P2: A > $o] :
~ ? [X3: A] :
( ( member2 @ A @ X3 @ ( bot_bot @ ( set @ A ) ) )
& ( P2 @ X3 ) ) ).
% bex_empty
thf(fact_6845_prod__list__zero__iff,axiom,
! [A: $tType] :
( ( ( semiring_1 @ A )
& ( semiri3467727345109120633visors @ A ) )
=> ! [Xs: list @ A] :
( ( ( groups5270119922927024881d_list @ A @ Xs )
= ( zero_zero @ A ) )
= ( member2 @ A @ ( zero_zero @ A ) @ ( set2 @ A @ Xs ) ) ) ) ).
% prod_list_zero_iff
thf(fact_6846_nths__nths,axiom,
! [A: $tType,Xs: list @ A,A4: set @ nat,B3: set @ nat] :
( ( nths @ A @ ( nths @ A @ Xs @ A4 ) @ B3 )
= ( nths @ A @ Xs
@ ( collect @ nat
@ ^ [I5: nat] :
( ( member2 @ nat @ I5 @ A4 )
& ( member2 @ nat
@ ( finite_card @ nat
@ ( collect @ nat
@ ^ [I10: nat] :
( ( member2 @ nat @ I10 @ A4 )
& ( ord_less @ nat @ I10 @ I5 ) ) ) )
@ B3 ) ) ) ) ) ).
% nths_nths
thf(fact_6847_max__extp_Omax__extI,axiom,
! [A: $tType,X7: set @ A,Y6: set @ A,R: A > A > $o] :
( ( finite_finite @ A @ X7 )
=> ( ( finite_finite @ A @ Y6 )
=> ( ( Y6
!= ( collect @ A @ ( bot_bot @ ( A > $o ) ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ? [Xa: A] :
( ( member2 @ A @ Xa @ Y6 )
& ( R @ X5 @ Xa ) ) )
=> ( max_extp @ A @ R @ X7 @ Y6 ) ) ) ) ) ).
% max_extp.max_extI
thf(fact_6848_max__extp_Osimps,axiom,
! [A: $tType] :
( ( max_extp @ A )
= ( ^ [R5: A > A > $o,A1: set @ A,A22: set @ A] :
( ( finite_finite @ A @ A1 )
& ( finite_finite @ A @ A22 )
& ( A22
!= ( collect @ A @ ( bot_bot @ ( A > $o ) ) ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A1 )
=> ? [Y2: A] :
( ( member2 @ A @ Y2 @ A22 )
& ( R5 @ X2 @ Y2 ) ) ) ) ) ) ).
% max_extp.simps
thf(fact_6849_max__extp_Ocases,axiom,
! [A: $tType,R: A > A > $o,A12: set @ A,A23: set @ A] :
( ( max_extp @ A @ R @ A12 @ A23 )
=> ~ ( ( finite_finite @ A @ A12 )
=> ( ( finite_finite @ A @ A23 )
=> ( ( A23
!= ( collect @ A @ ( bot_bot @ ( A > $o ) ) ) )
=> ~ ! [X3: A] :
( ( member2 @ A @ X3 @ A12 )
=> ? [Xa4: A] :
( ( member2 @ A @ Xa4 @ A23 )
& ( R @ X3 @ Xa4 ) ) ) ) ) ) ) ).
% max_extp.cases
thf(fact_6850_prod_Odistinct__set__conv__list,axiom,
! [A: $tType,B: $tType] :
( ( comm_monoid_mult @ A )
=> ! [Xs: list @ B,G: B > A] :
( ( distinct @ B @ Xs )
=> ( ( groups7121269368397514597t_prod @ B @ A @ G @ ( set2 @ B @ Xs ) )
= ( groups5270119922927024881d_list @ A @ ( map @ B @ A @ G @ Xs ) ) ) ) ) ).
% prod.distinct_set_conv_list
thf(fact_6851_min__ext__def,axiom,
! [A: $tType] :
( ( min_ext @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
( collect @ ( product_prod @ ( set @ A ) @ ( set @ A ) )
@ ^ [Uu3: product_prod @ ( set @ A ) @ ( set @ A )] :
? [X8: set @ A,Y9: set @ A] :
( ( Uu3
= ( product_Pair @ ( set @ A ) @ ( set @ A ) @ X8 @ Y9 ) )
& ( X8
!= ( bot_bot @ ( set @ A ) ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ Y9 )
=> ? [Y2: A] :
( ( member2 @ A @ Y2 @ X8 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y2 @ X2 ) @ R4 ) ) ) ) ) ) ) ).
% min_ext_def
thf(fact_6852_map__project__def,axiom,
! [B: $tType,A: $tType] :
( ( map_project @ A @ B )
= ( ^ [F3: A > ( option @ B ),A6: set @ A] :
( collect @ B
@ ^ [B4: B] :
? [X2: A] :
( ( member2 @ A @ X2 @ A6 )
& ( ( F3 @ X2 )
= ( some @ B @ B4 ) ) ) ) ) ) ).
% map_project_def
thf(fact_6853_bij__betw__roots__unity,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( bij_betw @ nat @ complex
@ ^ [K2: nat] : ( cis @ ( divide_divide @ real @ ( times_times @ real @ ( times_times @ real @ ( numeral_numeral @ real @ ( bit0 @ one2 ) ) @ pi ) @ ( semiring_1_of_nat @ real @ K2 ) ) @ ( semiring_1_of_nat @ real @ N2 ) ) )
@ ( set_ord_lessThan @ nat @ N2 )
@ ( collect @ complex
@ ^ [Z6: complex] :
( ( power_power @ complex @ Z6 @ N2 )
= ( one_one @ complex ) ) ) ) ) ).
% bij_betw_roots_unity
thf(fact_6854_bij__betw__add,axiom,
! [A: $tType] :
( ( cancel_semigroup_add @ A )
=> ! [A3: A,A4: set @ A,B3: set @ A] :
( ( bij_betw @ A @ A @ ( plus_plus @ A @ A3 ) @ A4 @ B3 )
= ( ( image2 @ A @ A @ ( plus_plus @ A @ A3 ) @ A4 )
= B3 ) ) ) ).
% bij_betw_add
thf(fact_6855_notIn__Un__bij__betw,axiom,
! [A: $tType,B: $tType,B2: A,A4: set @ A,F2: A > B,A16: set @ B] :
( ~ ( member2 @ A @ B2 @ A4 )
=> ( ~ ( member2 @ B @ ( F2 @ B2 ) @ A16 )
=> ( ( bij_betw @ A @ B @ F2 @ A4 @ A16 )
=> ( bij_betw @ A @ B @ F2 @ ( sup_sup @ ( set @ A ) @ A4 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) @ ( sup_sup @ ( set @ B ) @ A16 @ ( insert2 @ B @ ( F2 @ B2 ) @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ) ).
% notIn_Un_bij_betw
thf(fact_6856_notIn__Un__bij__betw3,axiom,
! [A: $tType,B: $tType,B2: A,A4: set @ A,F2: A > B,A16: set @ B] :
( ~ ( member2 @ A @ B2 @ A4 )
=> ( ~ ( member2 @ B @ ( F2 @ B2 ) @ A16 )
=> ( ( bij_betw @ A @ B @ F2 @ A4 @ A16 )
= ( bij_betw @ A @ B @ F2 @ ( sup_sup @ ( set @ A ) @ A4 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) @ ( sup_sup @ ( set @ B ) @ A16 @ ( insert2 @ B @ ( F2 @ B2 ) @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ) ).
% notIn_Un_bij_betw3
thf(fact_6857_bij__betw__comp__iff2,axiom,
! [C: $tType,A: $tType,B: $tType,F8: A > B,A16: set @ A,A20: set @ B,F2: C > A,A4: set @ C] :
( ( bij_betw @ A @ B @ F8 @ A16 @ A20 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image2 @ C @ A @ F2 @ A4 ) @ A16 )
=> ( ( bij_betw @ C @ A @ F2 @ A4 @ A16 )
= ( bij_betw @ C @ B @ ( comp @ A @ B @ C @ F8 @ F2 ) @ A4 @ A20 ) ) ) ) ).
% bij_betw_comp_iff2
thf(fact_6858_bij__fn,axiom,
! [A: $tType,F2: A > A,N2: nat] :
( ( bij_betw @ A @ A @ F2 @ ( top_top @ ( set @ A ) ) @ ( top_top @ ( set @ A ) ) )
=> ( bij_betw @ A @ A @ ( compow @ ( A > A ) @ N2 @ F2 ) @ ( top_top @ ( set @ A ) ) @ ( top_top @ ( set @ A ) ) ) ) ).
% bij_fn
thf(fact_6859_bij__betw__funpow,axiom,
! [A: $tType,F2: A > A,S3: set @ A,N2: nat] :
( ( bij_betw @ A @ A @ F2 @ S3 @ S3 )
=> ( bij_betw @ A @ A @ ( compow @ ( A > A ) @ N2 @ F2 ) @ S3 @ S3 ) ) ).
% bij_betw_funpow
thf(fact_6860_bij__betw__byWitness,axiom,
! [A: $tType,B: $tType,A4: set @ A,F8: B > A,F2: A > B,A16: set @ B] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ( F8 @ ( F2 @ X5 ) )
= X5 ) )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ A16 )
=> ( ( F2 @ ( F8 @ X5 ) )
= X5 ) )
=> ( ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ A16 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ F8 @ A16 ) @ A4 )
=> ( bij_betw @ A @ B @ F2 @ A4 @ A16 ) ) ) ) ) ).
% bij_betw_byWitness
thf(fact_6861_bij__betw__subset,axiom,
! [A: $tType,B: $tType,F2: A > B,A4: set @ A,A16: set @ B,B3: set @ A,B14: set @ B] :
( ( bij_betw @ A @ B @ F2 @ A4 @ A16 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( ( image2 @ A @ B @ F2 @ B3 )
= B14 )
=> ( bij_betw @ A @ B @ F2 @ B3 @ B14 ) ) ) ) ).
% bij_betw_subset
thf(fact_6862_bij__betw__empty2,axiom,
! [B: $tType,A: $tType,F2: A > B,A4: set @ A] :
( ( bij_betw @ A @ B @ F2 @ A4 @ ( bot_bot @ ( set @ B ) ) )
=> ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ).
% bij_betw_empty2
thf(fact_6863_bij__betw__empty1,axiom,
! [A: $tType,B: $tType,F2: A > B,A4: set @ B] :
( ( bij_betw @ A @ B @ F2 @ ( bot_bot @ ( set @ A ) ) @ A4 )
=> ( A4
= ( bot_bot @ ( set @ B ) ) ) ) ).
% bij_betw_empty1
thf(fact_6864_bij__betw__combine,axiom,
! [A: $tType,B: $tType,F2: A > B,A4: set @ A,B3: set @ B,C5: set @ A,D6: set @ B] :
( ( bij_betw @ A @ B @ F2 @ A4 @ B3 )
=> ( ( bij_betw @ A @ B @ F2 @ C5 @ D6 )
=> ( ( ( inf_inf @ ( set @ B ) @ B3 @ D6 )
= ( bot_bot @ ( set @ B ) ) )
=> ( bij_betw @ A @ B @ F2 @ ( sup_sup @ ( set @ A ) @ A4 @ C5 ) @ ( sup_sup @ ( set @ B ) @ B3 @ D6 ) ) ) ) ) ).
% bij_betw_combine
thf(fact_6865_bij__betw__partition,axiom,
! [A: $tType,B: $tType,F2: A > B,A4: set @ A,C5: set @ A,B3: set @ B,D6: set @ B] :
( ( bij_betw @ A @ B @ F2 @ ( sup_sup @ ( set @ A ) @ A4 @ C5 ) @ ( sup_sup @ ( set @ B ) @ B3 @ D6 ) )
=> ( ( bij_betw @ A @ B @ F2 @ C5 @ D6 )
=> ( ( ( inf_inf @ ( set @ A ) @ A4 @ C5 )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( ( inf_inf @ ( set @ B ) @ B3 @ D6 )
= ( bot_bot @ ( set @ B ) ) )
=> ( bij_betw @ A @ B @ F2 @ A4 @ B3 ) ) ) ) ) ).
% bij_betw_partition
thf(fact_6866_bij__betw__disjoint__Un,axiom,
! [A: $tType,B: $tType,F2: A > B,A4: set @ A,C5: set @ B,G: A > B,B3: set @ A,D6: set @ B] :
( ( bij_betw @ A @ B @ F2 @ A4 @ C5 )
=> ( ( bij_betw @ A @ B @ G @ B3 @ D6 )
=> ( ( ( inf_inf @ ( set @ A ) @ A4 @ B3 )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( ( inf_inf @ ( set @ B ) @ C5 @ D6 )
= ( bot_bot @ ( set @ B ) ) )
=> ( bij_betw @ A @ B
@ ^ [X2: A] : ( if @ B @ ( member2 @ A @ X2 @ A4 ) @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( sup_sup @ ( set @ A ) @ A4 @ B3 )
@ ( sup_sup @ ( set @ B ) @ C5 @ D6 ) ) ) ) ) ) ).
% bij_betw_disjoint_Un
thf(fact_6867_bij__betw__UNION__chain,axiom,
! [B: $tType,C: $tType,A: $tType,I6: set @ A,A4: A > ( set @ B ),F2: B > C,A16: A > ( set @ C )] :
( ! [I3: A,J2: A] :
( ( member2 @ A @ I3 @ I6 )
=> ( ( member2 @ A @ J2 @ I6 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( A4 @ I3 ) @ ( A4 @ J2 ) )
| ( ord_less_eq @ ( set @ B ) @ ( A4 @ J2 ) @ ( A4 @ I3 ) ) ) ) )
=> ( ! [I3: A] :
( ( member2 @ A @ I3 @ I6 )
=> ( bij_betw @ B @ C @ F2 @ ( A4 @ I3 ) @ ( A16 @ I3 ) ) )
=> ( bij_betw @ B @ C @ F2 @ ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ A4 @ I6 ) ) @ ( complete_Sup_Sup @ ( set @ C ) @ ( image2 @ A @ ( set @ C ) @ A16 @ I6 ) ) ) ) ) ).
% bij_betw_UNION_chain
thf(fact_6868_infinite__imp__bij__betw2,axiom,
! [A: $tType,A4: set @ A,A3: A] :
( ~ ( finite_finite @ A @ A4 )
=> ? [H5: A > A] : ( bij_betw @ A @ A @ H5 @ A4 @ ( sup_sup @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% infinite_imp_bij_betw2
thf(fact_6869_infinite__imp__bij__betw,axiom,
! [A: $tType,A4: set @ A,A3: A] :
( ~ ( finite_finite @ A @ A4 )
=> ? [H5: A > A] : ( bij_betw @ A @ A @ H5 @ A4 @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% infinite_imp_bij_betw
thf(fact_6870_vimage__subset__eq,axiom,
! [B: $tType,A: $tType,F2: A > B,B3: set @ B,A4: set @ A] :
( ( bij_betw @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) @ ( top_top @ ( set @ B ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ ( vimage @ A @ B @ F2 @ B3 ) @ A4 )
= ( ord_less_eq @ ( set @ B ) @ B3 @ ( image2 @ A @ B @ F2 @ A4 ) ) ) ) ).
% vimage_subset_eq
thf(fact_6871_ex__bij__betw__nat__finite,axiom,
! [A: $tType,M7: set @ A] :
( ( finite_finite @ A @ M7 )
=> ? [H5: nat > A] : ( bij_betw @ nat @ A @ H5 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( finite_card @ A @ M7 ) ) @ M7 ) ) ).
% ex_bij_betw_nat_finite
thf(fact_6872_sum_Oreindex__bij__betw__not__neutral,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( comm_monoid_add @ A )
=> ! [S5: set @ B,T5: set @ C,H2: B > C,S3: set @ B,T4: set @ C,G: C > A] :
( ( finite_finite @ B @ S5 )
=> ( ( finite_finite @ C @ T5 )
=> ( ( bij_betw @ B @ C @ H2 @ ( minus_minus @ ( set @ B ) @ S3 @ S5 ) @ ( minus_minus @ ( set @ C ) @ T4 @ T5 ) )
=> ( ! [A7: B] :
( ( member2 @ B @ A7 @ S5 )
=> ( ( G @ ( H2 @ A7 ) )
= ( zero_zero @ A ) ) )
=> ( ! [B5: C] :
( ( member2 @ C @ B5 @ T5 )
=> ( ( G @ B5 )
= ( zero_zero @ A ) ) )
=> ( ( groups7311177749621191930dd_sum @ B @ A
@ ^ [X2: B] : ( G @ ( H2 @ X2 ) )
@ S3 )
= ( groups7311177749621191930dd_sum @ C @ A @ G @ T4 ) ) ) ) ) ) ) ) ).
% sum.reindex_bij_betw_not_neutral
thf(fact_6873_bij__betw__nth,axiom,
! [A: $tType,Xs: list @ A,A4: set @ nat,B3: set @ A] :
( ( distinct @ A @ Xs )
=> ( ( A4
= ( set_ord_lessThan @ nat @ ( size_size @ ( list @ A ) @ Xs ) ) )
=> ( ( B3
= ( set2 @ A @ Xs ) )
=> ( bij_betw @ nat @ A @ ( nth @ A @ Xs ) @ A4 @ B3 ) ) ) ) ).
% bij_betw_nth
thf(fact_6874_Schroeder__Bernstein,axiom,
! [A: $tType,B: $tType,F2: A > B,A4: set @ A,B3: set @ B,G: B > A] :
( ( inj_on @ A @ B @ F2 @ A4 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ A4 ) @ B3 )
=> ( ( inj_on @ B @ A @ G @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ G @ B3 ) @ A4 )
=> ? [H5: A > B] : ( bij_betw @ A @ B @ H5 @ A4 @ B3 ) ) ) ) ) ).
% Schroeder_Bernstein
thf(fact_6875_lists__empty,axiom,
! [A: $tType] :
( ( lists @ A @ ( bot_bot @ ( set @ A ) ) )
= ( insert2 @ ( list @ A ) @ ( nil @ A ) @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) ) ).
% lists_empty
thf(fact_6876_Cons__in__lists__iff,axiom,
! [A: $tType,X: A,Xs: list @ A,A4: set @ A] :
( ( member2 @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ ( lists @ A @ A4 ) )
= ( ( member2 @ A @ X @ A4 )
& ( member2 @ ( list @ A ) @ Xs @ ( lists @ A @ A4 ) ) ) ) ).
% Cons_in_lists_iff
thf(fact_6877_in__listsI,axiom,
! [A: $tType,Xs: list @ A,A4: set @ A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( member2 @ A @ X5 @ A4 ) )
=> ( member2 @ ( list @ A ) @ Xs @ ( lists @ A @ A4 ) ) ) ).
% in_listsI
thf(fact_6878_lists__Int__eq,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( lists @ A @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) )
= ( inf_inf @ ( set @ ( list @ A ) ) @ ( lists @ A @ A4 ) @ ( lists @ A @ B3 ) ) ) ).
% lists_Int_eq
thf(fact_6879_append__in__lists__conv,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,A4: set @ A] :
( ( member2 @ ( list @ A ) @ ( append @ A @ Xs @ Ys ) @ ( lists @ A @ A4 ) )
= ( ( member2 @ ( list @ A ) @ Xs @ ( lists @ A @ A4 ) )
& ( member2 @ ( list @ A ) @ Ys @ ( lists @ A @ A4 ) ) ) ) ).
% append_in_lists_conv
thf(fact_6880_bij__betw__Suc,axiom,
! [M7: set @ nat,N7: set @ nat] :
( ( bij_betw @ nat @ nat @ suc @ M7 @ N7 )
= ( ( image2 @ nat @ nat @ suc @ M7 )
= N7 ) ) ).
% bij_betw_Suc
thf(fact_6881_lists__UNIV,axiom,
! [A: $tType] :
( ( lists @ A @ ( top_top @ ( set @ A ) ) )
= ( top_top @ ( set @ ( list @ A ) ) ) ) ).
% lists_UNIV
thf(fact_6882_lists__IntI,axiom,
! [A: $tType,L: list @ A,A4: set @ A,B3: set @ A] :
( ( member2 @ ( list @ A ) @ L @ ( lists @ A @ A4 ) )
=> ( ( member2 @ ( list @ A ) @ L @ ( lists @ A @ B3 ) )
=> ( member2 @ ( list @ A ) @ L @ ( lists @ A @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) ) ) ) ).
% lists_IntI
thf(fact_6883_listsE,axiom,
! [A: $tType,X: A,L: list @ A,A4: set @ A] :
( ( member2 @ ( list @ A ) @ ( cons @ A @ X @ L ) @ ( lists @ A @ A4 ) )
=> ~ ( ( member2 @ A @ X @ A4 )
=> ~ ( member2 @ ( list @ A ) @ L @ ( lists @ A @ A4 ) ) ) ) ).
% listsE
thf(fact_6884_lists_OCons,axiom,
! [A: $tType,A3: A,A4: set @ A,L: list @ A] :
( ( member2 @ A @ A3 @ A4 )
=> ( ( member2 @ ( list @ A ) @ L @ ( lists @ A @ A4 ) )
=> ( member2 @ ( list @ A ) @ ( cons @ A @ A3 @ L ) @ ( lists @ A @ A4 ) ) ) ) ).
% lists.Cons
thf(fact_6885_lists_Osimps,axiom,
! [A: $tType,A3: list @ A,A4: set @ A] :
( ( member2 @ ( list @ A ) @ A3 @ ( lists @ A @ A4 ) )
= ( ( A3
= ( nil @ A ) )
| ? [A5: A,L2: list @ A] :
( ( A3
= ( cons @ A @ A5 @ L2 ) )
& ( member2 @ A @ A5 @ A4 )
& ( member2 @ ( list @ A ) @ L2 @ ( lists @ A @ A4 ) ) ) ) ) ).
% lists.simps
thf(fact_6886_lists_Ocases,axiom,
! [A: $tType,A3: list @ A,A4: set @ A] :
( ( member2 @ ( list @ A ) @ A3 @ ( lists @ A @ A4 ) )
=> ( ( A3
!= ( nil @ A ) )
=> ~ ! [A7: A,L4: list @ A] :
( ( A3
= ( cons @ A @ A7 @ L4 ) )
=> ( ( member2 @ A @ A7 @ A4 )
=> ~ ( member2 @ ( list @ A ) @ L4 @ ( lists @ A @ A4 ) ) ) ) ) ) ).
% lists.cases
thf(fact_6887_lists_ONil,axiom,
! [A: $tType,A4: set @ A] : ( member2 @ ( list @ A ) @ ( nil @ A ) @ ( lists @ A @ A4 ) ) ).
% lists.Nil
thf(fact_6888_in__listsD,axiom,
! [A: $tType,Xs: list @ A,A4: set @ A] :
( ( member2 @ ( list @ A ) @ Xs @ ( lists @ A @ A4 ) )
=> ! [X3: A] :
( ( member2 @ A @ X3 @ ( set2 @ A @ Xs ) )
=> ( member2 @ A @ X3 @ A4 ) ) ) ).
% in_listsD
thf(fact_6889_in__lists__conv__set,axiom,
! [A: $tType,Xs: list @ A,A4: set @ A] :
( ( member2 @ ( list @ A ) @ Xs @ ( lists @ A @ A4 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ( member2 @ A @ X2 @ A4 ) ) ) ) ).
% in_lists_conv_set
thf(fact_6890_listrel__refl__on,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A )] :
( ( refl_on @ A @ A4 @ R2 )
=> ( refl_on @ ( list @ A ) @ ( lists @ A @ A4 ) @ ( listrel @ A @ A @ R2 ) ) ) ).
% listrel_refl_on
thf(fact_6891_lists__eq__set,axiom,
! [A: $tType] :
( ( lists @ A )
= ( ^ [A6: set @ A] :
( collect @ ( list @ A )
@ ^ [Xs2: list @ A] : ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs2 ) @ A6 ) ) ) ) ).
% lists_eq_set
thf(fact_6892_le__rel__bool__arg__iff,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( ord_less_eq @ ( $o > A ) )
= ( ^ [X8: $o > A,Y9: $o > A] :
( ( ord_less_eq @ A @ ( X8 @ $false ) @ ( Y9 @ $false ) )
& ( ord_less_eq @ A @ ( X8 @ $true ) @ ( Y9 @ $true ) ) ) ) ) ) ).
% le_rel_bool_arg_iff
thf(fact_6893_lists__mono,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ ( set @ ( list @ A ) ) @ ( lists @ A @ A4 ) @ ( lists @ A @ B3 ) ) ) ).
% lists_mono
thf(fact_6894_ex__bij__betw__finite__nat,axiom,
! [A: $tType,M7: set @ A] :
( ( finite_finite @ A @ M7 )
=> ? [H5: A > nat] : ( bij_betw @ A @ nat @ H5 @ M7 @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( finite_card @ A @ M7 ) ) ) ) ).
% ex_bij_betw_finite_nat
thf(fact_6895_lists__image,axiom,
! [A: $tType,B: $tType,F2: B > A,A4: set @ B] :
( ( lists @ A @ ( image2 @ B @ A @ F2 @ A4 ) )
= ( image2 @ ( list @ B ) @ ( list @ A ) @ ( map @ B @ A @ F2 ) @ ( lists @ B @ A4 ) ) ) ).
% lists_image
thf(fact_6896_Collect__finite__eq__lists,axiom,
! [A: $tType] :
( ( collect @ ( set @ A ) @ ( finite_finite @ A ) )
= ( image2 @ ( list @ A ) @ ( set @ A ) @ ( set2 @ A ) @ ( lists @ A @ ( top_top @ ( set @ A ) ) ) ) ) ).
% Collect_finite_eq_lists
thf(fact_6897_Collect__finite__subset__eq__lists,axiom,
! [A: $tType,T4: set @ A] :
( ( collect @ ( set @ A )
@ ^ [A6: set @ A] :
( ( finite_finite @ A @ A6 )
& ( ord_less_eq @ ( set @ A ) @ A6 @ T4 ) ) )
= ( image2 @ ( list @ A ) @ ( set @ A ) @ ( set2 @ A ) @ ( lists @ A @ T4 ) ) ) ).
% Collect_finite_subset_eq_lists
thf(fact_6898_listrel__subset,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : A4 ) )
=> ( ord_less_eq @ ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) @ ( listrel @ A @ A @ R2 )
@ ( product_Sigma @ ( list @ A ) @ ( list @ A ) @ ( lists @ A @ A4 )
@ ^ [Uu3: list @ A] : ( lists @ A @ A4 ) ) ) ) ).
% listrel_subset
thf(fact_6899_bij__betw__nth__root__unity,axiom,
! [C2: complex,N2: nat] :
( ( C2
!= ( zero_zero @ complex ) )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( bij_betw @ complex @ complex @ ( times_times @ complex @ ( times_times @ complex @ ( real_Vector_of_real @ complex @ ( root @ N2 @ ( real_V7770717601297561774m_norm @ complex @ C2 ) ) ) @ ( cis @ ( divide_divide @ real @ ( arg @ C2 ) @ ( semiring_1_of_nat @ real @ N2 ) ) ) ) )
@ ( collect @ complex
@ ^ [Z6: complex] :
( ( power_power @ complex @ Z6 @ N2 )
= ( one_one @ complex ) ) )
@ ( collect @ complex
@ ^ [Z6: complex] :
( ( power_power @ complex @ Z6 @ N2 )
= C2 ) ) ) ) ) ).
% bij_betw_nth_root_unity
thf(fact_6900_card__quotient__disjoint,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A )] :
( ( finite_finite @ A @ A4 )
=> ( ( inj_on @ A @ ( set @ ( set @ A ) )
@ ^ [X2: A] : ( equiv_quotient @ A @ ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) @ R2 )
@ A4 )
=> ( ( finite_card @ ( set @ A ) @ ( equiv_quotient @ A @ A4 @ R2 ) )
= ( finite_card @ A @ A4 ) ) ) ) ).
% card_quotient_disjoint
thf(fact_6901_quotient__empty,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( equiv_quotient @ A @ ( bot_bot @ ( set @ A ) ) @ R2 )
= ( bot_bot @ ( set @ ( set @ A ) ) ) ) ).
% quotient_empty
thf(fact_6902_quotient__is__empty,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A )] :
( ( ( equiv_quotient @ A @ A4 @ R2 )
= ( bot_bot @ ( set @ ( set @ A ) ) ) )
= ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ).
% quotient_is_empty
thf(fact_6903_quotient__is__empty2,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A )] :
( ( ( bot_bot @ ( set @ ( set @ A ) ) )
= ( equiv_quotient @ A @ A4 @ R2 ) )
= ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ).
% quotient_is_empty2
thf(fact_6904_quotient__diff1,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A,A3: A] :
( ( inj_on @ A @ ( set @ ( set @ A ) )
@ ^ [A5: A] : ( equiv_quotient @ A @ ( insert2 @ A @ A5 @ ( bot_bot @ ( set @ A ) ) ) @ R2 )
@ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( ( equiv_quotient @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) @ R2 )
= ( minus_minus @ ( set @ ( set @ A ) ) @ ( equiv_quotient @ A @ A4 @ R2 ) @ ( equiv_quotient @ A @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) @ R2 ) ) ) ) ) ).
% quotient_diff1
thf(fact_6905_INF__set__fold,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: B > A,Xs: list @ B] :
( ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ ( set2 @ B @ Xs ) ) )
= ( fold @ B @ A @ ( comp @ A @ ( A > A ) @ B @ ( inf_inf @ A ) @ F2 ) @ Xs @ ( top_top @ A ) ) ) ) ).
% INF_set_fold
thf(fact_6906_SUP__set__fold,axiom,
! [B: $tType,A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: B > A,Xs: list @ B] :
( ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ ( set2 @ B @ Xs ) ) )
= ( fold @ B @ A @ ( comp @ A @ ( A > A ) @ B @ ( sup_sup @ A ) @ F2 ) @ Xs @ ( bot_bot @ A ) ) ) ) ).
% SUP_set_fold
thf(fact_6907_fold__append,axiom,
! [A: $tType,B: $tType,F2: B > A > A,Xs: list @ B,Ys: list @ B] :
( ( fold @ B @ A @ F2 @ ( append @ B @ Xs @ Ys ) )
= ( comp @ A @ A @ A @ ( fold @ B @ A @ F2 @ Ys ) @ ( fold @ B @ A @ F2 @ Xs ) ) ) ).
% fold_append
thf(fact_6908_fold__replicate,axiom,
! [A: $tType,B: $tType,F2: B > A > A,N2: nat,X: B] :
( ( fold @ B @ A @ F2 @ ( replicate @ B @ N2 @ X ) )
= ( compow @ ( A > A ) @ N2 @ ( F2 @ X ) ) ) ).
% fold_replicate
thf(fact_6909_fold__filter,axiom,
! [A: $tType,B: $tType,F2: B > A > A,P2: B > $o,Xs: list @ B] :
( ( fold @ B @ A @ F2 @ ( filter2 @ B @ P2 @ Xs ) )
= ( fold @ B @ A
@ ^ [X2: B] : ( if @ ( A > A ) @ ( P2 @ X2 ) @ ( F2 @ X2 ) @ ( id @ A ) )
@ Xs ) ) ).
% fold_filter
thf(fact_6910_foldr__conv__fold,axiom,
! [A: $tType,B: $tType] :
( ( foldr @ B @ A )
= ( ^ [F3: B > A > A,Xs2: list @ B] : ( fold @ B @ A @ F3 @ ( rev @ B @ Xs2 ) ) ) ) ).
% foldr_conv_fold
thf(fact_6911_fold__invariant,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Q: A > $o,P2: B > $o,S: B,F2: A > B > B] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( Q @ X5 ) )
=> ( ( P2 @ S )
=> ( ! [X5: A,S2: B] :
( ( Q @ X5 )
=> ( ( P2 @ S2 )
=> ( P2 @ ( F2 @ X5 @ S2 ) ) ) )
=> ( P2 @ ( fold @ A @ B @ F2 @ Xs @ S ) ) ) ) ) ).
% fold_invariant
thf(fact_6912_List_Ofold__cong,axiom,
! [B: $tType,A: $tType,A3: A,B2: A,Xs: list @ B,Ys: list @ B,F2: B > A > A,G: B > A > A] :
( ( A3 = B2 )
=> ( ( Xs = Ys )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ ( set2 @ B @ Xs ) )
=> ( ( F2 @ X5 )
= ( G @ X5 ) ) )
=> ( ( fold @ B @ A @ F2 @ Xs @ A3 )
= ( fold @ B @ A @ G @ Ys @ B2 ) ) ) ) ) ).
% List.fold_cong
thf(fact_6913_fold__id,axiom,
! [A: $tType,B: $tType,Xs: list @ A,F2: A > B > B] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( F2 @ X5 )
= ( id @ B ) ) )
=> ( ( fold @ A @ B @ F2 @ Xs )
= ( id @ B ) ) ) ).
% fold_id
thf(fact_6914_fold__Nil,axiom,
! [A: $tType,B: $tType,F2: A > B > B] :
( ( fold @ A @ B @ F2 @ ( nil @ A ) )
= ( id @ B ) ) ).
% fold_Nil
thf(fact_6915_fold__simps_I1_J,axiom,
! [B: $tType,A: $tType,F2: B > A > A,S: A] :
( ( fold @ B @ A @ F2 @ ( nil @ B ) @ S )
= S ) ).
% fold_simps(1)
thf(fact_6916_fold__simps_I2_J,axiom,
! [B: $tType,A: $tType,F2: B > A > A,X: B,Xs: list @ B,S: A] :
( ( fold @ B @ A @ F2 @ ( cons @ B @ X @ Xs ) @ S )
= ( fold @ B @ A @ F2 @ Xs @ ( F2 @ X @ S ) ) ) ).
% fold_simps(2)
thf(fact_6917_foldl__conv__fold,axiom,
! [B: $tType,A: $tType] :
( ( foldl @ A @ B )
= ( ^ [F3: A > B > A,S7: A,Xs2: list @ B] :
( fold @ B @ A
@ ^ [X2: B,T3: A] : ( F3 @ T3 @ X2 )
@ Xs2
@ S7 ) ) ) ).
% foldl_conv_fold
thf(fact_6918_fold__Cons,axiom,
! [B: $tType,A: $tType,F2: A > B > B,X: A,Xs: list @ A] :
( ( fold @ A @ B @ F2 @ ( cons @ A @ X @ Xs ) )
= ( comp @ B @ B @ B @ ( fold @ A @ B @ F2 @ Xs ) @ ( F2 @ X ) ) ) ).
% fold_Cons
thf(fact_6919_fold__commute__apply,axiom,
! [A: $tType,C: $tType,B: $tType,Xs: list @ A,H2: B > C,G: A > B > B,F2: A > C > C,S: B] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( comp @ B @ C @ B @ H2 @ ( G @ X5 ) )
= ( comp @ C @ C @ B @ ( F2 @ X5 ) @ H2 ) ) )
=> ( ( H2 @ ( fold @ A @ B @ G @ Xs @ S ) )
= ( fold @ A @ C @ F2 @ Xs @ ( H2 @ S ) ) ) ) ).
% fold_commute_apply
thf(fact_6920_fold__commute,axiom,
! [A: $tType,C: $tType,B: $tType,Xs: list @ A,H2: B > C,G: A > B > B,F2: A > C > C] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( comp @ B @ C @ B @ H2 @ ( G @ X5 ) )
= ( comp @ C @ C @ B @ ( F2 @ X5 ) @ H2 ) ) )
=> ( ( comp @ B @ C @ B @ H2 @ ( fold @ A @ B @ G @ Xs ) )
= ( comp @ C @ C @ B @ ( fold @ A @ C @ F2 @ Xs ) @ H2 ) ) ) ).
% fold_commute
thf(fact_6921_fold__map,axiom,
! [B: $tType,A: $tType,C: $tType,G: B > A > A,F2: C > B,Xs: list @ C] :
( ( fold @ B @ A @ G @ ( map @ C @ B @ F2 @ Xs ) )
= ( fold @ C @ A @ ( comp @ B @ ( A > A ) @ C @ G @ F2 ) @ Xs ) ) ).
% fold_map
thf(fact_6922_union__set__fold,axiom,
! [A: $tType,Xs: list @ A,A4: set @ A] :
( ( sup_sup @ ( set @ A ) @ ( set2 @ A @ Xs ) @ A4 )
= ( fold @ A @ ( set @ A ) @ ( insert2 @ A ) @ Xs @ A4 ) ) ).
% union_set_fold
thf(fact_6923_rev__conv__fold,axiom,
! [A: $tType] :
( ( rev @ A )
= ( ^ [Xs2: list @ A] : ( fold @ A @ ( list @ A ) @ ( cons @ A ) @ Xs2 @ ( nil @ A ) ) ) ) ).
% rev_conv_fold
thf(fact_6924_fold__Cons__rev,axiom,
! [A: $tType,Xs: list @ A] :
( ( fold @ A @ ( list @ A ) @ ( cons @ A ) @ Xs )
= ( append @ A @ ( rev @ A @ Xs ) ) ) ).
% fold_Cons_rev
thf(fact_6925_fold__rev,axiom,
! [B: $tType,A: $tType,Xs: list @ A,F2: A > B > B] :
( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( member2 @ A @ Y4 @ ( set2 @ A @ Xs ) )
=> ( ( comp @ B @ B @ B @ ( F2 @ Y4 ) @ ( F2 @ X5 ) )
= ( comp @ B @ B @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) ) ) )
=> ( ( fold @ A @ B @ F2 @ ( rev @ A @ Xs ) )
= ( fold @ A @ B @ F2 @ Xs ) ) ) ).
% fold_rev
thf(fact_6926_List_Ounion__def,axiom,
! [A: $tType] :
( ( union @ A )
= ( fold @ A @ ( list @ A ) @ ( insert @ A ) ) ) ).
% List.union_def
thf(fact_6927_fold__plus__sum__list__rev,axiom,
! [A: $tType] :
( ( monoid_add @ A )
=> ! [Xs: list @ A] :
( ( fold @ A @ A @ ( plus_plus @ A ) @ Xs )
= ( plus_plus @ A @ ( groups8242544230860333062m_list @ A @ ( rev @ A @ Xs ) ) ) ) ) ).
% fold_plus_sum_list_rev
thf(fact_6928_fold__remove1__split,axiom,
! [B: $tType,A: $tType,Xs: list @ A,F2: A > B > B,X: A] :
( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( member2 @ A @ Y4 @ ( set2 @ A @ Xs ) )
=> ( ( comp @ B @ B @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) )
= ( comp @ B @ B @ B @ ( F2 @ Y4 ) @ ( F2 @ X5 ) ) ) ) )
=> ( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( fold @ A @ B @ F2 @ Xs )
= ( comp @ B @ B @ B @ ( fold @ A @ B @ F2 @ ( remove1 @ A @ X @ Xs ) ) @ ( F2 @ X ) ) ) ) ) ).
% fold_remove1_split
thf(fact_6929_foldr__fold,axiom,
! [B: $tType,A: $tType,Xs: list @ A,F2: A > B > B] :
( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( member2 @ A @ Y4 @ ( set2 @ A @ Xs ) )
=> ( ( comp @ B @ B @ B @ ( F2 @ Y4 ) @ ( F2 @ X5 ) )
= ( comp @ B @ B @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) ) ) )
=> ( ( foldr @ A @ B @ F2 @ Xs )
= ( fold @ A @ B @ F2 @ Xs ) ) ) ).
% foldr_fold
thf(fact_6930_fold__append__concat__rev,axiom,
! [A: $tType,Xss: list @ ( list @ A )] :
( ( fold @ ( list @ A ) @ ( list @ A ) @ ( append @ A ) @ Xss )
= ( append @ A @ ( concat @ A @ ( rev @ ( list @ A ) @ Xss ) ) ) ) ).
% fold_append_concat_rev
thf(fact_6931_Sup__set__fold,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [Xs: list @ A] :
( ( complete_Sup_Sup @ A @ ( set2 @ A @ Xs ) )
= ( fold @ A @ A @ ( sup_sup @ A ) @ Xs @ ( bot_bot @ A ) ) ) ) ).
% Sup_set_fold
thf(fact_6932_Inf__set__fold,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [Xs: list @ A] :
( ( complete_Inf_Inf @ A @ ( set2 @ A @ Xs ) )
= ( fold @ A @ A @ ( inf_inf @ A ) @ Xs @ ( top_top @ A ) ) ) ) ).
% Inf_set_fold
thf(fact_6933_Inf__fin_Oset__eq__fold,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ! [X: A,Xs: list @ A] :
( ( lattic7752659483105999362nf_fin @ A @ ( set2 @ A @ ( cons @ A @ X @ Xs ) ) )
= ( fold @ A @ A @ ( inf_inf @ A ) @ Xs @ X ) ) ) ).
% Inf_fin.set_eq_fold
thf(fact_6934_Sup__fin_Oset__eq__fold,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ! [X: A,Xs: list @ A] :
( ( lattic5882676163264333800up_fin @ A @ ( set2 @ A @ ( cons @ A @ X @ Xs ) ) )
= ( fold @ A @ A @ ( sup_sup @ A ) @ Xs @ X ) ) ) ).
% Sup_fin.set_eq_fold
thf(fact_6935_Max_Oset__eq__fold,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Xs: list @ A] :
( ( lattic643756798349783984er_Max @ A @ ( set2 @ A @ ( cons @ A @ X @ Xs ) ) )
= ( fold @ A @ A @ ( ord_max @ A ) @ Xs @ X ) ) ) ).
% Max.set_eq_fold
thf(fact_6936_Min_Oset__eq__fold,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Xs: list @ A] :
( ( lattic643756798350308766er_Min @ A @ ( set2 @ A @ ( cons @ A @ X @ Xs ) ) )
= ( fold @ A @ A @ ( ord_min @ A ) @ Xs @ X ) ) ) ).
% Min.set_eq_fold
thf(fact_6937_comp__fun__idem__on_Ofold__set__fold,axiom,
! [A: $tType,B: $tType,S3: set @ A,F2: A > B > B,Xs: list @ A,Y: B] :
( ( finite673082921795544331dem_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs ) @ S3 )
=> ( ( finite_fold @ A @ B @ F2 @ Y @ ( set2 @ A @ Xs ) )
= ( fold @ A @ B @ F2 @ Xs @ Y ) ) ) ) ).
% comp_fun_idem_on.fold_set_fold
thf(fact_6938_comp__fun__commute__on_Ofold__set__fold__remdups,axiom,
! [A: $tType,B: $tType,S3: set @ A,F2: A > B > B,Xs: list @ A,Y: B] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( set2 @ A @ Xs ) @ S3 )
=> ( ( finite_fold @ A @ B @ F2 @ Y @ ( set2 @ A @ Xs ) )
= ( fold @ A @ B @ F2 @ ( remdups @ A @ Xs ) @ Y ) ) ) ) ).
% comp_fun_commute_on.fold_set_fold_remdups
thf(fact_6939_finite__sequence__to__countable__set,axiom,
! [A: $tType,X7: set @ A] :
( ( countable_countable @ A @ X7 )
=> ~ ! [F6: nat > ( set @ A )] :
( ! [I4: nat] : ( ord_less_eq @ ( set @ A ) @ ( F6 @ I4 ) @ X7 )
=> ( ! [I4: nat] : ( ord_less_eq @ ( set @ A ) @ ( F6 @ I4 ) @ ( F6 @ ( suc @ I4 ) ) )
=> ( ! [I4: nat] : ( finite_finite @ A @ ( F6 @ I4 ) )
=> ( ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ F6 @ ( top_top @ ( set @ nat ) ) ) )
!= X7 ) ) ) ) ) ).
% finite_sequence_to_countable_set
thf(fact_6940_butlast__power,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( compow @ ( ( list @ A ) > ( list @ A ) ) @ N2 @ ( butlast @ A ) @ Xs )
= ( take @ A @ ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ N2 ) @ Xs ) ) ).
% butlast_power
thf(fact_6941_countable__empty,axiom,
! [A: $tType] : ( countable_countable @ A @ ( bot_bot @ ( set @ A ) ) ) ).
% countable_empty
thf(fact_6942_butlast__rev,axiom,
! [A: $tType,Xs: list @ A] :
( ( butlast @ A @ ( rev @ A @ Xs ) )
= ( rev @ A @ ( tl @ A @ Xs ) ) ) ).
% butlast_rev
thf(fact_6943_countable__Diff__eq,axiom,
! [A: $tType,A4: set @ A,X: A] :
( ( countable_countable @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( countable_countable @ A @ A4 ) ) ).
% countable_Diff_eq
thf(fact_6944_butlast__snoc,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( butlast @ A @ ( append @ A @ Xs @ ( cons @ A @ X @ ( nil @ A ) ) ) )
= Xs ) ).
% butlast_snoc
thf(fact_6945_length__butlast,axiom,
! [A: $tType,Xs: list @ A] :
( ( size_size @ ( list @ A ) @ ( butlast @ A @ Xs ) )
= ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) ) ) ).
% length_butlast
thf(fact_6946_countable__image__eq,axiom,
! [A: $tType,B: $tType,F2: B > A,S3: set @ B] :
( ( countable_countable @ A @ ( image2 @ B @ A @ F2 @ S3 ) )
= ( ? [T10: set @ B] :
( ( countable_countable @ B @ T10 )
& ( ord_less_eq @ ( set @ B ) @ T10 @ S3 )
& ( ( image2 @ B @ A @ F2 @ S3 )
= ( image2 @ B @ A @ F2 @ T10 ) ) ) ) ) ).
% countable_image_eq
thf(fact_6947_countable__subset__image,axiom,
! [A: $tType,B: $tType,B3: set @ A,F2: B > A,A4: set @ B] :
( ( ( countable_countable @ A @ B3 )
& ( ord_less_eq @ ( set @ A ) @ B3 @ ( image2 @ B @ A @ F2 @ A4 ) ) )
= ( ? [A19: set @ B] :
( ( countable_countable @ B @ A19 )
& ( ord_less_eq @ ( set @ B ) @ A19 @ A4 )
& ( B3
= ( image2 @ B @ A @ F2 @ A19 ) ) ) ) ) ).
% countable_subset_image
thf(fact_6948_ex__countable__subset__image,axiom,
! [A: $tType,B: $tType,F2: B > A,S3: set @ B,P2: ( set @ A ) > $o] :
( ( ? [T10: set @ A] :
( ( countable_countable @ A @ T10 )
& ( ord_less_eq @ ( set @ A ) @ T10 @ ( image2 @ B @ A @ F2 @ S3 ) )
& ( P2 @ T10 ) ) )
= ( ? [T10: set @ B] :
( ( countable_countable @ B @ T10 )
& ( ord_less_eq @ ( set @ B ) @ T10 @ S3 )
& ( P2 @ ( image2 @ B @ A @ F2 @ T10 ) ) ) ) ) ).
% ex_countable_subset_image
thf(fact_6949_all__countable__subset__image,axiom,
! [A: $tType,B: $tType,F2: B > A,S3: set @ B,P2: ( set @ A ) > $o] :
( ( ! [T10: set @ A] :
( ( ( countable_countable @ A @ T10 )
& ( ord_less_eq @ ( set @ A ) @ T10 @ ( image2 @ B @ A @ F2 @ S3 ) ) )
=> ( P2 @ T10 ) ) )
= ( ! [T10: set @ B] :
( ( ( countable_countable @ B @ T10 )
& ( ord_less_eq @ ( set @ B ) @ T10 @ S3 ) )
=> ( P2 @ ( image2 @ B @ A @ F2 @ T10 ) ) ) ) ) ).
% all_countable_subset_image
thf(fact_6950_ccSup__mono,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ( countable_countable @ A @ B3 )
=> ( ( countable_countable @ A @ A4 )
=> ( ! [A7: A] :
( ( member2 @ A @ A7 @ A4 )
=> ? [X3: A] :
( ( member2 @ A @ X3 @ B3 )
& ( ord_less_eq @ A @ A7 @ X3 ) ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ A4 ) @ ( complete_Sup_Sup @ A @ B3 ) ) ) ) ) ) ).
% ccSup_mono
thf(fact_6951_ccSup__least,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ A,Z: A] :
( ( countable_countable @ A @ A4 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ A @ X5 @ Z ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ A4 ) @ Z ) ) ) ) ).
% ccSup_least
thf(fact_6952_ccSup__upper,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ A,X: A] :
( ( countable_countable @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ A @ X @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ).
% ccSup_upper
thf(fact_6953_ccSup__le__iff,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ A,B2: A] :
( ( countable_countable @ A @ A4 )
=> ( ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ A4 ) @ B2 )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ X2 @ B2 ) ) ) ) ) ) ).
% ccSup_le_iff
thf(fact_6954_ccSup__upper2,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ A,U: A,V2: A] :
( ( countable_countable @ A @ A4 )
=> ( ( member2 @ A @ U @ A4 )
=> ( ( ord_less_eq @ A @ V2 @ U )
=> ( ord_less_eq @ A @ V2 @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ) ).
% ccSup_upper2
thf(fact_6955_ccInf__mono,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ( countable_countable @ A @ B3 )
=> ( ( countable_countable @ A @ A4 )
=> ( ! [B5: A] :
( ( member2 @ A @ B5 @ B3 )
=> ? [X3: A] :
( ( member2 @ A @ X3 @ A4 )
& ( ord_less_eq @ A @ X3 @ B5 ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ ( complete_Inf_Inf @ A @ B3 ) ) ) ) ) ) ).
% ccInf_mono
thf(fact_6956_ccInf__lower,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ A,X: A] :
( ( countable_countable @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ X ) ) ) ) ).
% ccInf_lower
thf(fact_6957_ccInf__lower2,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ A,U: A,V2: A] :
( ( countable_countable @ A @ A4 )
=> ( ( member2 @ A @ U @ A4 )
=> ( ( ord_less_eq @ A @ U @ V2 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ V2 ) ) ) ) ) ).
% ccInf_lower2
thf(fact_6958_le__ccInf__iff,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ A,B2: A] :
( ( countable_countable @ A @ A4 )
=> ( ( ord_less_eq @ A @ B2 @ ( complete_Inf_Inf @ A @ A4 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ A @ B2 @ X2 ) ) ) ) ) ) ).
% le_ccInf_iff
thf(fact_6959_ccInf__greatest,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ A,Z: A] :
( ( countable_countable @ A @ A4 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ord_less_eq @ A @ Z @ X5 ) )
=> ( ord_less_eq @ A @ Z @ ( complete_Inf_Inf @ A @ A4 ) ) ) ) ) ).
% ccInf_greatest
thf(fact_6960_countable__subset,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( countable_countable @ A @ B3 )
=> ( countable_countable @ A @ A4 ) ) ) ).
% countable_subset
thf(fact_6961_infinite__countable__subset_H,axiom,
! [A: $tType,X7: set @ A] :
( ~ ( finite_finite @ A @ X7 )
=> ? [C6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ C6 @ X7 )
& ( countable_countable @ A @ C6 )
& ~ ( finite_finite @ A @ C6 ) ) ) ).
% infinite_countable_subset'
thf(fact_6962_countable__Collect__finite__subset,axiom,
! [A: $tType,T4: set @ A] :
( ( countable_countable @ A @ T4 )
=> ( countable_countable @ ( set @ A )
@ ( collect @ ( set @ A )
@ ^ [A6: set @ A] :
( ( finite_finite @ A @ A6 )
& ( ord_less_eq @ ( set @ A ) @ A6 @ T4 ) ) ) ) ) ).
% countable_Collect_finite_subset
thf(fact_6963_map__butlast,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( map @ B @ A @ F2 @ ( butlast @ B @ Xs ) )
= ( butlast @ A @ ( map @ B @ A @ F2 @ Xs ) ) ) ).
% map_butlast
thf(fact_6964_butlast__tl,axiom,
! [A: $tType,Xs: list @ A] :
( ( butlast @ A @ ( tl @ A @ Xs ) )
= ( tl @ A @ ( butlast @ A @ Xs ) ) ) ).
% butlast_tl
thf(fact_6965_butlast_Osimps_I2_J,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( ( Xs
= ( nil @ A ) )
=> ( ( butlast @ A @ ( cons @ A @ X @ Xs ) )
= ( nil @ A ) ) )
& ( ( Xs
!= ( nil @ A ) )
=> ( ( butlast @ A @ ( cons @ A @ X @ Xs ) )
= ( cons @ A @ X @ ( butlast @ A @ Xs ) ) ) ) ) ).
% butlast.simps(2)
thf(fact_6966_ccInf__less__iff,axiom,
! [A: $tType] :
( ( ( counta3822494911875563373attice @ A )
& ( linorder @ A ) )
=> ! [S3: set @ A,A3: A] :
( ( countable_countable @ A @ S3 )
=> ( ( ord_less @ A @ ( complete_Inf_Inf @ A @ S3 ) @ A3 )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ S3 )
& ( ord_less @ A @ X2 @ A3 ) ) ) ) ) ) ).
% ccInf_less_iff
thf(fact_6967_less__ccSup__iff,axiom,
! [A: $tType] :
( ( ( counta3822494911875563373attice @ A )
& ( linorder @ A ) )
=> ! [S3: set @ A,A3: A] :
( ( countable_countable @ A @ S3 )
=> ( ( ord_less @ A @ A3 @ ( complete_Sup_Sup @ A @ S3 ) )
= ( ? [X2: A] :
( ( member2 @ A @ X2 @ S3 )
& ( ord_less @ A @ A3 @ X2 ) ) ) ) ) ) ).
% less_ccSup_iff
thf(fact_6968_butlast_Osimps_I1_J,axiom,
! [A: $tType] :
( ( butlast @ A @ ( nil @ A ) )
= ( nil @ A ) ) ).
% butlast.simps(1)
thf(fact_6969_drop__butlast,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( drop @ A @ N2 @ ( butlast @ A @ Xs ) )
= ( butlast @ A @ ( drop @ A @ N2 @ Xs ) ) ) ).
% drop_butlast
thf(fact_6970_distinct__butlast,axiom,
! [A: $tType,Xs: list @ A] :
( ( distinct @ A @ Xs )
=> ( distinct @ A @ ( butlast @ A @ Xs ) ) ) ).
% distinct_butlast
thf(fact_6971_in__set__butlastD,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ ( butlast @ A @ Xs ) ) )
=> ( member2 @ A @ X @ ( set2 @ A @ Xs ) ) ) ).
% in_set_butlastD
thf(fact_6972_in__set__butlast__appendI,axiom,
! [A: $tType,X: A,Xs: list @ A,Ys: list @ A] :
( ( ( member2 @ A @ X @ ( set2 @ A @ ( butlast @ A @ Xs ) ) )
| ( member2 @ A @ X @ ( set2 @ A @ ( butlast @ A @ Ys ) ) ) )
=> ( member2 @ A @ X @ ( set2 @ A @ ( butlast @ A @ ( append @ A @ Xs @ Ys ) ) ) ) ) ).
% in_set_butlast_appendI
thf(fact_6973_butlast__append,axiom,
! [A: $tType,Ys: list @ A,Xs: list @ A] :
( ( ( Ys
= ( nil @ A ) )
=> ( ( butlast @ A @ ( append @ A @ Xs @ Ys ) )
= ( butlast @ A @ Xs ) ) )
& ( ( Ys
!= ( nil @ A ) )
=> ( ( butlast @ A @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ Xs @ ( butlast @ A @ Ys ) ) ) ) ) ).
% butlast_append
thf(fact_6974_ccSup__subset__mono,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ( countable_countable @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ A4 ) @ ( complete_Sup_Sup @ A @ B3 ) ) ) ) ) ).
% ccSup_subset_mono
thf(fact_6975_ccInf__superset__mono,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( countable_countable @ A @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ A4 ) @ ( complete_Inf_Inf @ A @ B3 ) ) ) ) ) ).
% ccInf_superset_mono
thf(fact_6976_countable__image__eq__inj,axiom,
! [A: $tType,B: $tType,F2: B > A,S3: set @ B] :
( ( countable_countable @ A @ ( image2 @ B @ A @ F2 @ S3 ) )
= ( ? [T10: set @ B] :
( ( countable_countable @ B @ T10 )
& ( ord_less_eq @ ( set @ B ) @ T10 @ S3 )
& ( ( image2 @ B @ A @ F2 @ S3 )
= ( image2 @ B @ A @ F2 @ T10 ) )
& ( inj_on @ B @ A @ F2 @ T10 ) ) ) ) ).
% countable_image_eq_inj
thf(fact_6977_ex__countable__subset__image__inj,axiom,
! [A: $tType,B: $tType,F2: B > A,S3: set @ B,P2: ( set @ A ) > $o] :
( ( ? [T10: set @ A] :
( ( countable_countable @ A @ T10 )
& ( ord_less_eq @ ( set @ A ) @ T10 @ ( image2 @ B @ A @ F2 @ S3 ) )
& ( P2 @ T10 ) ) )
= ( ? [T10: set @ B] :
( ( countable_countable @ B @ T10 )
& ( ord_less_eq @ ( set @ B ) @ T10 @ S3 )
& ( inj_on @ B @ A @ F2 @ T10 )
& ( P2 @ ( image2 @ B @ A @ F2 @ T10 ) ) ) ) ) ).
% ex_countable_subset_image_inj
thf(fact_6978_all__countable__subset__image__inj,axiom,
! [A: $tType,B: $tType,F2: B > A,S3: set @ B,P2: ( set @ A ) > $o] :
( ( ! [T10: set @ A] :
( ( ( countable_countable @ A @ T10 )
& ( ord_less_eq @ ( set @ A ) @ T10 @ ( image2 @ B @ A @ F2 @ S3 ) ) )
=> ( P2 @ T10 ) ) )
= ( ! [T10: set @ B] :
( ( ( countable_countable @ B @ T10 )
& ( ord_less_eq @ ( set @ B ) @ T10 @ S3 )
& ( inj_on @ B @ A @ F2 @ T10 ) )
=> ( P2 @ ( image2 @ B @ A @ F2 @ T10 ) ) ) ) ) ).
% all_countable_subset_image_inj
thf(fact_6979_uncountable__def,axiom,
! [A: $tType,A4: set @ A] :
( ( ~ ( countable_countable @ A @ A4 ) )
= ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
& ~ ? [F3: nat > A] :
( ( image2 @ nat @ A @ F3 @ ( top_top @ ( set @ nat ) ) )
= A4 ) ) ) ).
% uncountable_def
thf(fact_6980_ccSUP__upper2,axiom,
! [A: $tType,B: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,I: B,U: A,F2: B > A] :
( ( countable_countable @ B @ A4 )
=> ( ( member2 @ B @ I @ A4 )
=> ( ( ord_less_eq @ A @ U @ ( F2 @ I ) )
=> ( ord_less_eq @ A @ U @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ) ) ).
% ccSUP_upper2
thf(fact_6981_ccSUP__le__iff,axiom,
! [A: $tType,B: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,F2: B > A,U: A] :
( ( countable_countable @ B @ A4 )
=> ( ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ U )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ X2 ) @ U ) ) ) ) ) ) ).
% ccSUP_le_iff
thf(fact_6982_ccSUP__upper,axiom,
! [A: $tType,B: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,I: B,F2: B > A] :
( ( countable_countable @ B @ A4 )
=> ( ( member2 @ B @ I @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ I ) @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ) ).
% ccSUP_upper
thf(fact_6983_ccSUP__least,axiom,
! [B: $tType,A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,F2: B > A,U: A] :
( ( countable_countable @ B @ A4 )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ I3 ) @ U ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ U ) ) ) ) ).
% ccSUP_least
thf(fact_6984_ccSUP__mono,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,B3: set @ C,F2: B > A,G: C > A] :
( ( countable_countable @ B @ A4 )
=> ( ( countable_countable @ C @ B3 )
=> ( ! [N3: B] :
( ( member2 @ B @ N3 @ A4 )
=> ? [X3: C] :
( ( member2 @ C @ X3 @ B3 )
& ( ord_less_eq @ A @ ( F2 @ N3 ) @ ( G @ X3 ) ) ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Sup_Sup @ A @ ( image2 @ C @ A @ G @ B3 ) ) ) ) ) ) ) ).
% ccSUP_mono
thf(fact_6985_less__ccSUP__iff,axiom,
! [A: $tType,B: $tType] :
( ( ( counta3822494911875563373attice @ A )
& ( linorder @ A ) )
=> ! [A4: set @ B,A3: A,F2: B > A] :
( ( countable_countable @ B @ A4 )
=> ( ( ord_less @ A @ A3 @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) )
= ( ? [X2: B] :
( ( member2 @ B @ X2 @ A4 )
& ( ord_less @ A @ A3 @ ( F2 @ X2 ) ) ) ) ) ) ) ).
% less_ccSUP_iff
thf(fact_6986_ccINF__greatest,axiom,
! [A: $tType,B: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,U: A,F2: B > A] :
( ( countable_countable @ B @ A4 )
=> ( ! [I3: B] :
( ( member2 @ B @ I3 @ A4 )
=> ( ord_less_eq @ A @ U @ ( F2 @ I3 ) ) )
=> ( ord_less_eq @ A @ U @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) ) ) ) ) ).
% ccINF_greatest
thf(fact_6987_le__ccINF__iff,axiom,
! [A: $tType,B: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,U: A,F2: B > A] :
( ( countable_countable @ B @ A4 )
=> ( ( ord_less_eq @ A @ U @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ A4 )
=> ( ord_less_eq @ A @ U @ ( F2 @ X2 ) ) ) ) ) ) ) ).
% le_ccINF_iff
thf(fact_6988_ccINF__lower2,axiom,
! [B: $tType,A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,I: B,F2: B > A,U: A] :
( ( countable_countable @ B @ A4 )
=> ( ( member2 @ B @ I @ A4 )
=> ( ( ord_less_eq @ A @ ( F2 @ I ) @ U )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ U ) ) ) ) ) ).
% ccINF_lower2
thf(fact_6989_ccINF__lower,axiom,
! [A: $tType,B: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,I: B,F2: B > A] :
( ( countable_countable @ B @ A4 )
=> ( ( member2 @ B @ I @ A4 )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( F2 @ I ) ) ) ) ) ).
% ccINF_lower
thf(fact_6990_ccINF__mono,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,B3: set @ C,F2: B > A,G: C > A] :
( ( countable_countable @ B @ A4 )
=> ( ( countable_countable @ C @ B3 )
=> ( ! [M3: C] :
( ( member2 @ C @ M3 @ B3 )
=> ? [X3: B] :
( ( member2 @ B @ X3 @ A4 )
& ( ord_less_eq @ A @ ( F2 @ X3 ) @ ( G @ M3 ) ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Inf_Inf @ A @ ( image2 @ C @ A @ G @ B3 ) ) ) ) ) ) ) ).
% ccINF_mono
thf(fact_6991_ccINF__less__iff,axiom,
! [A: $tType,B: $tType] :
( ( ( counta3822494911875563373attice @ A )
& ( linorder @ A ) )
=> ! [A4: set @ B,F2: B > A,A3: A] :
( ( countable_countable @ B @ A4 )
=> ( ( ord_less @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ A3 )
= ( ? [X2: B] :
( ( member2 @ B @ X2 @ A4 )
& ( ord_less @ A @ ( F2 @ X2 ) @ A3 ) ) ) ) ) ) ).
% ccINF_less_iff
thf(fact_6992_sorted__butlast,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( butlast @ A @ Xs ) ) ) ) ) ).
% sorted_butlast
thf(fact_6993_nth__butlast,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ ( butlast @ A @ Xs ) ) )
=> ( ( nth @ A @ ( butlast @ A @ Xs ) @ N2 )
= ( nth @ A @ Xs @ N2 ) ) ) ).
% nth_butlast
thf(fact_6994_take__butlast,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( take @ A @ N2 @ ( butlast @ A @ Xs ) )
= ( take @ A @ N2 @ Xs ) ) ) ).
% take_butlast
thf(fact_6995_ccSup__inter__less__eq,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( countable_countable @ A @ A4 )
=> ( ( countable_countable @ A @ B3 )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) @ ( inf_inf @ A @ ( complete_Sup_Sup @ A @ A4 ) @ ( complete_Sup_Sup @ A @ B3 ) ) ) ) ) ) ).
% ccSup_inter_less_eq
thf(fact_6996_less__eq__ccInf__inter,axiom,
! [A: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( countable_countable @ A @ A4 )
=> ( ( countable_countable @ A @ B3 )
=> ( ord_less_eq @ A @ ( sup_sup @ A @ ( complete_Inf_Inf @ A @ A4 ) @ ( complete_Inf_Inf @ A @ B3 ) ) @ ( complete_Inf_Inf @ A @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) ) ) ) ) ) ).
% less_eq_ccInf_inter
thf(fact_6997_countable__vimage,axiom,
! [B: $tType,A: $tType,B3: set @ A,F2: B > A] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ ( image2 @ B @ A @ F2 @ ( top_top @ ( set @ B ) ) ) )
=> ( ( countable_countable @ B @ ( vimage @ B @ A @ F2 @ B3 ) )
=> ( countable_countable @ A @ B3 ) ) ) ).
% countable_vimage
thf(fact_6998_ccSUP__subset__mono,axiom,
! [A: $tType,B: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [B3: set @ B,A4: set @ B,F2: B > A,G: B > A] :
( ( countable_countable @ B @ B3 )
=> ( ( ord_less_eq @ ( set @ B ) @ A4 @ B3 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ A4 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ord_less_eq @ A @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Sup_Sup @ A @ ( image2 @ B @ A @ G @ B3 ) ) ) ) ) ) ) ).
% ccSUP_subset_mono
thf(fact_6999_ccINF__superset__mono,axiom,
! [A: $tType,B: $tType] :
( ( counta3822494911875563373attice @ A )
=> ! [A4: set @ B,B3: set @ B,F2: B > A,G: B > A] :
( ( countable_countable @ B @ A4 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ A4 )
=> ( ! [X5: B] :
( ( member2 @ B @ X5 @ B3 )
=> ( ord_less_eq @ A @ ( F2 @ X5 ) @ ( G @ X5 ) ) )
=> ( ord_less_eq @ A @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ F2 @ A4 ) ) @ ( complete_Inf_Inf @ A @ ( image2 @ B @ A @ G @ B3 ) ) ) ) ) ) ) ).
% ccINF_superset_mono
thf(fact_7000_mono__ccSup,axiom,
! [B: $tType,A: $tType] :
( ( ( counta4013691401010221786attice @ A )
& ( counta3822494911875563373attice @ B ) )
=> ! [F2: A > B,A4: set @ A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( countable_countable @ A @ A4 )
=> ( ord_less_eq @ B @ ( complete_Sup_Sup @ B @ ( image2 @ A @ B @ F2 @ A4 ) ) @ ( F2 @ ( complete_Sup_Sup @ A @ A4 ) ) ) ) ) ) ).
% mono_ccSup
thf(fact_7001_mono__ccSUP,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( ( counta4013691401010221786attice @ A )
& ( counta3822494911875563373attice @ B ) )
=> ! [F2: A > B,I6: set @ C,A4: C > A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( countable_countable @ C @ I6 )
=> ( ord_less_eq @ B
@ ( complete_Sup_Sup @ B
@ ( image2 @ C @ B
@ ^ [X2: C] : ( F2 @ ( A4 @ X2 ) )
@ I6 ) )
@ ( F2 @ ( complete_Sup_Sup @ A @ ( image2 @ C @ A @ A4 @ I6 ) ) ) ) ) ) ) ).
% mono_ccSUP
thf(fact_7002_mono__ccINF,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( ( counta4013691401010221786attice @ A )
& ( counta3822494911875563373attice @ B ) )
=> ! [F2: A > B,I6: set @ C,A4: C > A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( countable_countable @ C @ I6 )
=> ( ord_less_eq @ B @ ( F2 @ ( complete_Inf_Inf @ A @ ( image2 @ C @ A @ A4 @ I6 ) ) )
@ ( complete_Inf_Inf @ B
@ ( image2 @ C @ B
@ ^ [X2: C] : ( F2 @ ( A4 @ X2 ) )
@ I6 ) ) ) ) ) ) ).
% mono_ccINF
thf(fact_7003_mono__ccInf,axiom,
! [B: $tType,A: $tType] :
( ( ( counta4013691401010221786attice @ A )
& ( counta3822494911875563373attice @ B ) )
=> ! [F2: A > B,A4: set @ A] :
( ( order_mono @ A @ B @ F2 )
=> ( ( countable_countable @ A @ A4 )
=> ( ord_less_eq @ B @ ( F2 @ ( complete_Inf_Inf @ A @ A4 ) ) @ ( complete_Inf_Inf @ B @ ( image2 @ A @ B @ F2 @ A4 ) ) ) ) ) ) ).
% mono_ccInf
thf(fact_7004_butlast__conv__take,axiom,
! [A: $tType] :
( ( butlast @ A )
= ( ^ [Xs2: list @ A] : ( take @ A @ ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs2 ) @ ( one_one @ nat ) ) @ Xs2 ) ) ) ).
% butlast_conv_take
thf(fact_7005_butlast__list__update,axiom,
! [A: $tType,K: nat,Xs: list @ A,X: A] :
( ( ( K
= ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) ) )
=> ( ( butlast @ A @ ( list_update @ A @ Xs @ K @ X ) )
= ( butlast @ A @ Xs ) ) )
& ( ( K
!= ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) ) )
=> ( ( butlast @ A @ ( list_update @ A @ Xs @ K @ X ) )
= ( list_update @ A @ ( butlast @ A @ Xs ) @ K @ X ) ) ) ) ).
% butlast_list_update
thf(fact_7006_butlast__take,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ord_less_eq @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( butlast @ A @ ( take @ A @ N2 @ Xs ) )
= ( take @ A @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ Xs ) ) ) ).
% butlast_take
thf(fact_7007_sort__key__conv__fold,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B] :
( ( inj_on @ B @ A @ F2 @ ( set2 @ B @ Xs ) )
=> ( ( linorder_sort_key @ B @ A @ F2 @ Xs )
= ( fold @ B @ ( list @ B ) @ ( linorder_insort_key @ B @ A @ F2 ) @ Xs @ ( nil @ B ) ) ) ) ) ).
% sort_key_conv_fold
thf(fact_7008_minus__set__fold,axiom,
! [A: $tType,A4: set @ A,Xs: list @ A] :
( ( minus_minus @ ( set @ A ) @ A4 @ ( set2 @ A @ Xs ) )
= ( fold @ A @ ( set @ A ) @ ( remove @ A ) @ Xs @ A4 ) ) ).
% minus_set_fold
thf(fact_7009_sort__upt,axiom,
! [M: nat,N2: nat] :
( ( linorder_sort_key @ nat @ nat
@ ^ [X2: nat] : X2
@ ( upt @ M @ N2 ) )
= ( upt @ M @ N2 ) ) ).
% sort_upt
thf(fact_7010_sort__upto,axiom,
! [I: int,J: int] :
( ( linorder_sort_key @ int @ int
@ ^ [X2: int] : X2
@ ( upto @ I @ J ) )
= ( upto @ I @ J ) ) ).
% sort_upto
thf(fact_7011_sort__key__simps_I1_J,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A] :
( ( linorder_sort_key @ B @ A @ F2 @ ( nil @ B ) )
= ( nil @ B ) ) ) ).
% sort_key_simps(1)
thf(fact_7012_set__sort,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B] :
( ( set2 @ B @ ( linorder_sort_key @ B @ A @ F2 @ Xs ) )
= ( set2 @ B @ Xs ) ) ) ).
% set_sort
thf(fact_7013_length__sort,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B] :
( ( size_size @ ( list @ B ) @ ( linorder_sort_key @ B @ A @ F2 @ Xs ) )
= ( size_size @ ( list @ B ) @ Xs ) ) ) ).
% length_sort
thf(fact_7014_distinct__sort,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B] :
( ( distinct @ B @ ( linorder_sort_key @ B @ A @ F2 @ Xs ) )
= ( distinct @ B @ Xs ) ) ) ).
% distinct_sort
thf(fact_7015_sort__key__simps_I2_J,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,X: B,Xs: list @ B] :
( ( linorder_sort_key @ B @ A @ F2 @ ( cons @ B @ X @ Xs ) )
= ( linorder_insort_key @ B @ A @ F2 @ X @ ( linorder_sort_key @ B @ A @ F2 @ Xs ) ) ) ) ).
% sort_key_simps(2)
thf(fact_7016_sort__key__const,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ! [C2: B,Xs: list @ A] :
( ( linorder_sort_key @ A @ B
@ ^ [X2: A] : C2
@ Xs )
= Xs ) ) ).
% sort_key_const
thf(fact_7017_filter__sort,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [P2: B > $o,F2: B > A,Xs: list @ B] :
( ( filter2 @ B @ P2 @ ( linorder_sort_key @ B @ A @ F2 @ Xs ) )
= ( linorder_sort_key @ B @ A @ F2 @ ( filter2 @ B @ P2 @ Xs ) ) ) ) ).
% filter_sort
thf(fact_7018_sort__key__stable,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ! [F2: A > B,K: B,Xs: list @ A] :
( ( filter2 @ A
@ ^ [Y2: A] :
( ( F2 @ Y2 )
= K )
@ ( linorder_sort_key @ A @ B @ F2 @ Xs ) )
= ( filter2 @ A
@ ^ [Y2: A] :
( ( F2 @ Y2 )
= K )
@ Xs ) ) ) ).
% sort_key_stable
thf(fact_7019_sorted__sort__id,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( ( linorder_sort_key @ A @ A
@ ^ [X2: A] : X2
@ Xs )
= Xs ) ) ) ).
% sorted_sort_id
thf(fact_7020_sorted__sort,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( sorted_wrt @ A @ ( ord_less_eq @ A )
@ ( linorder_sort_key @ A @ A
@ ^ [X2: A] : X2
@ Xs ) ) ) ).
% sorted_sort
thf(fact_7021_sorted__sort__key,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B] : ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ ( linorder_sort_key @ B @ A @ F2 @ Xs ) ) ) ) ).
% sorted_sort_key
thf(fact_7022_remove__code_I1_J,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( remove @ A @ X @ ( set2 @ A @ Xs ) )
= ( set2 @ A @ ( removeAll @ A @ X @ Xs ) ) ) ).
% remove_code(1)
thf(fact_7023_sorted__list__of__set__sort__remdups,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( linord4507533701916653071of_set @ A @ ( set2 @ A @ Xs ) )
= ( linorder_sort_key @ A @ A
@ ^ [X2: A] : X2
@ ( remdups @ A @ Xs ) ) ) ) ).
% sorted_list_of_set_sort_remdups
thf(fact_7024_sort__conv__fold,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A] :
( ( linorder_sort_key @ A @ A
@ ^ [X2: A] : X2
@ Xs )
= ( fold @ A @ ( list @ A )
@ ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2 )
@ Xs
@ ( nil @ A ) ) ) ) ).
% sort_conv_fold
thf(fact_7025_sort__key__def,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ( ( linorder_sort_key @ B @ A )
= ( ^ [F3: B > A,Xs2: list @ B] : ( foldr @ B @ ( list @ B ) @ ( linorder_insort_key @ B @ A @ F3 ) @ Xs2 @ ( nil @ B ) ) ) ) ) ).
% sort_key_def
thf(fact_7026_remove__def,axiom,
! [A: $tType] :
( ( remove @ A )
= ( ^ [X2: A,A6: set @ A] : ( minus_minus @ ( set @ A ) @ A6 @ ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ).
% remove_def
thf(fact_7027_Bleast__code,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,P2: A > $o] :
( ( bleast @ A @ ( set2 @ A @ Xs ) @ P2 )
= ( case_list @ A @ A @ ( abort_Bleast @ A @ ( set2 @ A @ Xs ) @ P2 )
@ ^ [X2: A,Xs2: list @ A] : X2
@ ( filter2 @ A @ P2
@ ( linorder_sort_key @ A @ A
@ ^ [X2: A] : X2
@ Xs ) ) ) ) ) ).
% Bleast_code
thf(fact_7028_range__from__nat__into,axiom,
! [A: $tType,A4: set @ A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( countable_countable @ A @ A4 )
=> ( ( image2 @ nat @ A @ ( counta4804993851260445106t_into @ A @ A4 ) @ ( top_top @ ( set @ nat ) ) )
= A4 ) ) ) ).
% range_from_nat_into
thf(fact_7029_from__nat__into__inject,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( countable_countable @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( countable_countable @ A @ B3 )
=> ( ( ( counta4804993851260445106t_into @ A @ A4 )
= ( counta4804993851260445106t_into @ A @ B3 ) )
= ( A4 = B3 ) ) ) ) ) ) ).
% from_nat_into_inject
thf(fact_7030_from__nat__into,axiom,
! [A: $tType,A4: set @ A,N2: nat] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ A @ ( counta4804993851260445106t_into @ A @ A4 @ N2 ) @ A4 ) ) ).
% from_nat_into
thf(fact_7031_inj__on__from__nat__into,axiom,
! [A: $tType] :
( inj_on @ ( set @ A ) @ ( nat > A ) @ ( counta4804993851260445106t_into @ A )
@ ( collect @ ( set @ A )
@ ^ [A6: set @ A] :
( ( A6
!= ( bot_bot @ ( set @ A ) ) )
& ( countable_countable @ A @ A6 ) ) ) ) ).
% inj_on_from_nat_into
thf(fact_7032_range__from__nat__into__subset,axiom,
! [A: $tType,A4: set @ A] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ord_less_eq @ ( set @ A ) @ ( image2 @ nat @ A @ ( counta4804993851260445106t_into @ A @ A4 ) @ ( top_top @ ( set @ nat ) ) ) @ A4 ) ) ).
% range_from_nat_into_subset
thf(fact_7033_subset__range__from__nat__into,axiom,
! [A: $tType,A4: set @ A] :
( ( countable_countable @ A @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ A4 @ ( image2 @ nat @ A @ ( counta4804993851260445106t_into @ A @ A4 ) @ ( top_top @ ( set @ nat ) ) ) ) ) ).
% subset_range_from_nat_into
thf(fact_7034_inter__coset__fold,axiom,
! [A: $tType,A4: set @ A,Xs: list @ A] :
( ( inf_inf @ ( set @ A ) @ A4 @ ( coset @ A @ Xs ) )
= ( fold @ A @ ( set @ A ) @ ( remove @ A ) @ Xs @ A4 ) ) ).
% inter_coset_fold
thf(fact_7035_complete__uniform,axiom,
! [A: $tType] :
( ( topolo7287701948861334536_space @ A )
=> ( ( topolo2479028161051973599mplete @ A )
= ( ^ [S8: set @ A] :
! [F10: filter @ A] :
( ( ord_less_eq @ ( filter @ A ) @ F10 @ ( principal @ A @ S8 ) )
=> ( ( F10
!= ( bot_bot @ ( filter @ A ) ) )
=> ( ( topolo6773858410816713723filter @ A @ F10 )
=> ? [X2: A] :
( ( member2 @ A @ X2 @ S8 )
& ( ord_less_eq @ ( filter @ A ) @ F10 @ ( topolo7230453075368039082e_nhds @ A @ X2 ) ) ) ) ) ) ) ) ) ).
% complete_uniform
thf(fact_7036_UNIV__coset,axiom,
! [A: $tType] :
( ( top_top @ ( set @ A ) )
= ( coset @ A @ ( nil @ A ) ) ) ).
% UNIV_coset
thf(fact_7037_subset__code_I2_J,axiom,
! [B: $tType,A4: set @ B,Ys: list @ B] :
( ( ord_less_eq @ ( set @ B ) @ A4 @ ( coset @ B @ Ys ) )
= ( ! [X2: B] :
( ( member2 @ B @ X2 @ ( set2 @ B @ Ys ) )
=> ~ ( member2 @ B @ X2 @ A4 ) ) ) ) ).
% subset_code(2)
thf(fact_7038_coset__def,axiom,
! [A: $tType] :
( ( coset @ A )
= ( ^ [Xs2: list @ A] : ( uminus_uminus @ ( set @ A ) @ ( set2 @ A @ Xs2 ) ) ) ) ).
% coset_def
thf(fact_7039_compl__coset,axiom,
! [A: $tType,Xs: list @ A] :
( ( uminus_uminus @ ( set @ A ) @ ( coset @ A @ Xs ) )
= ( set2 @ A @ Xs ) ) ).
% compl_coset
thf(fact_7040_insert__code_I2_J,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( insert2 @ A @ X @ ( coset @ A @ Xs ) )
= ( coset @ A @ ( removeAll @ A @ X @ Xs ) ) ) ).
% insert_code(2)
thf(fact_7041_union__coset__filter,axiom,
! [A: $tType,Xs: list @ A,A4: set @ A] :
( ( sup_sup @ ( set @ A ) @ ( coset @ A @ Xs ) @ A4 )
= ( coset @ A
@ ( filter2 @ A
@ ^ [X2: A] :
~ ( member2 @ A @ X2 @ A4 )
@ Xs ) ) ) ).
% union_coset_filter
thf(fact_7042_remove__code_I2_J,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( remove @ A @ X @ ( coset @ A @ Xs ) )
= ( coset @ A @ ( insert @ A @ X @ Xs ) ) ) ).
% remove_code(2)
thf(fact_7043_subset__code_I3_J,axiom,
! [C: $tType] :
~ ( ord_less_eq @ ( set @ C ) @ ( coset @ C @ ( nil @ C ) ) @ ( set2 @ C @ ( nil @ C ) ) ) ).
% subset_code(3)
thf(fact_7044_minus__coset__filter,axiom,
! [A: $tType,A4: set @ A,Xs: list @ A] :
( ( minus_minus @ ( set @ A ) @ A4 @ ( coset @ A @ Xs ) )
= ( set2 @ A
@ ( filter2 @ A
@ ^ [X2: A] : ( member2 @ A @ X2 @ A4 )
@ Xs ) ) ) ).
% minus_coset_filter
thf(fact_7045_shuffles_Opelims,axiom,
! [A: $tType,X: list @ A,Xa2: list @ A,Y: set @ ( list @ A )] :
( ( ( shuffles @ A @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( shuffles_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Xa2 ) )
=> ( ( ( X
= ( nil @ A ) )
=> ( ( Y
= ( insert2 @ ( list @ A ) @ Xa2 @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) )
=> ~ ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( shuffles_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Xa2 ) ) ) )
=> ( ( ( Xa2
= ( nil @ A ) )
=> ( ( Y
= ( insert2 @ ( list @ A ) @ X @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) )
=> ~ ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( shuffles_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ ( nil @ A ) ) ) ) )
=> ~ ! [X5: A,Xs3: list @ A] :
( ( X
= ( cons @ A @ X5 @ Xs3 ) )
=> ! [Y4: A,Ys4: list @ A] :
( ( Xa2
= ( cons @ A @ Y4 @ Ys4 ) )
=> ( ( Y
= ( sup_sup @ ( set @ ( list @ A ) ) @ ( image2 @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X5 ) @ ( shuffles @ A @ Xs3 @ ( cons @ A @ Y4 @ Ys4 ) ) ) @ ( image2 @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ Y4 ) @ ( shuffles @ A @ ( cons @ A @ X5 @ Xs3 ) @ Ys4 ) ) ) )
=> ~ ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( shuffles_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ ( cons @ A @ Y4 @ Ys4 ) ) ) ) ) ) ) ) ) ) ).
% shuffles.pelims
thf(fact_7046_comp__fun__commute__on_Ofold__graph__insertE__aux,axiom,
! [A: $tType,B: $tType,S3: set @ A,F2: A > B > B,A4: set @ A,Z: B,Y: B,A3: A] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ S3 )
=> ( ( finite_fold_graph @ A @ B @ F2 @ Z @ A4 @ Y )
=> ( ( member2 @ A @ A3 @ A4 )
=> ? [Y10: B] :
( ( Y
= ( F2 @ A3 @ Y10 ) )
& ( finite_fold_graph @ A @ B @ F2 @ Z @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) @ Y10 ) ) ) ) ) ) ).
% comp_fun_commute_on.fold_graph_insertE_aux
thf(fact_7047_fold__graph_OemptyI,axiom,
! [A: $tType,B: $tType,F2: A > B > B,Z: B] : ( finite_fold_graph @ A @ B @ F2 @ Z @ ( bot_bot @ ( set @ A ) ) @ Z ) ).
% fold_graph.emptyI
thf(fact_7048_empty__fold__graphE,axiom,
! [A: $tType,B: $tType,F2: A > B > B,Z: B,X: B] :
( ( finite_fold_graph @ A @ B @ F2 @ Z @ ( bot_bot @ ( set @ A ) ) @ X )
=> ( X = Z ) ) ).
% empty_fold_graphE
thf(fact_7049_shuffles_Opinduct,axiom,
! [A: $tType,A0: list @ A,A12: list @ A,P2: ( list @ A ) > ( list @ A ) > $o] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( shuffles_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ A0 @ A12 ) )
=> ( ! [Ys4: list @ A] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( shuffles_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Ys4 ) )
=> ( P2 @ ( nil @ A ) @ Ys4 ) )
=> ( ! [Xs3: list @ A] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( shuffles_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs3 @ ( nil @ A ) ) )
=> ( P2 @ Xs3 @ ( nil @ A ) ) )
=> ( ! [X5: A,Xs3: list @ A,Y4: A,Ys4: list @ A] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( shuffles_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ ( cons @ A @ Y4 @ Ys4 ) ) )
=> ( ( P2 @ Xs3 @ ( cons @ A @ Y4 @ Ys4 ) )
=> ( ( P2 @ ( cons @ A @ X5 @ Xs3 ) @ Ys4 )
=> ( P2 @ ( cons @ A @ X5 @ Xs3 ) @ ( cons @ A @ Y4 @ Ys4 ) ) ) ) )
=> ( P2 @ A0 @ A12 ) ) ) ) ) ).
% shuffles.pinduct
thf(fact_7050_fold__graph_Ocases,axiom,
! [A: $tType,B: $tType,F2: A > B > B,Z: B,A12: set @ A,A23: B] :
( ( finite_fold_graph @ A @ B @ F2 @ Z @ A12 @ A23 )
=> ( ( ( A12
= ( bot_bot @ ( set @ A ) ) )
=> ( A23 != Z ) )
=> ~ ! [X5: A,A9: set @ A] :
( ( A12
= ( insert2 @ A @ X5 @ A9 ) )
=> ! [Y4: B] :
( ( A23
= ( F2 @ X5 @ Y4 ) )
=> ( ~ ( member2 @ A @ X5 @ A9 )
=> ~ ( finite_fold_graph @ A @ B @ F2 @ Z @ A9 @ Y4 ) ) ) ) ) ) ).
% fold_graph.cases
thf(fact_7051_fold__graph_Osimps,axiom,
! [B: $tType,A: $tType] :
( ( finite_fold_graph @ A @ B )
= ( ^ [F3: A > B > B,Z6: B,A1: set @ A,A22: B] :
( ( ( A1
= ( bot_bot @ ( set @ A ) ) )
& ( A22 = Z6 ) )
| ? [X2: A,A6: set @ A,Y2: B] :
( ( A1
= ( insert2 @ A @ X2 @ A6 ) )
& ( A22
= ( F3 @ X2 @ Y2 ) )
& ~ ( member2 @ A @ X2 @ A6 )
& ( finite_fold_graph @ A @ B @ F3 @ Z6 @ A6 @ Y2 ) ) ) ) ) ).
% fold_graph.simps
thf(fact_7052_comp__fun__commute__on_Ofold__graph__determ,axiom,
! [A: $tType,B: $tType,S3: set @ A,F2: A > B > B,A4: set @ A,Z: B,X: B,Y: B] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ S3 )
=> ( ( finite_fold_graph @ A @ B @ F2 @ Z @ A4 @ X )
=> ( ( finite_fold_graph @ A @ B @ F2 @ Z @ A4 @ Y )
=> ( Y = X ) ) ) ) ) ).
% comp_fun_commute_on.fold_graph_determ
thf(fact_7053_shuffles_Opsimps_I2_J,axiom,
! [A: $tType,Xs: list @ A] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( shuffles_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs @ ( nil @ A ) ) )
=> ( ( shuffles @ A @ Xs @ ( nil @ A ) )
= ( insert2 @ ( list @ A ) @ Xs @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) ) ) ).
% shuffles.psimps(2)
thf(fact_7054_shuffles_Opsimps_I1_J,axiom,
! [A: $tType,Ys: list @ A] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( shuffles_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Ys ) )
=> ( ( shuffles @ A @ ( nil @ A ) @ Ys )
= ( insert2 @ ( list @ A ) @ Ys @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) ) ) ).
% shuffles.psimps(1)
thf(fact_7055_comp__fun__commute__on_Ofold__graph__insertE,axiom,
! [A: $tType,B: $tType,S3: set @ A,F2: A > B > B,X: A,A4: set @ A,Z: B,V2: B] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ A4 ) @ S3 )
=> ( ( finite_fold_graph @ A @ B @ F2 @ Z @ ( insert2 @ A @ X @ A4 ) @ V2 )
=> ( ~ ( member2 @ A @ X @ A4 )
=> ~ ! [Y4: B] :
( ( V2
= ( F2 @ X @ Y4 ) )
=> ~ ( finite_fold_graph @ A @ B @ F2 @ Z @ A4 @ Y4 ) ) ) ) ) ) ).
% comp_fun_commute_on.fold_graph_insertE
thf(fact_7056_shuffles_Opsimps_I3_J,axiom,
! [A: $tType,X: A,Xs: list @ A,Y: A,Ys: list @ A] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( shuffles_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) ) )
=> ( ( shuffles @ A @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) )
= ( sup_sup @ ( set @ ( list @ A ) ) @ ( image2 @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X ) @ ( shuffles @ A @ Xs @ ( cons @ A @ Y @ Ys ) ) ) @ ( image2 @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ Y ) @ ( shuffles @ A @ ( cons @ A @ X @ Xs ) @ Ys ) ) ) ) ) ).
% shuffles.psimps(3)
thf(fact_7057_comp__fun__commute__on_Ofold__equality,axiom,
! [A: $tType,B: $tType,S3: set @ A,F2: A > B > B,A4: set @ A,Z: B,Y: B] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ S3 )
=> ( ( finite_fold_graph @ A @ B @ F2 @ Z @ A4 @ Y )
=> ( ( finite_fold @ A @ B @ F2 @ Z @ A4 )
= Y ) ) ) ) ).
% comp_fun_commute_on.fold_equality
thf(fact_7058_comp__fun__commute__on_Ofold__graph__fold,axiom,
! [B: $tType,A: $tType,S3: set @ A,F2: A > B > B,A4: set @ A,Z: B] :
( ( finite4664212375090638736ute_on @ A @ B @ S3 @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ S3 )
=> ( ( finite_finite @ A @ A4 )
=> ( finite_fold_graph @ A @ B @ F2 @ Z @ A4 @ ( finite_fold @ A @ B @ F2 @ Z @ A4 ) ) ) ) ) ).
% comp_fun_commute_on.fold_graph_fold
thf(fact_7059_splice_Opinduct,axiom,
! [A: $tType,A0: list @ A,A12: list @ A,P2: ( list @ A ) > ( list @ A ) > $o] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( splice_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ A0 @ A12 ) )
=> ( ! [Ys4: list @ A] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( splice_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Ys4 ) )
=> ( P2 @ ( nil @ A ) @ Ys4 ) )
=> ( ! [X5: A,Xs3: list @ A,Ys4: list @ A] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( splice_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ Ys4 ) )
=> ( ( P2 @ Ys4 @ Xs3 )
=> ( P2 @ ( cons @ A @ X5 @ Xs3 ) @ Ys4 ) ) )
=> ( P2 @ A0 @ A12 ) ) ) ) ).
% splice.pinduct
thf(fact_7060_list_Oin__rel,axiom,
! [B: $tType,A: $tType] :
( ( list_all2 @ A @ B )
= ( ^ [R5: A > B > $o,A5: list @ A,B4: list @ B] :
? [Z6: list @ ( product_prod @ A @ B )] :
( ( member2 @ ( list @ ( product_prod @ A @ B ) ) @ Z6
@ ( collect @ ( list @ ( product_prod @ A @ B ) )
@ ^ [X2: list @ ( product_prod @ A @ B )] : ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) ) @ ( set2 @ ( product_prod @ A @ B ) @ X2 ) @ ( collect @ ( product_prod @ A @ B ) @ ( product_case_prod @ A @ B @ $o @ R5 ) ) ) ) )
& ( ( map @ ( product_prod @ A @ B ) @ A @ ( product_fst @ A @ B ) @ Z6 )
= A5 )
& ( ( map @ ( product_prod @ A @ B ) @ B @ ( product_snd @ A @ B ) @ Z6 )
= B4 ) ) ) ) ).
% list.in_rel
thf(fact_7061_list__all2__Nil2,axiom,
! [B: $tType,A: $tType,P2: A > B > $o,Xs: list @ A] :
( ( list_all2 @ A @ B @ P2 @ Xs @ ( nil @ B ) )
= ( Xs
= ( nil @ A ) ) ) ).
% list_all2_Nil2
thf(fact_7062_list__all2__Nil,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Ys: list @ B] :
( ( list_all2 @ A @ B @ P2 @ ( nil @ A ) @ Ys )
= ( Ys
= ( nil @ B ) ) ) ).
% list_all2_Nil
thf(fact_7063_list__all2__rev,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ B] :
( ( list_all2 @ A @ B @ P2 @ ( rev @ A @ Xs ) @ ( rev @ B @ Ys ) )
= ( list_all2 @ A @ B @ P2 @ Xs @ Ys ) ) ).
% list_all2_rev
thf(fact_7064_list__all2__rev1,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ B] :
( ( list_all2 @ A @ B @ P2 @ ( rev @ A @ Xs ) @ Ys )
= ( list_all2 @ A @ B @ P2 @ Xs @ ( rev @ B @ Ys ) ) ) ).
% list_all2_rev1
thf(fact_7065_list__all2__append2,axiom,
! [B: $tType,A: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ B,Zs: list @ B] :
( ( list_all2 @ A @ B @ P2 @ Xs @ ( append @ B @ Ys @ Zs ) )
= ( ? [Us2: list @ A,Vs: list @ A] :
( ( Xs
= ( append @ A @ Us2 @ Vs ) )
& ( ( size_size @ ( list @ A ) @ Us2 )
= ( size_size @ ( list @ B ) @ Ys ) )
& ( ( size_size @ ( list @ A ) @ Vs )
= ( size_size @ ( list @ B ) @ Zs ) )
& ( list_all2 @ A @ B @ P2 @ Us2 @ Ys )
& ( list_all2 @ A @ B @ P2 @ Vs @ Zs ) ) ) ) ).
% list_all2_append2
thf(fact_7066_list__all2__append1,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ A,Zs: list @ B] :
( ( list_all2 @ A @ B @ P2 @ ( append @ A @ Xs @ Ys ) @ Zs )
= ( ? [Us2: list @ B,Vs: list @ B] :
( ( Zs
= ( append @ B @ Us2 @ Vs ) )
& ( ( size_size @ ( list @ B ) @ Us2 )
= ( size_size @ ( list @ A ) @ Xs ) )
& ( ( size_size @ ( list @ B ) @ Vs )
= ( size_size @ ( list @ A ) @ Ys ) )
& ( list_all2 @ A @ B @ P2 @ Xs @ Us2 )
& ( list_all2 @ A @ B @ P2 @ Ys @ Vs ) ) ) ) ).
% list_all2_append1
thf(fact_7067_list__all2__append,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B,P2: A > B > $o,Us: list @ A,Vs2: list @ B] :
( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( list_all2 @ A @ B @ P2 @ ( append @ A @ Xs @ Us ) @ ( append @ B @ Ys @ Vs2 ) )
= ( ( list_all2 @ A @ B @ P2 @ Xs @ Ys )
& ( list_all2 @ A @ B @ P2 @ Us @ Vs2 ) ) ) ) ).
% list_all2_append
thf(fact_7068_list__all2__lengthD,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ B] :
( ( list_all2 @ A @ B @ P2 @ Xs @ Ys )
=> ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) ) ) ).
% list_all2_lengthD
thf(fact_7069_list__all2__same,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A] :
( ( list_all2 @ A @ A @ P2 @ Xs @ Xs )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X2 @ X2 ) ) ) ) ).
% list_all2_same
thf(fact_7070_list_Orel__refl__strong,axiom,
! [A: $tType,X: list @ A,Ra2: A > A > $o] :
( ! [Z2: A] :
( ( member2 @ A @ Z2 @ ( set2 @ A @ X ) )
=> ( Ra2 @ Z2 @ Z2 ) )
=> ( list_all2 @ A @ A @ Ra2 @ X @ X ) ) ).
% list.rel_refl_strong
thf(fact_7071_list_Orel__mono__strong,axiom,
! [A: $tType,B: $tType,R: A > B > $o,X: list @ A,Y: list @ B,Ra2: A > B > $o] :
( ( list_all2 @ A @ B @ R @ X @ Y )
=> ( ! [Z2: A,Yb: B] :
( ( member2 @ A @ Z2 @ ( set2 @ A @ X ) )
=> ( ( member2 @ B @ Yb @ ( set2 @ B @ Y ) )
=> ( ( R @ Z2 @ Yb )
=> ( Ra2 @ Z2 @ Yb ) ) ) )
=> ( list_all2 @ A @ B @ Ra2 @ X @ Y ) ) ) ).
% list.rel_mono_strong
thf(fact_7072_list_Orel__cong,axiom,
! [A: $tType,B: $tType,X: list @ A,Ya: list @ A,Y: list @ B,Xa2: list @ B,R: A > B > $o,Ra2: A > B > $o] :
( ( X = Ya )
=> ( ( Y = Xa2 )
=> ( ! [Z2: A,Yb: B] :
( ( member2 @ A @ Z2 @ ( set2 @ A @ Ya ) )
=> ( ( member2 @ B @ Yb @ ( set2 @ B @ Xa2 ) )
=> ( ( R @ Z2 @ Yb )
= ( Ra2 @ Z2 @ Yb ) ) ) )
=> ( ( list_all2 @ A @ B @ R @ X @ Y )
= ( list_all2 @ A @ B @ Ra2 @ Ya @ Xa2 ) ) ) ) ) ).
% list.rel_cong
thf(fact_7073_list__all2__dropI,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ B,N2: nat] :
( ( list_all2 @ A @ B @ P2 @ Xs @ Ys )
=> ( list_all2 @ A @ B @ P2 @ ( drop @ A @ N2 @ Xs ) @ ( drop @ B @ N2 @ Ys ) ) ) ).
% list_all2_dropI
thf(fact_7074_list__all2__takeI,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ B,N2: nat] :
( ( list_all2 @ A @ B @ P2 @ Xs @ Ys )
=> ( list_all2 @ A @ B @ P2 @ ( take @ A @ N2 @ Xs ) @ ( take @ B @ N2 @ Ys ) ) ) ).
% list_all2_takeI
thf(fact_7075_list_Octr__transfer_I1_J,axiom,
! [A: $tType,B: $tType,R: A > B > $o] : ( list_all2 @ A @ B @ R @ ( nil @ A ) @ ( nil @ B ) ) ).
% list.ctr_transfer(1)
thf(fact_7076_list_Orel__distinct_I2_J,axiom,
! [A: $tType,B: $tType,R: A > B > $o,Y21: A,Y222: list @ A] :
~ ( list_all2 @ A @ B @ R @ ( cons @ A @ Y21 @ Y222 ) @ ( nil @ B ) ) ).
% list.rel_distinct(2)
thf(fact_7077_list_Orel__distinct_I1_J,axiom,
! [A: $tType,B: $tType,R: A > B > $o,Y21: B,Y222: list @ B] :
~ ( list_all2 @ A @ B @ R @ ( nil @ A ) @ ( cons @ B @ Y21 @ Y222 ) ) ).
% list.rel_distinct(1)
thf(fact_7078_list_Orel__cases,axiom,
! [A: $tType,B: $tType,R: A > B > $o,A3: list @ A,B2: list @ B] :
( ( list_all2 @ A @ B @ R @ A3 @ B2 )
=> ( ( ( A3
= ( nil @ A ) )
=> ( B2
!= ( nil @ B ) ) )
=> ~ ! [X15: A,X23: list @ A] :
( ( A3
= ( cons @ A @ X15 @ X23 ) )
=> ! [Y15: B,Y23: list @ B] :
( ( B2
= ( cons @ B @ Y15 @ Y23 ) )
=> ( ( R @ X15 @ Y15 )
=> ~ ( list_all2 @ A @ B @ R @ X23 @ Y23 ) ) ) ) ) ) ).
% list.rel_cases
thf(fact_7079_list_Orel__induct,axiom,
! [A: $tType,B: $tType,R: A > B > $o,X: list @ A,Y: list @ B,Q: ( list @ A ) > ( list @ B ) > $o] :
( ( list_all2 @ A @ B @ R @ X @ Y )
=> ( ( Q @ ( nil @ A ) @ ( nil @ B ) )
=> ( ! [A21: A,A222: list @ A,B21: B,B222: list @ B] :
( ( R @ A21 @ B21 )
=> ( ( Q @ A222 @ B222 )
=> ( Q @ ( cons @ A @ A21 @ A222 ) @ ( cons @ B @ B21 @ B222 ) ) ) )
=> ( Q @ X @ Y ) ) ) ) ).
% list.rel_induct
thf(fact_7080_list__all2__induct,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ B,R: ( list @ A ) > ( list @ B ) > $o] :
( ( list_all2 @ A @ B @ P2 @ Xs @ Ys )
=> ( ( R @ ( nil @ A ) @ ( nil @ B ) )
=> ( ! [X5: A,Xs3: list @ A,Y4: B,Ys4: list @ B] :
( ( P2 @ X5 @ Y4 )
=> ( ( list_all2 @ A @ B @ P2 @ Xs3 @ Ys4 )
=> ( ( R @ Xs3 @ Ys4 )
=> ( R @ ( cons @ A @ X5 @ Xs3 ) @ ( cons @ B @ Y4 @ Ys4 ) ) ) ) )
=> ( R @ Xs @ Ys ) ) ) ) ).
% list_all2_induct
thf(fact_7081_list_Orel__inject_I2_J,axiom,
! [A: $tType,B: $tType,R: A > B > $o,X21: A,X222: list @ A,Y21: B,Y222: list @ B] :
( ( list_all2 @ A @ B @ R @ ( cons @ A @ X21 @ X222 ) @ ( cons @ B @ Y21 @ Y222 ) )
= ( ( R @ X21 @ Y21 )
& ( list_all2 @ A @ B @ R @ X222 @ Y222 ) ) ) ).
% list.rel_inject(2)
thf(fact_7082_list_Orel__intros_I2_J,axiom,
! [A: $tType,B: $tType,R: A > B > $o,X21: A,Y21: B,X222: list @ A,Y222: list @ B] :
( ( R @ X21 @ Y21 )
=> ( ( list_all2 @ A @ B @ R @ X222 @ Y222 )
=> ( list_all2 @ A @ B @ R @ ( cons @ A @ X21 @ X222 ) @ ( cons @ B @ Y21 @ Y222 ) ) ) ) ).
% list.rel_intros(2)
thf(fact_7083_list__all2__Cons,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,X: A,Xs: list @ A,Y: B,Ys: list @ B] :
( ( list_all2 @ A @ B @ P2 @ ( cons @ A @ X @ Xs ) @ ( cons @ B @ Y @ Ys ) )
= ( ( P2 @ X @ Y )
& ( list_all2 @ A @ B @ P2 @ Xs @ Ys ) ) ) ).
% list_all2_Cons
thf(fact_7084_list__all2__Cons1,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,X: A,Xs: list @ A,Ys: list @ B] :
( ( list_all2 @ A @ B @ P2 @ ( cons @ A @ X @ Xs ) @ Ys )
= ( ? [Z6: B,Zs3: list @ B] :
( ( Ys
= ( cons @ B @ Z6 @ Zs3 ) )
& ( P2 @ X @ Z6 )
& ( list_all2 @ A @ B @ P2 @ Xs @ Zs3 ) ) ) ) ).
% list_all2_Cons1
thf(fact_7085_list__all2__Cons2,axiom,
! [B: $tType,A: $tType,P2: A > B > $o,Xs: list @ A,Y: B,Ys: list @ B] :
( ( list_all2 @ A @ B @ P2 @ Xs @ ( cons @ B @ Y @ Ys ) )
= ( ? [Z6: A,Zs3: list @ A] :
( ( Xs
= ( cons @ A @ Z6 @ Zs3 ) )
& ( P2 @ Z6 @ Y )
& ( list_all2 @ A @ B @ P2 @ Zs3 @ Ys ) ) ) ) ).
% list_all2_Cons2
thf(fact_7086_list__all2__update__cong,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ B,X: A,Y: B,I: nat] :
( ( list_all2 @ A @ B @ P2 @ Xs @ Ys )
=> ( ( P2 @ X @ Y )
=> ( list_all2 @ A @ B @ P2 @ ( list_update @ A @ Xs @ I @ X ) @ ( list_update @ B @ Ys @ I @ Y ) ) ) ) ).
% list_all2_update_cong
thf(fact_7087_list_Orel__eq,axiom,
! [A: $tType] :
( ( list_all2 @ A @ A
@ ^ [Y5: A,Z3: A] : ( Y5 = Z3 ) )
= ( ^ [Y5: list @ A,Z3: list @ A] : ( Y5 = Z3 ) ) ) ).
% list.rel_eq
thf(fact_7088_list_Orel__refl,axiom,
! [B: $tType,Ra2: B > B > $o,X: list @ B] :
( ! [X5: B] : ( Ra2 @ X5 @ X5 )
=> ( list_all2 @ B @ B @ Ra2 @ X @ X ) ) ).
% list.rel_refl
thf(fact_7089_list__all2__eq,axiom,
! [A: $tType] :
( ( ^ [Y5: list @ A,Z3: list @ A] : ( Y5 = Z3 ) )
= ( list_all2 @ A @ A
@ ^ [Y5: A,Z3: A] : ( Y5 = Z3 ) ) ) ).
% list_all2_eq
thf(fact_7090_list__all2__mono,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ B,Q: A > B > $o] :
( ( list_all2 @ A @ B @ P2 @ Xs @ Ys )
=> ( ! [Xs3: A,Ys4: B] :
( ( P2 @ Xs3 @ Ys4 )
=> ( Q @ Xs3 @ Ys4 ) )
=> ( list_all2 @ A @ B @ Q @ Xs @ Ys ) ) ) ).
% list_all2_mono
thf(fact_7091_list__all2__refl,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A] :
( ! [X5: A] : ( P2 @ X5 @ X5 )
=> ( list_all2 @ A @ A @ P2 @ Xs @ Xs ) ) ).
% list_all2_refl
thf(fact_7092_list__all2__trans,axiom,
! [B: $tType,A: $tType,C: $tType,P1: A > B > $o,P22: B > C > $o,P32: A > C > $o,As: list @ A,Bs: list @ B,Cs: list @ C] :
( ! [A7: A,B5: B,C4: C] :
( ( P1 @ A7 @ B5 )
=> ( ( P22 @ B5 @ C4 )
=> ( P32 @ A7 @ C4 ) ) )
=> ( ( list_all2 @ A @ B @ P1 @ As @ Bs )
=> ( ( list_all2 @ B @ C @ P22 @ Bs @ Cs )
=> ( list_all2 @ A @ C @ P32 @ As @ Cs ) ) ) ) ).
% list_all2_trans
thf(fact_7093_list__all2__antisym,axiom,
! [A: $tType,P2: A > A > $o,Q: A > A > $o,Xs: list @ A,Ys: list @ A] :
( ! [X5: A,Y4: A] :
( ( P2 @ X5 @ Y4 )
=> ( ( Q @ Y4 @ X5 )
=> ( X5 = Y4 ) ) )
=> ( ( list_all2 @ A @ A @ P2 @ Xs @ Ys )
=> ( ( list_all2 @ A @ A @ Q @ Ys @ Xs )
=> ( Xs = Ys ) ) ) ) ).
% list_all2_antisym
thf(fact_7094_list__all2__appendI,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,A3: list @ A,B2: list @ B,C2: list @ A,D2: list @ B] :
( ( list_all2 @ A @ B @ P2 @ A3 @ B2 )
=> ( ( list_all2 @ A @ B @ P2 @ C2 @ D2 )
=> ( list_all2 @ A @ B @ P2 @ ( append @ A @ A3 @ C2 ) @ ( append @ B @ B2 @ D2 ) ) ) ) ).
% list_all2_appendI
thf(fact_7095_list_Orel__map_I2_J,axiom,
! [A: $tType,C: $tType,B: $tType,Sa: A > C > $o,X: list @ A,G: B > C,Y: list @ B] :
( ( list_all2 @ A @ C @ Sa @ X @ ( map @ B @ C @ G @ Y ) )
= ( list_all2 @ A @ B
@ ^ [X2: A,Y2: B] : ( Sa @ X2 @ ( G @ Y2 ) )
@ X
@ Y ) ) ).
% list.rel_map(2)
thf(fact_7096_list_Orel__map_I1_J,axiom,
! [A: $tType,C: $tType,B: $tType,Sb: C > B > $o,I: A > C,X: list @ A,Y: list @ B] :
( ( list_all2 @ C @ B @ Sb @ ( map @ A @ C @ I @ X ) @ Y )
= ( list_all2 @ A @ B
@ ^ [X2: A] : ( Sb @ ( I @ X2 ) )
@ X
@ Y ) ) ).
% list.rel_map(1)
thf(fact_7097_list__all2__map1,axiom,
! [C: $tType,A: $tType,B: $tType,P2: A > B > $o,F2: C > A,As: list @ C,Bs: list @ B] :
( ( list_all2 @ A @ B @ P2 @ ( map @ C @ A @ F2 @ As ) @ Bs )
= ( list_all2 @ C @ B
@ ^ [X2: C] : ( P2 @ ( F2 @ X2 ) )
@ As
@ Bs ) ) ).
% list_all2_map1
thf(fact_7098_list__all2__map2,axiom,
! [A: $tType,B: $tType,C: $tType,P2: A > B > $o,As: list @ A,F2: C > B,Bs: list @ C] :
( ( list_all2 @ A @ B @ P2 @ As @ ( map @ C @ B @ F2 @ Bs ) )
= ( list_all2 @ A @ C
@ ^ [X2: A,Y2: C] : ( P2 @ X2 @ ( F2 @ Y2 ) )
@ As
@ Bs ) ) ).
% list_all2_map2
thf(fact_7099_list_Orel__mono,axiom,
! [B: $tType,A: $tType,R: A > B > $o,Ra2: A > B > $o] :
( ( ord_less_eq @ ( A > B > $o ) @ R @ Ra2 )
=> ( ord_less_eq @ ( ( list @ A ) > ( list @ B ) > $o ) @ ( list_all2 @ A @ B @ R ) @ ( list_all2 @ A @ B @ Ra2 ) ) ) ).
% list.rel_mono
thf(fact_7100_list__all2__conv__all__nth,axiom,
! [B: $tType,A: $tType] :
( ( list_all2 @ A @ B )
= ( ^ [P: A > B > $o,Xs2: list @ A,Ys3: list @ B] :
( ( ( size_size @ ( list @ A ) @ Xs2 )
= ( size_size @ ( list @ B ) @ Ys3 ) )
& ! [I5: nat] :
( ( ord_less @ nat @ I5 @ ( size_size @ ( list @ A ) @ Xs2 ) )
=> ( P @ ( nth @ A @ Xs2 @ I5 ) @ ( nth @ B @ Ys3 @ I5 ) ) ) ) ) ) ).
% list_all2_conv_all_nth
thf(fact_7101_list__all2__all__nthI,axiom,
! [A: $tType,B: $tType,A3: list @ A,B2: list @ B,P2: A > B > $o] :
( ( ( size_size @ ( list @ A ) @ A3 )
= ( size_size @ ( list @ B ) @ B2 ) )
=> ( ! [N3: nat] :
( ( ord_less @ nat @ N3 @ ( size_size @ ( list @ A ) @ A3 ) )
=> ( P2 @ ( nth @ A @ A3 @ N3 ) @ ( nth @ B @ B2 @ N3 ) ) )
=> ( list_all2 @ A @ B @ P2 @ A3 @ B2 ) ) ) ).
% list_all2_all_nthI
thf(fact_7102_list__all2__nthD2,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ B,P4: nat] :
( ( list_all2 @ A @ B @ P2 @ Xs @ Ys )
=> ( ( ord_less @ nat @ P4 @ ( size_size @ ( list @ B ) @ Ys ) )
=> ( P2 @ ( nth @ A @ Xs @ P4 ) @ ( nth @ B @ Ys @ P4 ) ) ) ) ).
% list_all2_nthD2
thf(fact_7103_list__all2__nthD,axiom,
! [A: $tType,B: $tType,P2: A > B > $o,Xs: list @ A,Ys: list @ B,P4: nat] :
( ( list_all2 @ A @ B @ P2 @ Xs @ Ys )
=> ( ( ord_less @ nat @ P4 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( P2 @ ( nth @ A @ Xs @ P4 ) @ ( nth @ B @ Ys @ P4 ) ) ) ) ).
% list_all2_nthD
thf(fact_7104_list_Orel__sel,axiom,
! [B: $tType,A: $tType] :
( ( list_all2 @ A @ B )
= ( ^ [R5: A > B > $o,A5: list @ A,B4: list @ B] :
( ( ( A5
= ( nil @ A ) )
= ( B4
= ( nil @ B ) ) )
& ( ( A5
!= ( nil @ A ) )
=> ( ( B4
!= ( nil @ B ) )
=> ( ( R5 @ ( hd @ A @ A5 ) @ ( hd @ B @ B4 ) )
& ( list_all2 @ A @ B @ R5 @ ( tl @ A @ A5 ) @ ( tl @ B @ B4 ) ) ) ) ) ) ) ) ).
% list.rel_sel
thf(fact_7105_product__lists__set,axiom,
! [A: $tType,Xss: list @ ( list @ A )] :
( ( set2 @ ( list @ A ) @ ( product_lists @ A @ Xss ) )
= ( collect @ ( list @ A )
@ ^ [Xs2: list @ A] :
( list_all2 @ A @ ( list @ A )
@ ^ [X2: A,Ys3: list @ A] : ( member2 @ A @ X2 @ ( set2 @ A @ Ys3 ) )
@ Xs2
@ Xss ) ) ) ).
% product_lists_set
thf(fact_7106_list__all2I,axiom,
! [A: $tType,B: $tType,A3: list @ A,B2: list @ B,P2: A > B > $o] :
( ! [X5: product_prod @ A @ B] :
( ( member2 @ ( product_prod @ A @ B ) @ X5 @ ( set2 @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ A3 @ B2 ) ) )
=> ( product_case_prod @ A @ B @ $o @ P2 @ X5 ) )
=> ( ( ( size_size @ ( list @ A ) @ A3 )
= ( size_size @ ( list @ B ) @ B2 ) )
=> ( list_all2 @ A @ B @ P2 @ A3 @ B2 ) ) ) ).
% list_all2I
thf(fact_7107_list__all2__iff,axiom,
! [B: $tType,A: $tType] :
( ( list_all2 @ A @ B )
= ( ^ [P: A > B > $o,Xs2: list @ A,Ys3: list @ B] :
( ( ( size_size @ ( list @ A ) @ Xs2 )
= ( size_size @ ( list @ B ) @ Ys3 ) )
& ! [X2: product_prod @ A @ B] :
( ( member2 @ ( product_prod @ A @ B ) @ X2 @ ( set2 @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs2 @ Ys3 ) ) )
=> ( product_case_prod @ A @ B @ $o @ P @ X2 ) ) ) ) ) ).
% list_all2_iff
thf(fact_7108_splice_Opelims,axiom,
! [A: $tType,X: list @ A,Xa2: list @ A,Y: list @ A] :
( ( ( splice @ A @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( splice_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Xa2 ) )
=> ( ( ( X
= ( nil @ A ) )
=> ( ( Y = Xa2 )
=> ~ ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( splice_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Xa2 ) ) ) )
=> ~ ! [X5: A,Xs3: list @ A] :
( ( X
= ( cons @ A @ X5 @ Xs3 ) )
=> ( ( Y
= ( cons @ A @ X5 @ ( splice @ A @ Xa2 @ Xs3 ) ) )
=> ~ ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( splice_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X5 @ Xs3 ) @ Xa2 ) ) ) ) ) ) ) ).
% splice.pelims
thf(fact_7109_splice_Opsimps_I1_J,axiom,
! [A: $tType,Ys: list @ A] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( splice_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( nil @ A ) @ Ys ) )
=> ( ( splice @ A @ ( nil @ A ) @ Ys )
= Ys ) ) ).
% splice.psimps(1)
thf(fact_7110_split__Nil__iff,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( splice @ A @ Xs @ Ys )
= ( nil @ A ) )
= ( ( Xs
= ( nil @ A ) )
& ( Ys
= ( nil @ A ) ) ) ) ).
% split_Nil_iff
thf(fact_7111_splice__Nil2,axiom,
! [A: $tType,Xs: list @ A] :
( ( splice @ A @ Xs @ ( nil @ A ) )
= Xs ) ).
% splice_Nil2
thf(fact_7112_splice__in__shuffles,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] : ( member2 @ ( list @ A ) @ ( splice @ A @ Xs @ Ys ) @ ( shuffles @ A @ Xs @ Ys ) ) ).
% splice_in_shuffles
thf(fact_7113_length__splice,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( size_size @ ( list @ A ) @ ( splice @ A @ Xs @ Ys ) )
= ( plus_plus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( size_size @ ( list @ A ) @ Ys ) ) ) ).
% length_splice
thf(fact_7114_splice__replicate,axiom,
! [A: $tType,M: nat,X: A,N2: nat] :
( ( splice @ A @ ( replicate @ A @ M @ X ) @ ( replicate @ A @ N2 @ X ) )
= ( replicate @ A @ ( plus_plus @ nat @ M @ N2 ) @ X ) ) ).
% splice_replicate
thf(fact_7115_splice_Osimps_I2_J,axiom,
! [A: $tType,X: A,Xs: list @ A,Ys: list @ A] :
( ( splice @ A @ ( cons @ A @ X @ Xs ) @ Ys )
= ( cons @ A @ X @ ( splice @ A @ Ys @ Xs ) ) ) ).
% splice.simps(2)
thf(fact_7116_splice_Osimps_I1_J,axiom,
! [A: $tType,Ys: list @ A] :
( ( splice @ A @ ( nil @ A ) @ Ys )
= Ys ) ).
% splice.simps(1)
thf(fact_7117_splice_Oelims,axiom,
! [A: $tType,X: list @ A,Xa2: list @ A,Y: list @ A] :
( ( ( splice @ A @ X @ Xa2 )
= Y )
=> ( ( ( X
= ( nil @ A ) )
=> ( Y != Xa2 ) )
=> ~ ! [X5: A,Xs3: list @ A] :
( ( X
= ( cons @ A @ X5 @ Xs3 ) )
=> ( Y
!= ( cons @ A @ X5 @ ( splice @ A @ Xa2 @ Xs3 ) ) ) ) ) ) ).
% splice.elims
thf(fact_7118_splice_Opsimps_I2_J,axiom,
! [A: $tType,X: A,Xs: list @ A,Ys: list @ A] :
( ( accp @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( splice_rel @ A ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ ( cons @ A @ X @ Xs ) @ Ys ) )
=> ( ( splice @ A @ ( cons @ A @ X @ Xs ) @ Ys )
= ( cons @ A @ X @ ( splice @ A @ Ys @ Xs ) ) ) ) ).
% splice.psimps(2)
thf(fact_7119_increasing__Bseq__subseq__iff,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: nat > A,G: nat > nat] :
( ! [X5: nat,Y4: nat] :
( ( ord_less_eq @ nat @ X5 @ Y4 )
=> ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ A @ ( F2 @ X5 ) ) @ ( real_V7770717601297561774m_norm @ A @ ( F2 @ Y4 ) ) ) )
=> ( ( order_strict_mono @ nat @ nat @ G )
=> ( ( bfun @ nat @ A
@ ^ [X2: nat] : ( F2 @ ( G @ X2 ) )
@ ( at_top @ nat ) )
= ( bfun @ nat @ A @ F2 @ ( at_top @ nat ) ) ) ) ) ) ).
% increasing_Bseq_subseq_iff
thf(fact_7120_power_Opower__eq__if,axiom,
! [A: $tType] :
( ( power2 @ A )
= ( ^ [One: A,Times: A > A > A,P6: A,M2: nat] :
( if @ A
@ ( M2
= ( zero_zero @ nat ) )
@ One
@ ( Times @ P6 @ ( power2 @ A @ One @ Times @ P6 @ ( minus_minus @ nat @ M2 @ ( one_one @ nat ) ) ) ) ) ) ) ).
% power.power_eq_if
thf(fact_7121_strict__mono__less__eq,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( order @ B ) )
=> ! [F2: A > B,X: A,Y: A] :
( ( order_strict_mono @ A @ B @ F2 )
=> ( ( ord_less_eq @ B @ ( F2 @ X ) @ ( F2 @ Y ) )
= ( ord_less_eq @ A @ X @ Y ) ) ) ) ).
% strict_mono_less_eq
thf(fact_7122_strict__mono__leD,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ! [R2: A > B,M: A,N2: A] :
( ( order_strict_mono @ A @ B @ R2 )
=> ( ( ord_less_eq @ A @ M @ N2 )
=> ( ord_less_eq @ B @ ( R2 @ M ) @ ( R2 @ N2 ) ) ) ) ) ).
% strict_mono_leD
thf(fact_7123_strict__mono__imp__increasing,axiom,
! [F2: nat > nat,N2: nat] :
( ( order_strict_mono @ nat @ nat @ F2 )
=> ( ord_less_eq @ nat @ N2 @ ( F2 @ N2 ) ) ) ).
% strict_mono_imp_increasing
thf(fact_7124_strict__mono__Suc__iff,axiom,
! [A: $tType] :
( ( order @ A )
=> ( ( order_strict_mono @ nat @ A )
= ( ^ [F3: nat > A] :
! [N: nat] : ( ord_less @ A @ ( F3 @ N ) @ ( F3 @ ( suc @ N ) ) ) ) ) ) ).
% strict_mono_Suc_iff
thf(fact_7125_power_Opower_Opower__Suc,axiom,
! [A: $tType,One2: A,Times2: A > A > A,A3: A,N2: nat] :
( ( power2 @ A @ One2 @ Times2 @ A3 @ ( suc @ N2 ) )
= ( Times2 @ A3 @ ( power2 @ A @ One2 @ Times2 @ A3 @ N2 ) ) ) ).
% power.power.power_Suc
thf(fact_7126_power_Opower_Opower__0,axiom,
! [A: $tType,One2: A,Times2: A > A > A,A3: A] :
( ( power2 @ A @ One2 @ Times2 @ A3 @ ( zero_zero @ nat ) )
= One2 ) ).
% power.power.power_0
thf(fact_7127_strict__mono__add,axiom,
! [A: $tType] :
( ( linordered_semidom @ A )
=> ! [K: A] :
( order_strict_mono @ A @ A
@ ^ [N: A] : ( plus_plus @ A @ N @ K ) ) ) ).
% strict_mono_add
thf(fact_7128_strict__monoD,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ! [F2: A > B,X: A,Y: A] :
( ( order_strict_mono @ A @ B @ F2 )
=> ( ( ord_less @ A @ X @ Y )
=> ( ord_less @ B @ ( F2 @ X ) @ ( F2 @ Y ) ) ) ) ) ).
% strict_monoD
thf(fact_7129_strict__monoI,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ! [F2: A > B] :
( ! [X5: A,Y4: A] :
( ( ord_less @ A @ X5 @ Y4 )
=> ( ord_less @ B @ ( F2 @ X5 ) @ ( F2 @ Y4 ) ) )
=> ( order_strict_mono @ A @ B @ F2 ) ) ) ).
% strict_monoI
thf(fact_7130_strict__mono__def,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ( ( order_strict_mono @ A @ B )
= ( ^ [F3: A > B] :
! [X2: A,Y2: A] :
( ( ord_less @ A @ X2 @ Y2 )
=> ( ord_less @ B @ ( F3 @ X2 ) @ ( F3 @ Y2 ) ) ) ) ) ) ).
% strict_mono_def
thf(fact_7131_strict__mono__less,axiom,
! [B: $tType,A: $tType] :
( ( ( linorder @ A )
& ( order @ B ) )
=> ! [F2: A > B,X: A,Y: A] :
( ( order_strict_mono @ A @ B @ F2 )
=> ( ( ord_less @ B @ ( F2 @ X ) @ ( F2 @ Y ) )
= ( ord_less @ A @ X @ Y ) ) ) ) ).
% strict_mono_less
thf(fact_7132_summable__mono__reindex,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [G: nat > nat,F2: nat > A] :
( ( order_strict_mono @ nat @ nat @ G )
=> ( ! [N3: nat] :
( ~ ( member2 @ nat @ N3 @ ( image2 @ nat @ nat @ G @ ( top_top @ ( set @ nat ) ) ) )
=> ( ( F2 @ N3 )
= ( zero_zero @ A ) ) )
=> ( ( summable @ A
@ ^ [N: nat] : ( F2 @ ( G @ N ) ) )
= ( summable @ A @ F2 ) ) ) ) ) ).
% summable_mono_reindex
thf(fact_7133_sums__mono__reindex,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topolo4958980785337419405_space @ A ) )
=> ! [G: nat > nat,F2: nat > A,C2: A] :
( ( order_strict_mono @ nat @ nat @ G )
=> ( ! [N3: nat] :
( ~ ( member2 @ nat @ N3 @ ( image2 @ nat @ nat @ G @ ( top_top @ ( set @ nat ) ) ) )
=> ( ( F2 @ N3 )
= ( zero_zero @ A ) ) )
=> ( ( sums @ A
@ ^ [N: nat] : ( F2 @ ( G @ N ) )
@ C2 )
= ( sums @ A @ F2 @ C2 ) ) ) ) ) ).
% sums_mono_reindex
thf(fact_7134_suminf__mono__reindex,axiom,
! [A: $tType] :
( ( ( comm_monoid_add @ A )
& ( topological_t2_space @ A ) )
=> ! [G: nat > nat,F2: nat > A] :
( ( order_strict_mono @ nat @ nat @ G )
=> ( ! [N3: nat] :
( ~ ( member2 @ nat @ N3 @ ( image2 @ nat @ nat @ G @ ( top_top @ ( set @ nat ) ) ) )
=> ( ( F2 @ N3 )
= ( zero_zero @ A ) ) )
=> ( ( suminf @ A
@ ^ [N: nat] : ( F2 @ ( G @ N ) ) )
= ( suminf @ A @ F2 ) ) ) ) ) ).
% suminf_mono_reindex
thf(fact_7135_finite__def,axiom,
! [A: $tType] :
( ( finite_finite @ A )
= ( complete_lattice_lfp @ ( ( set @ A ) > $o )
@ ^ [P6: ( set @ A ) > $o,X2: set @ A] :
( ( X2
= ( bot_bot @ ( set @ A ) ) )
| ? [A6: set @ A,A5: A] :
( ( X2
= ( insert2 @ A @ A5 @ A6 ) )
& ( P6 @ A6 ) ) ) ) ) ).
% finite_def
thf(fact_7136_finite__refines__card__le,axiom,
! [A: $tType,A4: set @ A,R: set @ ( product_prod @ A @ A ),S3: set @ ( product_prod @ A @ A )] :
( ( finite_finite @ ( set @ A ) @ ( equiv_quotient @ A @ A4 @ R ) )
=> ( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R @ S3 )
=> ( ( equiv_equiv @ A @ A4 @ R )
=> ( ( equiv_equiv @ A @ A4 @ S3 )
=> ( ord_less_eq @ nat @ ( finite_card @ ( set @ A ) @ ( equiv_quotient @ A @ A4 @ S3 ) ) @ ( finite_card @ ( set @ A ) @ ( equiv_quotient @ A @ A4 @ R ) ) ) ) ) ) ) ).
% finite_refines_card_le
thf(fact_7137_equiv__listrel,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A )] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( equiv_equiv @ ( list @ A ) @ ( lists @ A @ A4 ) @ ( listrel @ A @ A @ R2 ) ) ) ).
% equiv_listrel
thf(fact_7138_in__quotient__imp__non__empty,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X7: set @ A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ ( set @ A ) @ X7 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( X7
!= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% in_quotient_imp_non_empty
thf(fact_7139_in__quotient__imp__closed,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X7: set @ A,X: A,Y: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ ( set @ A ) @ X7 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( ( member2 @ A @ X @ X7 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
=> ( member2 @ A @ Y @ X7 ) ) ) ) ) ).
% in_quotient_imp_closed
thf(fact_7140_quotient__eq__iff,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X7: set @ A,Y6: set @ A,X: A,Y: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ ( set @ A ) @ X7 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( ( member2 @ ( set @ A ) @ Y6 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( ( member2 @ A @ X @ X7 )
=> ( ( member2 @ A @ Y @ Y6 )
=> ( ( X7 = Y6 )
= ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 ) ) ) ) ) ) ) ).
% quotient_eq_iff
thf(fact_7141_quotient__eqI,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X7: set @ A,Y6: set @ A,X: A,Y: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ ( set @ A ) @ X7 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( ( member2 @ ( set @ A ) @ Y6 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( ( member2 @ A @ X @ X7 )
=> ( ( member2 @ A @ Y @ Y6 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
=> ( X7 = Y6 ) ) ) ) ) ) ) ).
% quotient_eqI
thf(fact_7142_lfp__def,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ( ( complete_lattice_lfp @ A )
= ( ^ [F3: A > A] :
( complete_Inf_Inf @ A
@ ( collect @ A
@ ^ [U2: A] : ( ord_less_eq @ A @ ( F3 @ U2 ) @ U2 ) ) ) ) ) ) ).
% lfp_def
thf(fact_7143_in__quotient__imp__subset,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X7: set @ A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ ( set @ A ) @ X7 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( ord_less_eq @ ( set @ A ) @ X7 @ A4 ) ) ) ).
% in_quotient_imp_subset
thf(fact_7144_lfp__lfp,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A > A] :
( ! [X5: A,Y4: A,W: A,Z2: A] :
( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ( ord_less_eq @ A @ W @ Z2 )
=> ( ord_less_eq @ A @ ( F2 @ X5 @ W ) @ ( F2 @ Y4 @ Z2 ) ) ) )
=> ( ( complete_lattice_lfp @ A
@ ^ [X2: A] : ( complete_lattice_lfp @ A @ ( F2 @ X2 ) ) )
= ( complete_lattice_lfp @ A
@ ^ [X2: A] : ( F2 @ X2 @ X2 ) ) ) ) ) ).
% lfp_lfp
thf(fact_7145_lfp__greatest,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,A4: A] :
( ! [U4: A] :
( ( ord_less_eq @ A @ ( F2 @ U4 ) @ U4 )
=> ( ord_less_eq @ A @ A4 @ U4 ) )
=> ( ord_less_eq @ A @ A4 @ ( complete_lattice_lfp @ A @ F2 ) ) ) ) ).
% lfp_greatest
thf(fact_7146_lfp__lowerbound,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,A4: A] :
( ( ord_less_eq @ A @ ( F2 @ A4 ) @ A4 )
=> ( ord_less_eq @ A @ ( complete_lattice_lfp @ A @ F2 ) @ A4 ) ) ) ).
% lfp_lowerbound
thf(fact_7147_lfp__mono,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,G: A > A] :
( ! [Z10: A] : ( ord_less_eq @ A @ ( F2 @ Z10 ) @ ( G @ Z10 ) )
=> ( ord_less_eq @ A @ ( complete_lattice_lfp @ A @ F2 ) @ ( complete_lattice_lfp @ A @ G ) ) ) ) ).
% lfp_mono
thf(fact_7148_lfp__eqI,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F5: A > A,X: A] :
( ( order_mono @ A @ A @ F5 )
=> ( ( ( F5 @ X )
= X )
=> ( ! [Z2: A] :
( ( ( F5 @ Z2 )
= Z2 )
=> ( ord_less_eq @ A @ X @ Z2 ) )
=> ( ( complete_lattice_lfp @ A @ F5 )
= X ) ) ) ) ) ).
% lfp_eqI
thf(fact_7149_quotient__disj,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X7: set @ A,Y6: set @ A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ ( set @ A ) @ X7 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( ( member2 @ ( set @ A ) @ Y6 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( ( X7 = Y6 )
| ( ( inf_inf @ ( set @ A ) @ X7 @ Y6 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% quotient_disj
thf(fact_7150_lfp__induct,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,P2: A] :
( ( order_mono @ A @ A @ F2 )
=> ( ( ord_less_eq @ A @ ( F2 @ ( inf_inf @ A @ ( complete_lattice_lfp @ A @ F2 ) @ P2 ) ) @ P2 )
=> ( ord_less_eq @ A @ ( complete_lattice_lfp @ A @ F2 ) @ P2 ) ) ) ) ).
% lfp_induct
thf(fact_7151_def__lfp__induct,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: A,F2: A > A,P2: A] :
( ( A4
= ( complete_lattice_lfp @ A @ F2 ) )
=> ( ( order_mono @ A @ A @ F2 )
=> ( ( ord_less_eq @ A @ ( F2 @ ( inf_inf @ A @ A4 @ P2 ) ) @ P2 )
=> ( ord_less_eq @ A @ A4 @ P2 ) ) ) ) ) ).
% def_lfp_induct
thf(fact_7152_lfp__ordinal__induct,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,P2: A > $o] :
( ( order_mono @ A @ A @ F2 )
=> ( ! [S6: A] :
( ( P2 @ S6 )
=> ( ( ord_less_eq @ A @ S6 @ ( complete_lattice_lfp @ A @ F2 ) )
=> ( P2 @ ( F2 @ S6 ) ) ) )
=> ( ! [M8: set @ A] :
( ! [X3: A] :
( ( member2 @ A @ X3 @ M8 )
=> ( P2 @ X3 ) )
=> ( P2 @ ( complete_Sup_Sup @ A @ M8 ) ) )
=> ( P2 @ ( complete_lattice_lfp @ A @ F2 ) ) ) ) ) ) ).
% lfp_ordinal_induct
thf(fact_7153_lfp__funpow,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,N2: nat] :
( ( order_mono @ A @ A @ F2 )
=> ( ( complete_lattice_lfp @ A @ ( compow @ ( A > A ) @ ( suc @ N2 ) @ F2 ) )
= ( complete_lattice_lfp @ A @ F2 ) ) ) ) ).
% lfp_funpow
thf(fact_7154_eq__equiv__class__iff2,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X: A,Y: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( member2 @ A @ Y @ A4 )
=> ( ( ( equiv_quotient @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) @ R2 )
= ( equiv_quotient @ A @ ( insert2 @ A @ Y @ ( bot_bot @ ( set @ A ) ) ) @ R2 ) )
= ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 ) ) ) ) ) ).
% eq_equiv_class_iff2
thf(fact_7155_lfp__Kleene__iter,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,K: nat] :
( ( order_mono @ A @ A @ F2 )
=> ( ( ( compow @ ( A > A ) @ ( suc @ K ) @ F2 @ ( bot_bot @ A ) )
= ( compow @ ( A > A ) @ K @ F2 @ ( bot_bot @ A ) ) )
=> ( ( complete_lattice_lfp @ A @ F2 )
= ( compow @ ( A > A ) @ K @ F2 @ ( bot_bot @ A ) ) ) ) ) ) ).
% lfp_Kleene_iter
thf(fact_7156_in__quotient__imp__in__rel,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X7: set @ A,X: A,Y: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ ( set @ A ) @ X7 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ ( insert2 @ A @ Y @ ( bot_bot @ ( set @ A ) ) ) ) @ X7 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 ) ) ) ) ).
% in_quotient_imp_in_rel
thf(fact_7157_iteratesp__def,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ( ( comple7512665784863727008ratesp @ A )
= ( ^ [F3: A > A] :
( complete_lattice_lfp @ ( A > $o )
@ ^ [P6: A > $o,X2: A] :
( ? [Y2: A] :
( ( X2
= ( F3 @ Y2 ) )
& ( P6 @ Y2 ) )
| ? [M9: set @ A] :
( ( X2
= ( complete_Sup_Sup @ A @ M9 ) )
& ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ M9 )
& ! [Y2: A] :
( ( member2 @ A @ Y2 @ M9 )
=> ( P6 @ Y2 ) ) ) ) ) ) ) ) ).
% iteratesp_def
thf(fact_7158_UN__equiv__class__inject,axiom,
! [B: $tType,A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),F2: A > ( set @ B ),X7: set @ A,Y6: set @ A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( equiv_congruent @ A @ ( set @ B ) @ R2 @ F2 )
=> ( ( ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ F2 @ X7 ) )
= ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ F2 @ Y6 ) ) )
=> ( ( member2 @ ( set @ A ) @ X7 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( ( member2 @ ( set @ A ) @ Y6 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( ( member2 @ A @ Y4 @ A4 )
=> ( ( ( F2 @ X5 )
= ( F2 @ Y4 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Y4 ) @ R2 ) ) ) )
=> ( X7 = Y6 ) ) ) ) ) ) ) ).
% UN_equiv_class_inject
thf(fact_7159_congruentI,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A ),F2: A > B] :
( ! [Y4: A,Z2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z2 ) @ R2 )
=> ( ( F2 @ Y4 )
= ( F2 @ Z2 ) ) )
=> ( equiv_congruent @ A @ B @ R2 @ F2 ) ) ).
% congruentI
thf(fact_7160_congruentD,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A ),F2: A > B,Y: A,Z: A] :
( ( equiv_congruent @ A @ B @ R2 @ F2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ Z ) @ R2 )
=> ( ( F2 @ Y )
= ( F2 @ Z ) ) ) ) ).
% congruentD
thf(fact_7161_lfp__induct2,axiom,
! [A: $tType,B: $tType,A3: A,B2: B,F2: ( set @ ( product_prod @ A @ B ) ) > ( set @ ( product_prod @ A @ B ) ),P2: A > B > $o] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ ( complete_lattice_lfp @ ( set @ ( product_prod @ A @ B ) ) @ F2 ) )
=> ( ( order_mono @ ( set @ ( product_prod @ A @ B ) ) @ ( set @ ( product_prod @ A @ B ) ) @ F2 )
=> ( ! [A7: A,B5: B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A7 @ B5 ) @ ( F2 @ ( inf_inf @ ( set @ ( product_prod @ A @ B ) ) @ ( complete_lattice_lfp @ ( set @ ( product_prod @ A @ B ) ) @ F2 ) @ ( collect @ ( product_prod @ A @ B ) @ ( product_case_prod @ A @ B @ $o @ P2 ) ) ) ) )
=> ( P2 @ A7 @ B5 ) )
=> ( P2 @ A3 @ B2 ) ) ) ) ).
% lfp_induct2
thf(fact_7162_iteratesp_OSup,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [M7: set @ A,F2: A > A] :
( ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ M7 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ M7 )
=> ( comple7512665784863727008ratesp @ A @ F2 @ X5 ) )
=> ( comple7512665784863727008ratesp @ A @ F2 @ ( complete_Sup_Sup @ A @ M7 ) ) ) ) ) ).
% iteratesp.Sup
thf(fact_7163_iteratesp_Ocases,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [F2: A > A,A3: A] :
( ( comple7512665784863727008ratesp @ A @ F2 @ A3 )
=> ( ! [X5: A] :
( ( A3
= ( F2 @ X5 ) )
=> ~ ( comple7512665784863727008ratesp @ A @ F2 @ X5 ) )
=> ~ ! [M8: set @ A] :
( ( A3
= ( complete_Sup_Sup @ A @ M8 ) )
=> ( ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ M8 )
=> ~ ! [X3: A] :
( ( member2 @ A @ X3 @ M8 )
=> ( comple7512665784863727008ratesp @ A @ F2 @ X3 ) ) ) ) ) ) ) ).
% iteratesp.cases
thf(fact_7164_iteratesp_Osimps,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ( ( comple7512665784863727008ratesp @ A )
= ( ^ [F3: A > A,A5: A] :
( ? [X2: A] :
( ( A5
= ( F3 @ X2 ) )
& ( comple7512665784863727008ratesp @ A @ F3 @ X2 ) )
| ? [M9: set @ A] :
( ( A5
= ( complete_Sup_Sup @ A @ M9 ) )
& ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ M9 )
& ! [X2: A] :
( ( member2 @ A @ X2 @ M9 )
=> ( comple7512665784863727008ratesp @ A @ F3 @ X2 ) ) ) ) ) ) ) ).
% iteratesp.simps
thf(fact_7165_lfp__transfer__bounded,axiom,
! [A: $tType,B: $tType] :
( ( ( comple6319245703460814977attice @ B )
& ( comple6319245703460814977attice @ A ) )
=> ! [P2: A > $o,F2: A > A,Alpha: A > B,G: B > B] :
( ( P2 @ ( bot_bot @ A ) )
=> ( ! [X5: A] :
( ( P2 @ X5 )
=> ( P2 @ ( F2 @ X5 ) ) )
=> ( ! [M8: nat > A] :
( ! [I4: nat] : ( P2 @ ( M8 @ I4 ) )
=> ( P2 @ ( complete_Sup_Sup @ A @ ( image2 @ nat @ A @ M8 @ ( top_top @ ( set @ nat ) ) ) ) ) )
=> ( ! [M8: nat > A] :
( ( order_mono @ nat @ A @ M8 )
=> ( ! [I4: nat] : ( P2 @ ( M8 @ I4 ) )
=> ( ( Alpha @ ( complete_Sup_Sup @ A @ ( image2 @ nat @ A @ M8 @ ( top_top @ ( set @ nat ) ) ) ) )
= ( complete_Sup_Sup @ B
@ ( image2 @ nat @ B
@ ^ [I5: nat] : ( Alpha @ ( M8 @ I5 ) )
@ ( top_top @ ( set @ nat ) ) ) ) ) ) )
=> ( ( order_sup_continuous @ A @ A @ F2 )
=> ( ( order_sup_continuous @ B @ B @ G )
=> ( ! [X5: A] :
( ( P2 @ X5 )
=> ( ( ord_less_eq @ A @ X5 @ ( complete_lattice_lfp @ A @ F2 ) )
=> ( ( Alpha @ ( F2 @ X5 ) )
= ( G @ ( Alpha @ X5 ) ) ) ) )
=> ( ! [X5: B] : ( ord_less_eq @ B @ ( Alpha @ ( bot_bot @ A ) ) @ ( G @ X5 ) )
=> ( ( Alpha @ ( complete_lattice_lfp @ A @ F2 ) )
= ( complete_lattice_lfp @ B @ G ) ) ) ) ) ) ) ) ) ) ) ).
% lfp_transfer_bounded
thf(fact_7166_proj__iff,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X: A,Y: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ X @ ( insert2 @ A @ Y @ ( bot_bot @ ( set @ A ) ) ) ) @ A4 )
=> ( ( ( equiv_proj @ A @ A @ R2 @ X )
= ( equiv_proj @ A @ A @ R2 @ Y ) )
= ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 ) ) ) ) ).
% proj_iff
thf(fact_7167_lfp__transfer,axiom,
! [A: $tType,B: $tType] :
( ( ( comple6319245703460814977attice @ B )
& ( comple6319245703460814977attice @ A ) )
=> ! [Alpha: A > B,F2: A > A,G: B > B] :
( ( order_sup_continuous @ A @ B @ Alpha )
=> ( ( order_sup_continuous @ A @ A @ F2 )
=> ( ( order_sup_continuous @ B @ B @ G )
=> ( ! [X5: B] : ( ord_less_eq @ B @ ( Alpha @ ( bot_bot @ A ) ) @ ( G @ X5 ) )
=> ( ! [X5: A] :
( ( ord_less_eq @ A @ X5 @ ( complete_lattice_lfp @ A @ F2 ) )
=> ( ( Alpha @ ( F2 @ X5 ) )
= ( G @ ( Alpha @ X5 ) ) ) )
=> ( ( Alpha @ ( complete_lattice_lfp @ A @ F2 ) )
= ( complete_lattice_lfp @ B @ G ) ) ) ) ) ) ) ) ).
% lfp_transfer
thf(fact_7168_cclfp__transfer,axiom,
! [A: $tType,B: $tType] :
( ( ( counta3822494911875563373attice @ B )
& ( counta3822494911875563373attice @ A ) )
=> ! [Alpha: A > B,F2: A > A,G: B > B] :
( ( order_sup_continuous @ A @ B @ Alpha )
=> ( ( order_mono @ A @ A @ F2 )
=> ( ( ( Alpha @ ( bot_bot @ A ) )
= ( bot_bot @ B ) )
=> ( ! [X5: A] :
( ( Alpha @ ( F2 @ X5 ) )
= ( G @ ( Alpha @ X5 ) ) )
=> ( ( Alpha @ ( order_532582986084564980_cclfp @ A @ F2 ) )
= ( order_532582986084564980_cclfp @ B @ G ) ) ) ) ) ) ) ).
% cclfp_transfer
thf(fact_7169_sup__continuous__lfp,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F5: A > A] :
( ( order_sup_continuous @ A @ A @ F5 )
=> ( ( complete_lattice_lfp @ A @ F5 )
= ( complete_Sup_Sup @ A
@ ( image2 @ nat @ A
@ ^ [I5: nat] : ( compow @ ( A > A ) @ I5 @ F5 @ ( bot_bot @ A ) )
@ ( top_top @ ( set @ nat ) ) ) ) ) ) ) ).
% sup_continuous_lfp
thf(fact_7170_UN__equiv__class,axiom,
! [B: $tType,A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),F2: A > ( set @ B ),A3: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( equiv_congruent @ A @ ( set @ B ) @ R2 @ F2 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ F2 @ ( image @ A @ A @ R2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) )
= ( F2 @ A3 ) ) ) ) ) ).
% UN_equiv_class
thf(fact_7171_ord__class_Olexordp__def,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( ord_lexordp @ A )
= ( complete_lattice_lfp @ ( ( list @ A ) > ( list @ A ) > $o )
@ ^ [P6: ( list @ A ) > ( list @ A ) > $o,X16: list @ A,X24: list @ A] :
( ? [Y2: A,Ys3: list @ A] :
( ( X16
= ( nil @ A ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( X16
= ( cons @ A @ X2 @ Xs2 ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) )
& ( ord_less @ A @ X2 @ Y2 ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( X16
= ( cons @ A @ X2 @ Xs2 ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) )
& ~ ( ord_less @ A @ X2 @ Y2 )
& ~ ( ord_less @ A @ Y2 @ X2 )
& ( P6 @ Xs2 @ Ys3 ) ) ) ) ) ) ).
% ord_class.lexordp_def
thf(fact_7172_ImageI,axiom,
! [B: $tType,A: $tType,A3: A,B2: B,R2: set @ ( product_prod @ A @ B ),A4: set @ A] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ R2 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( member2 @ B @ B2 @ ( image @ A @ B @ R2 @ A4 ) ) ) ) ).
% ImageI
thf(fact_7173_Image__empty2,axiom,
! [B: $tType,A: $tType,R: set @ ( product_prod @ B @ A )] :
( ( image @ B @ A @ R @ ( bot_bot @ ( set @ B ) ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% Image_empty2
thf(fact_7174_lexordp__simps_I1_J,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [Ys: list @ A] :
( ( ord_lexordp @ A @ ( nil @ A ) @ Ys )
= ( Ys
!= ( nil @ A ) ) ) ) ).
% lexordp_simps(1)
thf(fact_7175_lexordp__simps_I2_J,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [Xs: list @ A] :
~ ( ord_lexordp @ A @ Xs @ ( nil @ A ) ) ) ).
% lexordp_simps(2)
thf(fact_7176_lexordp__simps_I3_J,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [X: A,Xs: list @ A,Y: A,Ys: list @ A] :
( ( ord_lexordp @ A @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) )
= ( ( ord_less @ A @ X @ Y )
| ( ~ ( ord_less @ A @ Y @ X )
& ( ord_lexordp @ A @ Xs @ Ys ) ) ) ) ) ).
% lexordp_simps(3)
thf(fact_7177_Image__empty1,axiom,
! [B: $tType,A: $tType,X7: set @ B] :
( ( image @ B @ A @ ( bot_bot @ ( set @ ( product_prod @ B @ A ) ) ) @ X7 )
= ( bot_bot @ ( set @ A ) ) ) ).
% Image_empty1
thf(fact_7178_Image__singleton__iff,axiom,
! [A: $tType,B: $tType,B2: A,R2: set @ ( product_prod @ B @ A ),A3: B] :
( ( member2 @ A @ B2 @ ( image @ B @ A @ R2 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) )
= ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ A3 @ B2 ) @ R2 ) ) ).
% Image_singleton_iff
thf(fact_7179_listrel__Nil,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ B @ A )] :
( ( image @ ( list @ B ) @ ( list @ A ) @ ( listrel @ B @ A @ R2 ) @ ( insert2 @ ( list @ B ) @ ( nil @ B ) @ ( bot_bot @ ( set @ ( list @ B ) ) ) ) )
= ( insert2 @ ( list @ A ) @ ( nil @ A ) @ ( bot_bot @ ( set @ ( list @ A ) ) ) ) ) ).
% listrel_Nil
thf(fact_7180_equiv__class__self,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),A3: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( member2 @ A @ A3 @ ( image @ A @ A @ R2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% equiv_class_self
thf(fact_7181_wfE__pf,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A ),A4: set @ A] :
( ( wf @ A @ R )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( image @ A @ A @ R @ A4 ) )
=> ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% wfE_pf
thf(fact_7182_wfI__pf,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A )] :
( ! [A9: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A9 @ ( image @ A @ A @ R @ A9 ) )
=> ( A9
= ( bot_bot @ ( set @ A ) ) ) )
=> ( wf @ A @ R ) ) ).
% wfI_pf
thf(fact_7183_Image__mono,axiom,
! [B: $tType,A: $tType,R6: set @ ( product_prod @ A @ B ),R2: set @ ( product_prod @ A @ B ),A16: set @ A,A4: set @ A] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) ) @ R6 @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ A16 @ A4 )
=> ( ord_less_eq @ ( set @ B ) @ ( image @ A @ B @ R6 @ A16 ) @ ( image @ A @ B @ R2 @ A4 ) ) ) ) ).
% Image_mono
thf(fact_7184_Image__closed__trancl,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),X7: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( image @ A @ A @ R2 @ X7 ) @ X7 )
=> ( ( image @ A @ A @ ( transitive_rtrancl @ A @ R2 ) @ X7 )
= X7 ) ) ).
% Image_closed_trancl
thf(fact_7185_Image__Int__subset,axiom,
! [A: $tType,B: $tType,R: set @ ( product_prod @ B @ A ),A4: set @ B,B3: set @ B] : ( ord_less_eq @ ( set @ A ) @ ( image @ B @ A @ R @ ( inf_inf @ ( set @ B ) @ A4 @ B3 ) ) @ ( inf_inf @ ( set @ A ) @ ( image @ B @ A @ R @ A4 ) @ ( image @ B @ A @ R @ B3 ) ) ) ).
% Image_Int_subset
thf(fact_7186_lexordp__append__rightI,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [Ys: list @ A,Xs: list @ A] :
( ( Ys
!= ( nil @ A ) )
=> ( ord_lexordp @ A @ Xs @ ( append @ A @ Xs @ Ys ) ) ) ) ).
% lexordp_append_rightI
thf(fact_7187_ImageE,axiom,
! [A: $tType,B: $tType,B2: A,R2: set @ ( product_prod @ B @ A ),A4: set @ B] :
( ( member2 @ A @ B2 @ ( image @ B @ A @ R2 @ A4 ) )
=> ~ ! [X5: B] :
( ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ X5 @ B2 ) @ R2 )
=> ~ ( member2 @ B @ X5 @ A4 ) ) ) ).
% ImageE
thf(fact_7188_Image__iff,axiom,
! [A: $tType,B: $tType,B2: A,R2: set @ ( product_prod @ B @ A ),A4: set @ B] :
( ( member2 @ A @ B2 @ ( image @ B @ A @ R2 @ A4 ) )
= ( ? [X2: B] :
( ( member2 @ B @ X2 @ A4 )
& ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ X2 @ B2 ) @ R2 ) ) ) ) ).
% Image_iff
thf(fact_7189_rev__ImageI,axiom,
! [B: $tType,A: $tType,A3: A,A4: set @ A,B2: B,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ A @ A3 @ A4 )
=> ( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ R2 )
=> ( member2 @ B @ B2 @ ( image @ A @ B @ R2 @ A4 ) ) ) ) ).
% rev_ImageI
thf(fact_7190_lexordp_ONil,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [Y: A,Ys: list @ A] : ( ord_lexordp @ A @ ( nil @ A ) @ ( cons @ A @ Y @ Ys ) ) ) ).
% lexordp.Nil
thf(fact_7191_lexordp_OCons,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [X: A,Y: A,Xs: list @ A,Ys: list @ A] :
( ( ord_less @ A @ X @ Y )
=> ( ord_lexordp @ A @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) ) ) ) ).
% lexordp.Cons
thf(fact_7192_lexordp_OCons__eq,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [X: A,Y: A,Xs: list @ A,Ys: list @ A] :
( ~ ( ord_less @ A @ X @ Y )
=> ( ~ ( ord_less @ A @ Y @ X )
=> ( ( ord_lexordp @ A @ Xs @ Ys )
=> ( ord_lexordp @ A @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) ) ) ) ) ) ).
% lexordp.Cons_eq
thf(fact_7193_lexordp__irreflexive,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [Xs: list @ A] :
( ! [X5: A] :
~ ( ord_less @ A @ X5 @ X5 )
=> ~ ( ord_lexordp @ A @ Xs @ Xs ) ) ) ).
% lexordp_irreflexive
thf(fact_7194_lexordp__antisym,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [Xs: list @ A,Ys: list @ A] :
( ( ord_lexordp @ A @ Xs @ Ys )
=> ~ ( ord_lexordp @ A @ Ys @ Xs ) ) ) ).
% lexordp_antisym
thf(fact_7195_lexordp__trans,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,Ys: list @ A,Zs: list @ A] :
( ( ord_lexordp @ A @ Xs @ Ys )
=> ( ( ord_lexordp @ A @ Ys @ Zs )
=> ( ord_lexordp @ A @ Xs @ Zs ) ) ) ) ).
% lexordp_trans
thf(fact_7196_lexordp__linear,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,Ys: list @ A] :
( ( ord_lexordp @ A @ Xs @ Ys )
| ( Xs = Ys )
| ( ord_lexordp @ A @ Ys @ Xs ) ) ) ).
% lexordp_linear
thf(fact_7197_lexordp__irreflexive_H,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [Xs: list @ A] :
~ ( ord_lexordp @ A @ Xs @ Xs ) ) ).
% lexordp_irreflexive'
thf(fact_7198_lexordp__append__leftI,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [Us: list @ A,Vs2: list @ A,Xs: list @ A] :
( ( ord_lexordp @ A @ Us @ Vs2 )
=> ( ord_lexordp @ A @ ( append @ A @ Xs @ Us ) @ ( append @ A @ Xs @ Vs2 ) ) ) ) ).
% lexordp_append_leftI
thf(fact_7199_lexordp__append__leftD,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [Xs: list @ A,Us: list @ A,Vs2: list @ A] :
( ( ord_lexordp @ A @ ( append @ A @ Xs @ Us ) @ ( append @ A @ Xs @ Vs2 ) )
=> ( ! [A7: A] :
~ ( ord_less @ A @ A7 @ A7 )
=> ( ord_lexordp @ A @ Us @ Vs2 ) ) ) ) ).
% lexordp_append_leftD
thf(fact_7200_Image__def,axiom,
! [B: $tType,A: $tType] :
( ( image @ A @ B )
= ( ^ [R4: set @ ( product_prod @ A @ B ),S7: set @ A] :
( collect @ B
@ ^ [Y2: B] :
? [X2: A] :
( ( member2 @ A @ X2 @ S7 )
& ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R4 ) ) ) ) ) ).
% Image_def
thf(fact_7201_countable__Image,axiom,
! [B: $tType,A: $tType,Y6: set @ A,X7: set @ ( product_prod @ A @ B )] :
( ! [Y4: A] :
( ( member2 @ A @ Y4 @ Y6 )
=> ( countable_countable @ B @ ( image @ A @ B @ X7 @ ( insert2 @ A @ Y4 @ ( bot_bot @ ( set @ A ) ) ) ) ) )
=> ( ( countable_countable @ A @ Y6 )
=> ( countable_countable @ B @ ( image @ A @ B @ X7 @ Y6 ) ) ) ) ).
% countable_Image
thf(fact_7202_quotientE,axiom,
! [A: $tType,X7: set @ A,A4: set @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( set @ A ) @ X7 @ ( equiv_quotient @ A @ A4 @ R2 ) )
=> ~ ! [X5: A] :
( ( X7
= ( image @ A @ A @ R2 @ ( insert2 @ A @ X5 @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ~ ( member2 @ A @ X5 @ A4 ) ) ) ).
% quotientE
thf(fact_7203_quotientI,axiom,
! [A: $tType,X: A,A4: set @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ A @ X @ A4 )
=> ( member2 @ ( set @ A ) @ ( image @ A @ A @ R2 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) @ ( equiv_quotient @ A @ A4 @ R2 ) ) ) ).
% quotientI
thf(fact_7204_Image__singleton,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ B @ A ),A3: B] :
( ( image @ B @ A @ R2 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) )
= ( collect @ A
@ ^ [B4: A] : ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ A3 @ B4 ) @ R2 ) ) ) ).
% Image_singleton
thf(fact_7205_proj__def,axiom,
! [A: $tType,B: $tType] :
( ( equiv_proj @ B @ A )
= ( ^ [R4: set @ ( product_prod @ B @ A ),X2: B] : ( image @ B @ A @ R4 @ ( insert2 @ B @ X2 @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ).
% proj_def
thf(fact_7206_Image__INT__subset,axiom,
! [A: $tType,B: $tType,C: $tType,R2: set @ ( product_prod @ B @ A ),B3: C > ( set @ B ),A4: set @ C] :
( ord_less_eq @ ( set @ A ) @ ( image @ B @ A @ R2 @ ( complete_Inf_Inf @ ( set @ B ) @ ( image2 @ C @ ( set @ B ) @ B3 @ A4 ) ) )
@ ( complete_Inf_Inf @ ( set @ A )
@ ( image2 @ C @ ( set @ A )
@ ^ [X2: C] : ( image @ B @ A @ R2 @ ( B3 @ X2 ) )
@ A4 ) ) ) ).
% Image_INT_subset
thf(fact_7207_Image__subset,axiom,
! [A: $tType,B: $tType,R2: set @ ( product_prod @ A @ B ),A4: set @ A,B3: set @ B,C5: set @ A] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) ) @ R2
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) )
=> ( ord_less_eq @ ( set @ B ) @ ( image @ A @ B @ R2 @ C5 ) @ B3 ) ) ).
% Image_subset
thf(fact_7208_lexordp_Ocases,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [A12: list @ A,A23: list @ A] :
( ( ord_lexordp @ A @ A12 @ A23 )
=> ( ( ( A12
= ( nil @ A ) )
=> ! [Y4: A,Ys4: list @ A] :
( A23
!= ( cons @ A @ Y4 @ Ys4 ) ) )
=> ( ! [X5: A] :
( ? [Xs3: list @ A] :
( A12
= ( cons @ A @ X5 @ Xs3 ) )
=> ! [Y4: A] :
( ? [Ys4: list @ A] :
( A23
= ( cons @ A @ Y4 @ Ys4 ) )
=> ~ ( ord_less @ A @ X5 @ Y4 ) ) )
=> ~ ! [X5: A,Y4: A,Xs3: list @ A] :
( ( A12
= ( cons @ A @ X5 @ Xs3 ) )
=> ! [Ys4: list @ A] :
( ( A23
= ( cons @ A @ Y4 @ Ys4 ) )
=> ( ~ ( ord_less @ A @ X5 @ Y4 )
=> ( ~ ( ord_less @ A @ Y4 @ X5 )
=> ~ ( ord_lexordp @ A @ Xs3 @ Ys4 ) ) ) ) ) ) ) ) ) ).
% lexordp.cases
thf(fact_7209_lexordp_Osimps,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( ord_lexordp @ A )
= ( ^ [A1: list @ A,A22: list @ A] :
( ? [Y2: A,Ys3: list @ A] :
( ( A1
= ( nil @ A ) )
& ( A22
= ( cons @ A @ Y2 @ Ys3 ) ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( A1
= ( cons @ A @ X2 @ Xs2 ) )
& ( A22
= ( cons @ A @ Y2 @ Ys3 ) )
& ( ord_less @ A @ X2 @ Y2 ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( A1
= ( cons @ A @ X2 @ Xs2 ) )
& ( A22
= ( cons @ A @ Y2 @ Ys3 ) )
& ~ ( ord_less @ A @ X2 @ Y2 )
& ~ ( ord_less @ A @ Y2 @ X2 )
& ( ord_lexordp @ A @ Xs2 @ Ys3 ) ) ) ) ) ) ).
% lexordp.simps
thf(fact_7210_lexordp__cases,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,Ys: list @ A] :
( ( ord_lexordp @ A @ Xs @ Ys )
=> ( ( ( Xs
= ( nil @ A ) )
=> ! [Y4: A,Ys5: list @ A] :
( Ys
!= ( cons @ A @ Y4 @ Ys5 ) ) )
=> ( ! [X5: A] :
( ? [Xs4: list @ A] :
( Xs
= ( cons @ A @ X5 @ Xs4 ) )
=> ! [Y4: A] :
( ? [Ys5: list @ A] :
( Ys
= ( cons @ A @ Y4 @ Ys5 ) )
=> ~ ( ord_less @ A @ X5 @ Y4 ) ) )
=> ~ ! [X5: A,Xs4: list @ A] :
( ( Xs
= ( cons @ A @ X5 @ Xs4 ) )
=> ! [Ys5: list @ A] :
( ( Ys
= ( cons @ A @ X5 @ Ys5 ) )
=> ~ ( ord_lexordp @ A @ Xs4 @ Ys5 ) ) ) ) ) ) ) ).
% lexordp_cases
thf(fact_7211_lexordp__induct,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,Ys: list @ A,P2: ( list @ A ) > ( list @ A ) > $o] :
( ( ord_lexordp @ A @ Xs @ Ys )
=> ( ! [Y4: A,Ys4: list @ A] : ( P2 @ ( nil @ A ) @ ( cons @ A @ Y4 @ Ys4 ) )
=> ( ! [X5: A,Xs3: list @ A,Y4: A,Ys4: list @ A] :
( ( ord_less @ A @ X5 @ Y4 )
=> ( P2 @ ( cons @ A @ X5 @ Xs3 ) @ ( cons @ A @ Y4 @ Ys4 ) ) )
=> ( ! [X5: A,Xs3: list @ A,Ys4: list @ A] :
( ( ord_lexordp @ A @ Xs3 @ Ys4 )
=> ( ( P2 @ Xs3 @ Ys4 )
=> ( P2 @ ( cons @ A @ X5 @ Xs3 ) @ ( cons @ A @ X5 @ Ys4 ) ) ) )
=> ( P2 @ Xs @ Ys ) ) ) ) ) ) ).
% lexordp_induct
thf(fact_7212_lexordp__iff,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_lexordp @ A )
= ( ^ [Xs2: list @ A,Ys3: list @ A] :
( ? [X2: A,Vs: list @ A] :
( Ys3
= ( append @ A @ Xs2 @ ( cons @ A @ X2 @ Vs ) ) )
| ? [Us2: list @ A,A5: A,B4: A,Vs: list @ A,Ws3: list @ A] :
( ( ord_less @ A @ A5 @ B4 )
& ( Xs2
= ( append @ A @ Us2 @ ( cons @ A @ A5 @ Vs ) ) )
& ( Ys3
= ( append @ A @ Us2 @ ( cons @ A @ B4 @ Ws3 ) ) ) ) ) ) ) ) ).
% lexordp_iff
thf(fact_7213_lexordp__append__left__rightI,axiom,
! [A: $tType] :
( ( ord @ A )
=> ! [X: A,Y: A,Us: list @ A,Xs: list @ A,Ys: list @ A] :
( ( ord_less @ A @ X @ Y )
=> ( ord_lexordp @ A @ ( append @ A @ Us @ ( cons @ A @ X @ Xs ) ) @ ( append @ A @ Us @ ( cons @ A @ Y @ Ys ) ) ) ) ) ).
% lexordp_append_left_rightI
thf(fact_7214_listrel__Cons,axiom,
! [A: $tType,B: $tType,R2: set @ ( product_prod @ B @ A ),X: B,Xs: list @ B] :
( ( image @ ( list @ B ) @ ( list @ A ) @ ( listrel @ B @ A @ R2 ) @ ( insert2 @ ( list @ B ) @ ( cons @ B @ X @ Xs ) @ ( bot_bot @ ( set @ ( list @ B ) ) ) ) )
= ( set_Cons @ A @ ( image @ B @ A @ R2 @ ( insert2 @ B @ X @ ( bot_bot @ ( set @ B ) ) ) ) @ ( image @ ( list @ B ) @ ( list @ A ) @ ( listrel @ B @ A @ R2 ) @ ( insert2 @ ( list @ B ) @ Xs @ ( bot_bot @ ( set @ ( list @ B ) ) ) ) ) ) ) ).
% listrel_Cons
thf(fact_7215_equiv__class__eq__iff,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X: A,Y: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
= ( ( ( image @ A @ A @ R2 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( image @ A @ A @ R2 @ ( insert2 @ A @ Y @ ( bot_bot @ ( set @ A ) ) ) ) )
& ( member2 @ A @ X @ A4 )
& ( member2 @ A @ Y @ A4 ) ) ) ) ).
% equiv_class_eq_iff
thf(fact_7216_eq__equiv__class__iff,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X: A,Y: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( member2 @ A @ Y @ A4 )
=> ( ( ( image @ A @ A @ R2 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( image @ A @ A @ R2 @ ( insert2 @ A @ Y @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 ) ) ) ) ) ).
% eq_equiv_class_iff
thf(fact_7217_equiv__class__eq,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ( image @ A @ A @ R2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) )
= ( image @ A @ A @ R2 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% equiv_class_eq
thf(fact_7218_eq__equiv__class,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A,A4: set @ A] :
( ( ( image @ A @ A @ R2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) )
= ( image @ A @ A @ R2 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ A @ B2 @ A4 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 ) ) ) ) ).
% eq_equiv_class
thf(fact_7219_refines__equiv__class__eq,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A ),S3: set @ ( product_prod @ A @ A ),A4: set @ A,A3: A] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R @ S3 )
=> ( ( equiv_equiv @ A @ A4 @ R )
=> ( ( equiv_equiv @ A @ A4 @ S3 )
=> ( ( image @ A @ A @ R @ ( image @ A @ A @ S3 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( image @ A @ A @ S3 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% refines_equiv_class_eq
thf(fact_7220_refines__equiv__class__eq2,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A ),S3: set @ ( product_prod @ A @ A ),A4: set @ A,A3: A] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R @ S3 )
=> ( ( equiv_equiv @ A @ A4 @ R )
=> ( ( equiv_equiv @ A @ A4 @ S3 )
=> ( ( image @ A @ A @ S3 @ ( image @ A @ A @ R @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( image @ A @ A @ S3 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% refines_equiv_class_eq2
thf(fact_7221_Image__eq__UN,axiom,
! [A: $tType,B: $tType] :
( ( image @ B @ A )
= ( ^ [R4: set @ ( product_prod @ B @ A ),B6: set @ B] :
( complete_Sup_Sup @ ( set @ A )
@ ( image2 @ B @ ( set @ A )
@ ^ [Y2: B] : ( image @ B @ A @ R4 @ ( insert2 @ B @ Y2 @ ( bot_bot @ ( set @ B ) ) ) )
@ B6 ) ) ) ) ).
% Image_eq_UN
thf(fact_7222_equiv__class__subset,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ord_less_eq @ ( set @ A ) @ ( image @ A @ A @ R2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) @ ( image @ A @ A @ R2 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% equiv_class_subset
thf(fact_7223_subset__equiv__class,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),B2: A,A3: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image @ A @ A @ R2 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) @ ( image @ A @ A @ R2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( ( member2 @ A @ B2 @ A4 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 ) ) ) ) ).
% subset_equiv_class
thf(fact_7224_equiv__class__nondisjoint,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),X: A,A3: A,B2: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( member2 @ A @ X @ ( inf_inf @ ( set @ A ) @ ( image @ A @ A @ R2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) @ ( image @ A @ A @ R2 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 ) ) ) ).
% equiv_class_nondisjoint
thf(fact_7225_singleton__quotient,axiom,
! [A: $tType,X: A,R2: set @ ( product_prod @ A @ A )] :
( ( equiv_quotient @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) @ R2 )
= ( insert2 @ ( set @ A ) @ ( image @ A @ A @ R2 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) @ ( bot_bot @ ( set @ ( set @ A ) ) ) ) ) ).
% singleton_quotient
thf(fact_7226_lexordp__conv__lexord,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( ord_lexordp @ A )
= ( ^ [Xs2: list @ A,Ys3: list @ A] : ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Xs2 @ Ys3 ) @ ( lexord @ A @ ( collect @ ( product_prod @ A @ A ) @ ( product_case_prod @ A @ A @ $o @ ( ord_less @ A ) ) ) ) ) ) ) ) ).
% lexordp_conv_lexord
thf(fact_7227_quotient__def,axiom,
! [A: $tType] :
( ( equiv_quotient @ A )
= ( ^ [A6: set @ A,R4: set @ ( product_prod @ A @ A )] :
( complete_Sup_Sup @ ( set @ ( set @ A ) )
@ ( image2 @ A @ ( set @ ( set @ A ) )
@ ^ [X2: A] : ( insert2 @ ( set @ A ) @ ( image @ A @ A @ R4 @ ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) ) @ ( bot_bot @ ( set @ ( set @ A ) ) ) )
@ A6 ) ) ) ) ).
% quotient_def
thf(fact_7228_Image__fold,axiom,
! [B: $tType,A: $tType,R: set @ ( product_prod @ A @ B ),S3: set @ A] :
( ( finite_finite @ ( product_prod @ A @ B ) @ R )
=> ( ( image @ A @ B @ R @ S3 )
= ( finite_fold @ ( product_prod @ A @ B ) @ ( set @ B )
@ ( product_case_prod @ A @ B @ ( ( set @ B ) > ( set @ B ) )
@ ^ [X2: A,Y2: B,A6: set @ B] : ( if @ ( set @ B ) @ ( member2 @ A @ X2 @ S3 ) @ ( insert2 @ B @ Y2 @ A6 ) @ A6 ) )
@ ( bot_bot @ ( set @ B ) )
@ R ) ) ) ).
% Image_fold
thf(fact_7229_congruent2__implies__congruent__UN,axiom,
! [B: $tType,C: $tType,A: $tType,A18: set @ A,R1: set @ ( product_prod @ A @ A ),A26: set @ B,R22: set @ ( product_prod @ B @ B ),F2: A > B > ( set @ C ),A3: B] :
( ( equiv_equiv @ A @ A18 @ R1 )
=> ( ( equiv_equiv @ B @ A26 @ R22 )
=> ( ( equiv_congruent2 @ A @ B @ ( set @ C ) @ R1 @ R22 @ F2 )
=> ( ( member2 @ B @ A3 @ A26 )
=> ( equiv_congruent @ A @ ( set @ C ) @ R1
@ ^ [X16: A] : ( complete_Sup_Sup @ ( set @ C ) @ ( image2 @ B @ ( set @ C ) @ ( F2 @ X16 ) @ ( image @ B @ B @ R22 @ ( insert2 @ B @ A3 @ ( bot_bot @ ( set @ B ) ) ) ) ) ) ) ) ) ) ) ).
% congruent2_implies_congruent_UN
thf(fact_7230_UN__equiv__class2,axiom,
! [A: $tType,C: $tType,B: $tType,A18: set @ A,R1: set @ ( product_prod @ A @ A ),A26: set @ B,R22: set @ ( product_prod @ B @ B ),F2: A > B > ( set @ C ),A12: A,A23: B] :
( ( equiv_equiv @ A @ A18 @ R1 )
=> ( ( equiv_equiv @ B @ A26 @ R22 )
=> ( ( equiv_congruent2 @ A @ B @ ( set @ C ) @ R1 @ R22 @ F2 )
=> ( ( member2 @ A @ A12 @ A18 )
=> ( ( member2 @ B @ A23 @ A26 )
=> ( ( complete_Sup_Sup @ ( set @ C )
@ ( image2 @ A @ ( set @ C )
@ ^ [X16: A] : ( complete_Sup_Sup @ ( set @ C ) @ ( image2 @ B @ ( set @ C ) @ ( F2 @ X16 ) @ ( image @ B @ B @ R22 @ ( insert2 @ B @ A23 @ ( bot_bot @ ( set @ B ) ) ) ) ) )
@ ( image @ A @ A @ R1 @ ( insert2 @ A @ A12 @ ( bot_bot @ ( set @ A ) ) ) ) ) )
= ( F2 @ A12 @ A23 ) ) ) ) ) ) ) ).
% UN_equiv_class2
thf(fact_7231_congruent2D,axiom,
! [A: $tType,C: $tType,B: $tType,R1: set @ ( product_prod @ A @ A ),R22: set @ ( product_prod @ B @ B ),F2: A > B > C,Y1: A,Z1: A,Y22: B,Z22: B] :
( ( equiv_congruent2 @ A @ B @ C @ R1 @ R22 @ F2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y1 @ Z1 ) @ R1 )
=> ( ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ Y22 @ Z22 ) @ R22 )
=> ( ( F2 @ Y1 @ Y22 )
= ( F2 @ Z1 @ Z22 ) ) ) ) ) ).
% congruent2D
thf(fact_7232_congruent2I_H,axiom,
! [C: $tType,B: $tType,A: $tType,R1: set @ ( product_prod @ A @ A ),R22: set @ ( product_prod @ B @ B ),F2: A > B > C] :
( ! [Y15: A,Z12: A,Y23: B,Z23: B] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y15 @ Z12 ) @ R1 )
=> ( ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ Y23 @ Z23 ) @ R22 )
=> ( ( F2 @ Y15 @ Y23 )
= ( F2 @ Z12 @ Z23 ) ) ) )
=> ( equiv_congruent2 @ A @ B @ C @ R1 @ R22 @ F2 ) ) ).
% congruent2I'
thf(fact_7233_congruent2I,axiom,
! [C: $tType,B: $tType,A: $tType,A18: set @ A,R1: set @ ( product_prod @ A @ A ),A26: set @ B,R22: set @ ( product_prod @ B @ B ),F2: A > B > C] :
( ( equiv_equiv @ A @ A18 @ R1 )
=> ( ( equiv_equiv @ B @ A26 @ R22 )
=> ( ! [Y4: A,Z2: A,W: B] :
( ( member2 @ B @ W @ A26 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z2 ) @ R1 )
=> ( ( F2 @ Y4 @ W )
= ( F2 @ Z2 @ W ) ) ) )
=> ( ! [Y4: B,Z2: B,W: A] :
( ( member2 @ A @ W @ A18 )
=> ( ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ Y4 @ Z2 ) @ R22 )
=> ( ( F2 @ W @ Y4 )
= ( F2 @ W @ Z2 ) ) ) )
=> ( equiv_congruent2 @ A @ B @ C @ R1 @ R22 @ F2 ) ) ) ) ) ).
% congruent2I
thf(fact_7234_congruent2__commuteI,axiom,
! [B: $tType,A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),F2: A > A > B] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ! [Y4: A,Z2: A] :
( ( member2 @ A @ Y4 @ A4 )
=> ( ( member2 @ A @ Z2 @ A4 )
=> ( ( F2 @ Y4 @ Z2 )
= ( F2 @ Z2 @ Y4 ) ) ) )
=> ( ! [Y4: A,Z2: A,W: A] :
( ( member2 @ A @ W @ A4 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z2 ) @ R2 )
=> ( ( F2 @ W @ Y4 )
= ( F2 @ W @ Z2 ) ) ) )
=> ( equiv_congruent2 @ A @ A @ B @ R2 @ R2 @ F2 ) ) ) ) ).
% congruent2_commuteI
thf(fact_7235_subset__Image1__Image1__iff,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( order_preorder_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ B2 @ ( field2 @ A @ R2 ) )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image @ A @ A @ R2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) @ ( image @ A @ A @ R2 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ A3 ) @ R2 ) ) ) ) ) ).
% subset_Image1_Image1_iff
thf(fact_7236_ord_Olexordp__def,axiom,
! [A: $tType] :
( ( lexordp2 @ A )
= ( ^ [Less2: A > A > $o] :
( complete_lattice_lfp @ ( ( list @ A ) > ( list @ A ) > $o )
@ ^ [P6: ( list @ A ) > ( list @ A ) > $o,X16: list @ A,X24: list @ A] :
( ? [Y2: A,Ys3: list @ A] :
( ( X16
= ( nil @ A ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( X16
= ( cons @ A @ X2 @ Xs2 ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) )
& ( Less2 @ X2 @ Y2 ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( X16
= ( cons @ A @ X2 @ Xs2 ) )
& ( X24
= ( cons @ A @ Y2 @ Ys3 ) )
& ~ ( Less2 @ X2 @ Y2 )
& ~ ( Less2 @ Y2 @ X2 )
& ( P6 @ Xs2 @ Ys3 ) ) ) ) ) ) ).
% ord.lexordp_def
thf(fact_7237_ord_Olexordp__simps_I3_J,axiom,
! [A: $tType,Less: A > A > $o,X: A,Xs: list @ A,Y: A,Ys: list @ A] :
( ( lexordp2 @ A @ Less @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) )
= ( ( Less @ X @ Y )
| ( ~ ( Less @ Y @ X )
& ( lexordp2 @ A @ Less @ Xs @ Ys ) ) ) ) ).
% ord.lexordp_simps(3)
thf(fact_7238_ord_Olexordp__simps_I1_J,axiom,
! [A: $tType,Less: A > A > $o,Ys: list @ A] :
( ( lexordp2 @ A @ Less @ ( nil @ A ) @ Ys )
= ( Ys
!= ( nil @ A ) ) ) ).
% ord.lexordp_simps(1)
thf(fact_7239_ord_Olexordp__simps_I2_J,axiom,
! [A: $tType,Less: A > A > $o,Xs: list @ A] :
~ ( lexordp2 @ A @ Less @ Xs @ ( nil @ A ) ) ).
% ord.lexordp_simps(2)
thf(fact_7240_ord_Olexordp_ONil,axiom,
! [A: $tType,Less: A > A > $o,Y: A,Ys: list @ A] : ( lexordp2 @ A @ Less @ ( nil @ A ) @ ( cons @ A @ Y @ Ys ) ) ).
% ord.lexordp.Nil
thf(fact_7241_ord_Olexordp_Ocases,axiom,
! [A: $tType,Less: A > A > $o,A12: list @ A,A23: list @ A] :
( ( lexordp2 @ A @ Less @ A12 @ A23 )
=> ( ( ( A12
= ( nil @ A ) )
=> ! [Y4: A,Ys4: list @ A] :
( A23
!= ( cons @ A @ Y4 @ Ys4 ) ) )
=> ( ! [X5: A] :
( ? [Xs3: list @ A] :
( A12
= ( cons @ A @ X5 @ Xs3 ) )
=> ! [Y4: A] :
( ? [Ys4: list @ A] :
( A23
= ( cons @ A @ Y4 @ Ys4 ) )
=> ~ ( Less @ X5 @ Y4 ) ) )
=> ~ ! [X5: A,Y4: A,Xs3: list @ A] :
( ( A12
= ( cons @ A @ X5 @ Xs3 ) )
=> ! [Ys4: list @ A] :
( ( A23
= ( cons @ A @ Y4 @ Ys4 ) )
=> ( ~ ( Less @ X5 @ Y4 )
=> ( ~ ( Less @ Y4 @ X5 )
=> ~ ( lexordp2 @ A @ Less @ Xs3 @ Ys4 ) ) ) ) ) ) ) ) ).
% ord.lexordp.cases
thf(fact_7242_ord_Olexordp_Osimps,axiom,
! [A: $tType] :
( ( lexordp2 @ A )
= ( ^ [Less2: A > A > $o,A1: list @ A,A22: list @ A] :
( ? [Y2: A,Ys3: list @ A] :
( ( A1
= ( nil @ A ) )
& ( A22
= ( cons @ A @ Y2 @ Ys3 ) ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( A1
= ( cons @ A @ X2 @ Xs2 ) )
& ( A22
= ( cons @ A @ Y2 @ Ys3 ) )
& ( Less2 @ X2 @ Y2 ) )
| ? [X2: A,Y2: A,Xs2: list @ A,Ys3: list @ A] :
( ( A1
= ( cons @ A @ X2 @ Xs2 ) )
& ( A22
= ( cons @ A @ Y2 @ Ys3 ) )
& ~ ( Less2 @ X2 @ Y2 )
& ~ ( Less2 @ Y2 @ X2 )
& ( lexordp2 @ A @ Less2 @ Xs2 @ Ys3 ) ) ) ) ) ).
% ord.lexordp.simps
thf(fact_7243_ord_Olexordp_OCons,axiom,
! [A: $tType,Less: A > A > $o,X: A,Y: A,Xs: list @ A,Ys: list @ A] :
( ( Less @ X @ Y )
=> ( lexordp2 @ A @ Less @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) ) ) ).
% ord.lexordp.Cons
thf(fact_7244_ord_Olexordp_OCons__eq,axiom,
! [A: $tType,Less: A > A > $o,X: A,Y: A,Xs: list @ A,Ys: list @ A] :
( ~ ( Less @ X @ Y )
=> ( ~ ( Less @ Y @ X )
=> ( ( lexordp2 @ A @ Less @ Xs @ Ys )
=> ( lexordp2 @ A @ Less @ ( cons @ A @ X @ Xs ) @ ( cons @ A @ Y @ Ys ) ) ) ) ) ).
% ord.lexordp.Cons_eq
thf(fact_7245_ord_Olexordp_Ocong,axiom,
! [A: $tType] :
( ( lexordp2 @ A )
= ( lexordp2 @ A ) ) ).
% ord.lexordp.cong
thf(fact_7246_ord_Olexordp__irreflexive,axiom,
! [A: $tType,Less: A > A > $o,Xs: list @ A] :
( ! [X5: A] :
~ ( Less @ X5 @ X5 )
=> ~ ( lexordp2 @ A @ Less @ Xs @ Xs ) ) ).
% ord.lexordp_irreflexive
thf(fact_7247_ord_Olexordp__append__leftI,axiom,
! [A: $tType,Less: A > A > $o,Us: list @ A,Vs2: list @ A,Xs: list @ A] :
( ( lexordp2 @ A @ Less @ Us @ Vs2 )
=> ( lexordp2 @ A @ Less @ ( append @ A @ Xs @ Us ) @ ( append @ A @ Xs @ Vs2 ) ) ) ).
% ord.lexordp_append_leftI
thf(fact_7248_ord_Olexordp__append__leftD,axiom,
! [A: $tType,Less: A > A > $o,Xs: list @ A,Us: list @ A,Vs2: list @ A] :
( ( lexordp2 @ A @ Less @ ( append @ A @ Xs @ Us ) @ ( append @ A @ Xs @ Vs2 ) )
=> ( ! [A7: A] :
~ ( Less @ A7 @ A7 )
=> ( lexordp2 @ A @ Less @ Us @ Vs2 ) ) ) ).
% ord.lexordp_append_leftD
thf(fact_7249_ord_Olexordp__append__left__rightI,axiom,
! [A: $tType,Less: A > A > $o,X: A,Y: A,Us: list @ A,Xs: list @ A,Ys: list @ A] :
( ( Less @ X @ Y )
=> ( lexordp2 @ A @ Less @ ( append @ A @ Us @ ( cons @ A @ X @ Xs ) ) @ ( append @ A @ Us @ ( cons @ A @ Y @ Ys ) ) ) ) ).
% ord.lexordp_append_left_rightI
thf(fact_7250_ord_Olexordp__append__rightI,axiom,
! [A: $tType,Ys: list @ A,Less: A > A > $o,Xs: list @ A] :
( ( Ys
!= ( nil @ A ) )
=> ( lexordp2 @ A @ Less @ Xs @ ( append @ A @ Xs @ Ys ) ) ) ).
% ord.lexordp_append_rightI
thf(fact_7251_preorder__on__empty,axiom,
! [A: $tType] : ( order_preorder_on @ A @ ( bot_bot @ ( set @ A ) ) @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ).
% preorder_on_empty
thf(fact_7252_subset__Image__Image__iff,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A,B3: set @ A] :
( ( order_preorder_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( field2 @ A @ R2 ) )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( field2 @ A @ R2 ) )
=> ( ( ord_less_eq @ ( set @ A ) @ ( image @ A @ A @ R2 @ A4 ) @ ( image @ A @ A @ R2 @ B3 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ? [Y2: A] :
( ( member2 @ A @ Y2 @ B3 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y2 @ X2 ) @ R2 ) ) ) ) ) ) ) ) ).
% subset_Image_Image_iff
thf(fact_7253_Refl__antisym__eq__Image1__Image1__iff,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( refl_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( antisym @ A @ R2 )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ B2 @ ( field2 @ A @ R2 ) )
=> ( ( ( image @ A @ A @ R2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) )
= ( image @ A @ A @ R2 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( A3 = B2 ) ) ) ) ) ) ).
% Refl_antisym_eq_Image1_Image1_iff
thf(fact_7254_finite__enumerate__initial__segment,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A,N2: nat,S: A] :
( ( finite_finite @ A @ S3 )
=> ( ( ord_less @ nat @ N2 @ ( finite_card @ A @ ( inf_inf @ ( set @ A ) @ S3 @ ( set_ord_lessThan @ A @ S ) ) ) )
=> ( ( infini527867602293511546merate @ A @ ( inf_inf @ ( set @ A ) @ S3 @ ( set_ord_lessThan @ A @ S ) ) @ N2 )
= ( infini527867602293511546merate @ A @ S3 @ N2 ) ) ) ) ) ).
% finite_enumerate_initial_segment
thf(fact_7255_enumerate__mono__iff,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A,M: nat,N2: nat] :
( ~ ( finite_finite @ A @ S3 )
=> ( ( ord_less @ A @ ( infini527867602293511546merate @ A @ S3 @ M ) @ ( infini527867602293511546merate @ A @ S3 @ N2 ) )
= ( ord_less @ nat @ M @ N2 ) ) ) ) ).
% enumerate_mono_iff
thf(fact_7256_finite__enumerate__mono__iff,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A,M: nat,N2: nat] :
( ( finite_finite @ A @ S3 )
=> ( ( ord_less @ nat @ M @ ( finite_card @ A @ S3 ) )
=> ( ( ord_less @ nat @ N2 @ ( finite_card @ A @ S3 ) )
=> ( ( ord_less @ A @ ( infini527867602293511546merate @ A @ S3 @ M ) @ ( infini527867602293511546merate @ A @ S3 @ N2 ) )
= ( ord_less @ nat @ M @ N2 ) ) ) ) ) ) ).
% finite_enumerate_mono_iff
thf(fact_7257_antisym__empty,axiom,
! [A: $tType] : ( antisym @ A @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ).
% antisym_empty
thf(fact_7258_antisym__def,axiom,
! [A: $tType] :
( ( antisym @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
! [X2: A,Y2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R4 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y2 @ X2 ) @ R4 )
=> ( X2 = Y2 ) ) ) ) ) ).
% antisym_def
thf(fact_7259_antisymI,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ! [X5: A,Y4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Y4 ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ X5 ) @ R2 )
=> ( X5 = Y4 ) ) )
=> ( antisym @ A @ R2 ) ) ).
% antisymI
thf(fact_7260_antisymD,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( antisym @ A @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ A3 ) @ R2 )
=> ( A3 = B2 ) ) ) ) ).
% antisymD
thf(fact_7261_le__enumerate,axiom,
! [S3: set @ nat,N2: nat] :
( ~ ( finite_finite @ nat @ S3 )
=> ( ord_less_eq @ nat @ N2 @ ( infini527867602293511546merate @ nat @ S3 @ N2 ) ) ) ).
% le_enumerate
thf(fact_7262_antisym__singleton,axiom,
! [A: $tType,X: product_prod @ A @ A] : ( antisym @ A @ ( insert2 @ ( product_prod @ A @ A ) @ X @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ) ).
% antisym_singleton
thf(fact_7263_enumerate__step,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A,N2: nat] :
( ~ ( finite_finite @ A @ S3 )
=> ( ord_less @ A @ ( infini527867602293511546merate @ A @ S3 @ N2 ) @ ( infini527867602293511546merate @ A @ S3 @ ( suc @ N2 ) ) ) ) ) ).
% enumerate_step
thf(fact_7264_enumerate__mono,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [M: nat,N2: nat,S3: set @ A] :
( ( ord_less @ nat @ M @ N2 )
=> ( ~ ( finite_finite @ A @ S3 )
=> ( ord_less @ A @ ( infini527867602293511546merate @ A @ S3 @ M ) @ ( infini527867602293511546merate @ A @ S3 @ N2 ) ) ) ) ) ).
% enumerate_mono
thf(fact_7265_finite__enum__ext,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [X7: set @ A,Y6: set @ A] :
( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( finite_card @ A @ X7 ) )
=> ( ( infini527867602293511546merate @ A @ X7 @ I3 )
= ( infini527867602293511546merate @ A @ Y6 @ I3 ) ) )
=> ( ( finite_finite @ A @ X7 )
=> ( ( finite_finite @ A @ Y6 )
=> ( ( ( finite_card @ A @ X7 )
= ( finite_card @ A @ Y6 ) )
=> ( X7 = Y6 ) ) ) ) ) ) ).
% finite_enum_ext
thf(fact_7266_finite__enumerate__Ex,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A,S: A] :
( ( finite_finite @ A @ S3 )
=> ( ( member2 @ A @ S @ S3 )
=> ? [N3: nat] :
( ( ord_less @ nat @ N3 @ ( finite_card @ A @ S3 ) )
& ( ( infini527867602293511546merate @ A @ S3 @ N3 )
= S ) ) ) ) ) ).
% finite_enumerate_Ex
thf(fact_7267_finite__enumerate__in__set,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A,N2: nat] :
( ( finite_finite @ A @ S3 )
=> ( ( ord_less @ nat @ N2 @ ( finite_card @ A @ S3 ) )
=> ( member2 @ A @ ( infini527867602293511546merate @ A @ S3 @ N2 ) @ S3 ) ) ) ) ).
% finite_enumerate_in_set
thf(fact_7268_finite__enumerate__mono,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [M: nat,N2: nat,S3: set @ A] :
( ( ord_less @ nat @ M @ N2 )
=> ( ( finite_finite @ A @ S3 )
=> ( ( ord_less @ nat @ N2 @ ( finite_card @ A @ S3 ) )
=> ( ord_less @ A @ ( infini527867602293511546merate @ A @ S3 @ M ) @ ( infini527867602293511546merate @ A @ S3 @ N2 ) ) ) ) ) ) ).
% finite_enumerate_mono
thf(fact_7269_finite__le__enumerate,axiom,
! [S3: set @ nat,N2: nat] :
( ( finite_finite @ nat @ S3 )
=> ( ( ord_less @ nat @ N2 @ ( finite_card @ nat @ S3 ) )
=> ( ord_less_eq @ nat @ N2 @ ( infini527867602293511546merate @ nat @ S3 @ N2 ) ) ) ) ).
% finite_le_enumerate
thf(fact_7270_finite__enumerate__step,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A,N2: nat] :
( ( finite_finite @ A @ S3 )
=> ( ( ord_less @ nat @ ( suc @ N2 ) @ ( finite_card @ A @ S3 ) )
=> ( ord_less @ A @ ( infini527867602293511546merate @ A @ S3 @ N2 ) @ ( infini527867602293511546merate @ A @ S3 @ ( suc @ N2 ) ) ) ) ) ) ).
% finite_enumerate_step
thf(fact_7271_enumerate__Suc_H,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A,N2: nat] :
( ( infini527867602293511546merate @ A @ S3 @ ( suc @ N2 ) )
= ( infini527867602293511546merate @ A @ ( minus_minus @ ( set @ A ) @ S3 @ ( insert2 @ A @ ( infini527867602293511546merate @ A @ S3 @ ( zero_zero @ nat ) ) @ ( bot_bot @ ( set @ A ) ) ) ) @ N2 ) ) ) ).
% enumerate_Suc'
thf(fact_7272_finite__enum__subset,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [X7: set @ A,Y6: set @ A] :
( ! [I3: nat] :
( ( ord_less @ nat @ I3 @ ( finite_card @ A @ X7 ) )
=> ( ( infini527867602293511546merate @ A @ X7 @ I3 )
= ( infini527867602293511546merate @ A @ Y6 @ I3 ) ) )
=> ( ( finite_finite @ A @ X7 )
=> ( ( finite_finite @ A @ Y6 )
=> ( ( ord_less_eq @ nat @ ( finite_card @ A @ X7 ) @ ( finite_card @ A @ Y6 ) )
=> ( ord_less_eq @ ( set @ A ) @ X7 @ Y6 ) ) ) ) ) ) ).
% finite_enum_subset
thf(fact_7273_finite__enumerate__Suc_H_H,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A,N2: nat] :
( ( finite_finite @ A @ S3 )
=> ( ( ord_less @ nat @ ( suc @ N2 ) @ ( finite_card @ A @ S3 ) )
=> ( ( infini527867602293511546merate @ A @ S3 @ ( suc @ N2 ) )
= ( ord_Least @ A
@ ^ [S7: A] :
( ( member2 @ A @ S7 @ S3 )
& ( ord_less @ A @ ( infini527867602293511546merate @ A @ S3 @ N2 ) @ S7 ) ) ) ) ) ) ) ).
% finite_enumerate_Suc''
thf(fact_7274_enumerate__Suc,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A,N2: nat] :
( ( infini527867602293511546merate @ A @ S3 @ ( suc @ N2 ) )
= ( infini527867602293511546merate @ A
@ ( minus_minus @ ( set @ A ) @ S3
@ ( insert2 @ A
@ ( ord_Least @ A
@ ^ [N: A] : ( member2 @ A @ N @ S3 ) )
@ ( bot_bot @ ( set @ A ) ) ) )
@ N2 ) ) ) ).
% enumerate_Suc
thf(fact_7275_Least__eq__0,axiom,
! [P2: nat > $o] :
( ( P2 @ ( zero_zero @ nat ) )
=> ( ( ord_Least @ nat @ P2 )
= ( zero_zero @ nat ) ) ) ).
% Least_eq_0
thf(fact_7276_Least__Suc,axiom,
! [P2: nat > $o,N2: nat] :
( ( P2 @ N2 )
=> ( ~ ( P2 @ ( zero_zero @ nat ) )
=> ( ( ord_Least @ nat @ P2 )
= ( suc
@ ( ord_Least @ nat
@ ^ [M2: nat] : ( P2 @ ( suc @ M2 ) ) ) ) ) ) ) ).
% Least_Suc
thf(fact_7277_Least__le,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [P2: A > $o,K: A] :
( ( P2 @ K )
=> ( ord_less_eq @ A @ ( ord_Least @ A @ P2 ) @ K ) ) ) ).
% Least_le
thf(fact_7278_Least1I,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [P2: A > $o] :
( ? [X3: A] :
( ( P2 @ X3 )
& ! [Y4: A] :
( ( P2 @ Y4 )
=> ( ord_less_eq @ A @ X3 @ Y4 ) )
& ! [Y4: A] :
( ( ( P2 @ Y4 )
& ! [Ya2: A] :
( ( P2 @ Ya2 )
=> ( ord_less_eq @ A @ Y4 @ Ya2 ) ) )
=> ( Y4 = X3 ) ) )
=> ( P2 @ ( ord_Least @ A @ P2 ) ) ) ) ).
% Least1I
thf(fact_7279_Least1__le,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [P2: A > $o,Z: A] :
( ? [X3: A] :
( ( P2 @ X3 )
& ! [Y4: A] :
( ( P2 @ Y4 )
=> ( ord_less_eq @ A @ X3 @ Y4 ) )
& ! [Y4: A] :
( ( ( P2 @ Y4 )
& ! [Ya2: A] :
( ( P2 @ Ya2 )
=> ( ord_less_eq @ A @ Y4 @ Ya2 ) ) )
=> ( Y4 = X3 ) ) )
=> ( ( P2 @ Z )
=> ( ord_less_eq @ A @ ( ord_Least @ A @ P2 ) @ Z ) ) ) ) ).
% Least1_le
thf(fact_7280_LeastI2__order,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [P2: A > $o,X: A,Q: A > $o] :
( ( P2 @ X )
=> ( ! [Y4: A] :
( ( P2 @ Y4 )
=> ( ord_less_eq @ A @ X @ Y4 ) )
=> ( ! [X5: A] :
( ( P2 @ X5 )
=> ( ! [Y3: A] :
( ( P2 @ Y3 )
=> ( ord_less_eq @ A @ X5 @ Y3 ) )
=> ( Q @ X5 ) ) )
=> ( Q @ ( ord_Least @ A @ P2 ) ) ) ) ) ) ).
% LeastI2_order
thf(fact_7281_Least__equality,axiom,
! [A: $tType] :
( ( order @ A )
=> ! [P2: A > $o,X: A] :
( ( P2 @ X )
=> ( ! [Y4: A] :
( ( P2 @ Y4 )
=> ( ord_less_eq @ A @ X @ Y4 ) )
=> ( ( ord_Least @ A @ P2 )
= X ) ) ) ) ).
% Least_equality
thf(fact_7282_LeastI2__wellorder,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [P2: A > $o,A3: A,Q: A > $o] :
( ( P2 @ A3 )
=> ( ! [A7: A] :
( ( P2 @ A7 )
=> ( ! [B9: A] :
( ( P2 @ B9 )
=> ( ord_less_eq @ A @ A7 @ B9 ) )
=> ( Q @ A7 ) ) )
=> ( Q @ ( ord_Least @ A @ P2 ) ) ) ) ) ).
% LeastI2_wellorder
thf(fact_7283_LeastI2__wellorder__ex,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [P2: A > $o,Q: A > $o] :
( ? [X_1: A] : ( P2 @ X_1 )
=> ( ! [A7: A] :
( ( P2 @ A7 )
=> ( ! [B9: A] :
( ( P2 @ B9 )
=> ( ord_less_eq @ A @ A7 @ B9 ) )
=> ( Q @ A7 ) ) )
=> ( Q @ ( ord_Least @ A @ P2 ) ) ) ) ) ).
% LeastI2_wellorder_ex
thf(fact_7284_Least__Suc2,axiom,
! [P2: nat > $o,N2: nat,Q: nat > $o,M: nat] :
( ( P2 @ N2 )
=> ( ( Q @ M )
=> ( ~ ( P2 @ ( zero_zero @ nat ) )
=> ( ! [K3: nat] :
( ( P2 @ ( suc @ K3 ) )
= ( Q @ K3 ) )
=> ( ( ord_Least @ nat @ P2 )
= ( suc @ ( ord_Least @ nat @ Q ) ) ) ) ) ) ) ).
% Least_Suc2
thf(fact_7285_not__less__Least,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [K: A,P2: A > $o] :
( ( ord_less @ A @ K @ ( ord_Least @ A @ P2 ) )
=> ~ ( P2 @ K ) ) ) ).
% not_less_Least
thf(fact_7286_Least__Min,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [P2: A > $o] :
( ( finite_finite @ A @ ( collect @ A @ P2 ) )
=> ( ? [X_1: A] : ( P2 @ X_1 )
=> ( ( ord_Least @ A @ P2 )
= ( lattic643756798350308766er_Min @ A @ ( collect @ A @ P2 ) ) ) ) ) ) ).
% Least_Min
thf(fact_7287_Bleast__def,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( bleast @ A )
= ( ^ [S8: set @ A,P: A > $o] :
( ord_Least @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ S8 )
& ( P @ X2 ) ) ) ) ) ) ).
% Bleast_def
thf(fact_7288_abort__Bleast__def,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( abort_Bleast @ A )
= ( ^ [S8: set @ A,P: A > $o] :
( ord_Least @ A
@ ^ [X2: A] :
( ( member2 @ A @ X2 @ S8 )
& ( P @ X2 ) ) ) ) ) ) ).
% abort_Bleast_def
thf(fact_7289_enumerate__0,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A] :
( ( infini527867602293511546merate @ A @ S3 @ ( zero_zero @ nat ) )
= ( ord_Least @ A
@ ^ [N: A] : ( member2 @ A @ N @ S3 ) ) ) ) ).
% enumerate_0
thf(fact_7290_Least__mono,axiom,
! [B: $tType,A: $tType] :
( ( ( order @ A )
& ( order @ B ) )
=> ! [F2: A > B,S3: set @ A] :
( ( order_mono @ A @ B @ F2 )
=> ( ? [X3: A] :
( ( member2 @ A @ X3 @ S3 )
& ! [Xa4: A] :
( ( member2 @ A @ Xa4 @ S3 )
=> ( ord_less_eq @ A @ X3 @ Xa4 ) ) )
=> ( ( ord_Least @ B
@ ^ [Y2: B] : ( member2 @ B @ Y2 @ ( image2 @ A @ B @ F2 @ S3 ) ) )
= ( F2
@ ( ord_Least @ A
@ ^ [X2: A] : ( member2 @ A @ X2 @ S3 ) ) ) ) ) ) ) ).
% Least_mono
thf(fact_7291_Least__def,axiom,
! [A: $tType] :
( ( ord @ A )
=> ( ( ord_Least @ A )
= ( ^ [P: A > $o] :
( the @ A
@ ^ [X2: A] :
( ( P @ X2 )
& ! [Y2: A] :
( ( P @ Y2 )
=> ( ord_less_eq @ A @ X2 @ Y2 ) ) ) ) ) ) ) ).
% Least_def
thf(fact_7292_enumerate__Suc_H_H,axiom,
! [A: $tType] :
( ( wellorder @ A )
=> ! [S3: set @ A,N2: nat] :
( ~ ( finite_finite @ A @ S3 )
=> ( ( infini527867602293511546merate @ A @ S3 @ ( suc @ N2 ) )
= ( ord_Least @ A
@ ^ [S7: A] :
( ( member2 @ A @ S7 @ S3 )
& ( ord_less @ A @ ( infini527867602293511546merate @ A @ S3 @ N2 ) @ S7 ) ) ) ) ) ) ).
% enumerate_Suc''
thf(fact_7293_fold__atLeastAtMost__nat_Opelims,axiom,
! [A: $tType,X: nat > A > A,Xa2: nat,Xb: nat,Xc: A,Y: A] :
( ( ( set_fo6178422350223883121st_nat @ A @ X @ Xa2 @ Xb @ Xc )
= Y )
=> ( ( accp @ ( product_prod @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) ) @ ( set_fo1817059534552279752at_rel @ A ) @ ( product_Pair @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) @ X @ ( product_Pair @ nat @ ( product_prod @ nat @ A ) @ Xa2 @ ( product_Pair @ nat @ A @ Xb @ Xc ) ) ) )
=> ~ ( ( ( ( ord_less @ nat @ Xb @ Xa2 )
=> ( Y = Xc ) )
& ( ~ ( ord_less @ nat @ Xb @ Xa2 )
=> ( Y
= ( set_fo6178422350223883121st_nat @ A @ X @ ( plus_plus @ nat @ Xa2 @ ( one_one @ nat ) ) @ Xb @ ( X @ Xa2 @ Xc ) ) ) ) )
=> ~ ( accp @ ( product_prod @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) ) @ ( set_fo1817059534552279752at_rel @ A ) @ ( product_Pair @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) @ X @ ( product_Pair @ nat @ ( product_prod @ nat @ A ) @ Xa2 @ ( product_Pair @ nat @ A @ Xb @ Xc ) ) ) ) ) ) ) ).
% fold_atLeastAtMost_nat.pelims
thf(fact_7294_fold__atLeastAtMost__nat_Opsimps,axiom,
! [A: $tType,F2: nat > A > A,A3: nat,B2: nat,Acc3: A] :
( ( accp @ ( product_prod @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) ) @ ( set_fo1817059534552279752at_rel @ A ) @ ( product_Pair @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) @ F2 @ ( product_Pair @ nat @ ( product_prod @ nat @ A ) @ A3 @ ( product_Pair @ nat @ A @ B2 @ Acc3 ) ) ) )
=> ( ( ( ord_less @ nat @ B2 @ A3 )
=> ( ( set_fo6178422350223883121st_nat @ A @ F2 @ A3 @ B2 @ Acc3 )
= Acc3 ) )
& ( ~ ( ord_less @ nat @ B2 @ A3 )
=> ( ( set_fo6178422350223883121st_nat @ A @ F2 @ A3 @ B2 @ Acc3 )
= ( set_fo6178422350223883121st_nat @ A @ F2 @ ( plus_plus @ nat @ A3 @ ( one_one @ nat ) ) @ B2 @ ( F2 @ A3 @ Acc3 ) ) ) ) ) ) ).
% fold_atLeastAtMost_nat.psimps
thf(fact_7295_fold__atLeastAtMost__nat_Opinduct,axiom,
! [A: $tType,A0: nat > A > A,A12: nat,A23: nat,A32: A,P2: ( nat > A > A ) > nat > nat > A > $o] :
( ( accp @ ( product_prod @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) ) @ ( set_fo1817059534552279752at_rel @ A ) @ ( product_Pair @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) @ A0 @ ( product_Pair @ nat @ ( product_prod @ nat @ A ) @ A12 @ ( product_Pair @ nat @ A @ A23 @ A32 ) ) ) )
=> ( ! [F4: nat > A > A,A7: nat,B5: nat,Acc: A] :
( ( accp @ ( product_prod @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) ) @ ( set_fo1817059534552279752at_rel @ A ) @ ( product_Pair @ ( nat > A > A ) @ ( product_prod @ nat @ ( product_prod @ nat @ A ) ) @ F4 @ ( product_Pair @ nat @ ( product_prod @ nat @ A ) @ A7 @ ( product_Pair @ nat @ A @ B5 @ Acc ) ) ) )
=> ( ( ~ ( ord_less @ nat @ B5 @ A7 )
=> ( P2 @ F4 @ ( plus_plus @ nat @ A7 @ ( one_one @ nat ) ) @ B5 @ ( F4 @ A7 @ Acc ) ) )
=> ( P2 @ F4 @ A7 @ B5 @ Acc ) ) )
=> ( P2 @ A0 @ A12 @ A23 @ A32 ) ) ) ).
% fold_atLeastAtMost_nat.pinduct
thf(fact_7296_lexn_Osimps_I2_J,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),N2: nat] :
( ( lexn @ A @ R2 @ ( suc @ N2 ) )
= ( inf_inf @ ( set @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) ) @ ( image2 @ ( product_prod @ ( product_prod @ A @ ( list @ A ) ) @ ( product_prod @ A @ ( list @ A ) ) ) @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_map_prod @ ( product_prod @ A @ ( list @ A ) ) @ ( list @ A ) @ ( product_prod @ A @ ( list @ A ) ) @ ( list @ A ) @ ( product_case_prod @ A @ ( list @ A ) @ ( list @ A ) @ ( cons @ A ) ) @ ( product_case_prod @ A @ ( list @ A ) @ ( list @ A ) @ ( cons @ A ) ) ) @ ( lex_prod @ A @ ( list @ A ) @ R2 @ ( lexn @ A @ R2 @ N2 ) ) )
@ ( collect @ ( product_prod @ ( list @ A ) @ ( list @ A ) )
@ ( product_case_prod @ ( list @ A ) @ ( list @ A ) @ $o
@ ^ [Xs2: list @ A,Ys3: list @ A] :
( ( ( size_size @ ( list @ A ) @ Xs2 )
= ( suc @ N2 ) )
& ( ( size_size @ ( list @ A ) @ Ys3 )
= ( suc @ N2 ) ) ) ) ) ) ) ).
% lexn.simps(2)
thf(fact_7297_stable__sort__key__def,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ( ( linord3483353639454293061rt_key @ B @ A )
= ( ^ [Sk: ( B > A ) > ( list @ B ) > ( list @ B )] :
! [F3: B > A,Xs2: list @ B,K2: A] :
( ( filter2 @ B
@ ^ [Y2: B] :
( ( F3 @ Y2 )
= K2 )
@ ( Sk @ F3 @ Xs2 ) )
= ( filter2 @ B
@ ^ [Y2: B] :
( ( F3 @ Y2 )
= K2 )
@ Xs2 ) ) ) ) ) ).
% stable_sort_key_def
thf(fact_7298_map__prod__simp,axiom,
! [C: $tType,A: $tType,B: $tType,D: $tType,F2: C > A,G: D > B,A3: C,B2: D] :
( ( product_map_prod @ C @ A @ D @ B @ F2 @ G @ ( product_Pair @ C @ D @ A3 @ B2 ) )
= ( product_Pair @ A @ B @ ( F2 @ A3 ) @ ( G @ B2 ) ) ) ).
% map_prod_simp
thf(fact_7299_map__prod__imageI,axiom,
! [D: $tType,C: $tType,B: $tType,A: $tType,A3: A,B2: B,R: set @ ( product_prod @ A @ B ),F2: A > C,G: B > D] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ R )
=> ( member2 @ ( product_prod @ C @ D ) @ ( product_Pair @ C @ D @ ( F2 @ A3 ) @ ( G @ B2 ) ) @ ( image2 @ ( product_prod @ A @ B ) @ ( product_prod @ C @ D ) @ ( product_map_prod @ A @ C @ B @ D @ F2 @ G ) @ R ) ) ) ).
% map_prod_imageI
thf(fact_7300_map__prod__def,axiom,
! [B: $tType,D: $tType,C: $tType,A: $tType] :
( ( product_map_prod @ A @ C @ B @ D )
= ( ^ [F3: A > C,G2: B > D] :
( product_case_prod @ A @ B @ ( product_prod @ C @ D )
@ ^ [X2: A,Y2: B] : ( product_Pair @ C @ D @ ( F3 @ X2 ) @ ( G2 @ Y2 ) ) ) ) ) ).
% map_prod_def
thf(fact_7301_prod__fun__imageE,axiom,
! [B: $tType,A: $tType,D: $tType,C: $tType,C2: product_prod @ A @ B,F2: C > A,G: D > B,R: set @ ( product_prod @ C @ D )] :
( ( member2 @ ( product_prod @ A @ B ) @ C2 @ ( image2 @ ( product_prod @ C @ D ) @ ( product_prod @ A @ B ) @ ( product_map_prod @ C @ A @ D @ B @ F2 @ G ) @ R ) )
=> ~ ! [X5: C,Y4: D] :
( ( C2
= ( product_Pair @ A @ B @ ( F2 @ X5 ) @ ( G @ Y4 ) ) )
=> ~ ( member2 @ ( product_prod @ C @ D ) @ ( product_Pair @ C @ D @ X5 @ Y4 ) @ R ) ) ) ).
% prod_fun_imageE
thf(fact_7302_stable__sort__key__sort__key,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ( linord3483353639454293061rt_key @ A @ B @ ( linorder_sort_key @ A @ B ) ) ) ).
% stable_sort_key_sort_key
thf(fact_7303_tendsto__iff__uniformity,axiom,
! [A: $tType,B: $tType] :
( ( topolo7287701948861334536_space @ B )
=> ! [F2: A > B,L: B,F5: filter @ A] :
( ( filterlim @ A @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ L ) @ F5 )
= ( ! [E6: ( product_prod @ B @ B ) > $o] :
( ( eventually @ ( product_prod @ B @ B ) @ E6 @ ( topolo7806501430040627800ormity @ B ) )
=> ( eventually @ A
@ ^ [X2: A] : ( E6 @ ( product_Pair @ B @ B @ ( F2 @ X2 ) @ L ) )
@ F5 ) ) ) ) ) ).
% tendsto_iff_uniformity
thf(fact_7304_independentD,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S: set @ A,T2: set @ A,U: A > real,V2: A] :
( ~ ( real_V358717886546972837endent @ A @ S )
=> ( ( finite_finite @ A @ T2 )
=> ( ( ord_less_eq @ ( set @ A ) @ T2 @ S )
=> ( ( ( groups7311177749621191930dd_sum @ A @ A
@ ^ [V5: A] : ( real_V8093663219630862766scaleR @ A @ ( U @ V5 ) @ V5 )
@ T2 )
= ( zero_zero @ A ) )
=> ( ( member2 @ A @ V2 @ T2 )
=> ( ( U @ V2 )
= ( zero_zero @ real ) ) ) ) ) ) ) ) ).
% independentD
thf(fact_7305_independent__empty,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ~ ( real_V358717886546972837endent @ A @ ( bot_bot @ ( set @ A ) ) ) ) ).
% independent_empty
thf(fact_7306_dependent__single,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: A] :
( ( real_V358717886546972837endent @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( X
= ( zero_zero @ A ) ) ) ) ).
% dependent_single
thf(fact_7307_dependent__zero,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A4: set @ A] :
( ( member2 @ A @ ( zero_zero @ A ) @ A4 )
=> ( real_V358717886546972837endent @ A @ A4 ) ) ) ).
% dependent_zero
thf(fact_7308_uniformity__bot,axiom,
! [A: $tType] :
( ( topolo7287701948861334536_space @ A )
=> ( ( topolo7806501430040627800ormity @ A )
!= ( bot_bot @ ( filter @ ( product_prod @ A @ A ) ) ) ) ) ).
% uniformity_bot
thf(fact_7309_uniformity__transE,axiom,
! [A: $tType] :
( ( topolo7287701948861334536_space @ A )
=> ! [E5: ( product_prod @ A @ A ) > $o] :
( ( eventually @ ( product_prod @ A @ A ) @ E5 @ ( topolo7806501430040627800ormity @ A ) )
=> ~ ! [D8: ( product_prod @ A @ A ) > $o] :
( ( eventually @ ( product_prod @ A @ A ) @ D8 @ ( topolo7806501430040627800ormity @ A ) )
=> ~ ! [X3: A,Y3: A] :
( ( D8 @ ( product_Pair @ A @ A @ X3 @ Y3 ) )
=> ! [Z4: A] :
( ( D8 @ ( product_Pair @ A @ A @ Y3 @ Z4 ) )
=> ( E5 @ ( product_Pair @ A @ A @ X3 @ Z4 ) ) ) ) ) ) ) ).
% uniformity_transE
thf(fact_7310_uniformity__trans,axiom,
! [A: $tType] :
( ( topolo7287701948861334536_space @ A )
=> ! [E5: ( product_prod @ A @ A ) > $o] :
( ( eventually @ ( product_prod @ A @ A ) @ E5 @ ( topolo7806501430040627800ormity @ A ) )
=> ? [D8: ( product_prod @ A @ A ) > $o] :
( ( eventually @ ( product_prod @ A @ A ) @ D8 @ ( topolo7806501430040627800ormity @ A ) )
& ! [X3: A,Y3: A,Z4: A] :
( ( D8 @ ( product_Pair @ A @ A @ X3 @ Y3 ) )
=> ( ( D8 @ ( product_Pair @ A @ A @ Y3 @ Z4 ) )
=> ( E5 @ ( product_Pair @ A @ A @ X3 @ Z4 ) ) ) ) ) ) ) ).
% uniformity_trans
thf(fact_7311_uniformity__refl,axiom,
! [A: $tType] :
( ( topolo7287701948861334536_space @ A )
=> ! [E5: ( product_prod @ A @ A ) > $o,X: A] :
( ( eventually @ ( product_prod @ A @ A ) @ E5 @ ( topolo7806501430040627800ormity @ A ) )
=> ( E5 @ ( product_Pair @ A @ A @ X @ X ) ) ) ) ).
% uniformity_refl
thf(fact_7312_dependent__mono,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ( real_V358717886546972837endent @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( real_V358717886546972837endent @ A @ A4 ) ) ) ) ).
% dependent_mono
thf(fact_7313_independent__mono,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ~ ( real_V358717886546972837endent @ A @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ~ ( real_V358717886546972837endent @ A @ B3 ) ) ) ) ).
% independent_mono
thf(fact_7314_independent__Union__directed,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [C5: set @ ( set @ A )] :
( ! [C4: set @ A,D3: set @ A] :
( ( member2 @ ( set @ A ) @ C4 @ C5 )
=> ( ( member2 @ ( set @ A ) @ D3 @ C5 )
=> ( ( ord_less_eq @ ( set @ A ) @ C4 @ D3 )
| ( ord_less_eq @ ( set @ A ) @ D3 @ C4 ) ) ) )
=> ( ! [C4: set @ A] :
( ( member2 @ ( set @ A ) @ C4 @ C5 )
=> ~ ( real_V358717886546972837endent @ A @ C4 ) )
=> ~ ( real_V358717886546972837endent @ A @ ( complete_Sup_Sup @ ( set @ A ) @ C5 ) ) ) ) ) ).
% independent_Union_directed
thf(fact_7315_uniformity__sym,axiom,
! [A: $tType] :
( ( topolo7287701948861334536_space @ A )
=> ! [E5: ( product_prod @ A @ A ) > $o] :
( ( eventually @ ( product_prod @ A @ A ) @ E5 @ ( topolo7806501430040627800ormity @ A ) )
=> ( eventually @ ( product_prod @ A @ A )
@ ( product_case_prod @ A @ A @ $o
@ ^ [X2: A,Y2: A] : ( E5 @ ( product_Pair @ A @ A @ Y2 @ X2 ) ) )
@ ( topolo7806501430040627800ormity @ A ) ) ) ) ).
% uniformity_sym
thf(fact_7316_Cauchy__uniform__iff,axiom,
! [A: $tType] :
( ( topolo7287701948861334536_space @ A )
=> ( ( topolo3814608138187158403Cauchy @ A )
= ( ^ [X8: nat > A] :
! [P: ( product_prod @ A @ A ) > $o] :
( ( eventually @ ( product_prod @ A @ A ) @ P @ ( topolo7806501430040627800ormity @ A ) )
=> ? [N6: nat] :
! [N: nat] :
( ( ord_less_eq @ nat @ N6 @ N )
=> ! [M2: nat] :
( ( ord_less_eq @ nat @ N6 @ M2 )
=> ( P @ ( product_Pair @ A @ A @ ( X8 @ N ) @ ( X8 @ M2 ) ) ) ) ) ) ) ) ) ).
% Cauchy_uniform_iff
thf(fact_7317_totally__bounded__def,axiom,
! [A: $tType] :
( ( topolo7287701948861334536_space @ A )
=> ( ( topolo6688025880775521714ounded @ A )
= ( ^ [S8: set @ A] :
! [E6: ( product_prod @ A @ A ) > $o] :
( ( eventually @ ( product_prod @ A @ A ) @ E6 @ ( topolo7806501430040627800ormity @ A ) )
=> ? [X8: set @ A] :
( ( finite_finite @ A @ X8 )
& ! [X2: A] :
( ( member2 @ A @ X2 @ S8 )
=> ? [Y2: A] :
( ( member2 @ A @ Y2 @ X8 )
& ( E6 @ ( product_Pair @ A @ A @ Y2 @ X2 ) ) ) ) ) ) ) ) ) ).
% totally_bounded_def
thf(fact_7318_dependent__finite,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A] :
( ( finite_finite @ A @ S3 )
=> ( ( real_V358717886546972837endent @ A @ S3 )
= ( ? [U2: A > real] :
( ? [X2: A] :
( ( member2 @ A @ X2 @ S3 )
& ( ( U2 @ X2 )
!= ( zero_zero @ real ) ) )
& ( ( groups7311177749621191930dd_sum @ A @ A
@ ^ [V5: A] : ( real_V8093663219630862766scaleR @ A @ ( U2 @ V5 ) @ V5 )
@ S3 )
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% dependent_finite
thf(fact_7319_independent__if__scalars__zero,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A4: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ! [F4: A > real,X5: A] :
( ( ( groups7311177749621191930dd_sum @ A @ A
@ ^ [Y2: A] : ( real_V8093663219630862766scaleR @ A @ ( F4 @ Y2 ) @ Y2 )
@ A4 )
= ( zero_zero @ A ) )
=> ( ( member2 @ A @ X5 @ A4 )
=> ( ( F4 @ X5 )
= ( zero_zero @ real ) ) ) )
=> ~ ( real_V358717886546972837endent @ A @ A4 ) ) ) ) ).
% independent_if_scalars_zero
thf(fact_7320_independentD__unique,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [B3: set @ A,X7: A > real,Y6: A > real] :
( ~ ( real_V358717886546972837endent @ A @ B3 )
=> ( ( finite_finite @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( X7 @ X2 )
!= ( zero_zero @ real ) ) ) )
=> ( ( ord_less_eq @ ( set @ A )
@ ( collect @ A
@ ^ [X2: A] :
( ( X7 @ X2 )
!= ( zero_zero @ real ) ) )
@ B3 )
=> ( ( finite_finite @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( Y6 @ X2 )
!= ( zero_zero @ real ) ) ) )
=> ( ( ord_less_eq @ ( set @ A )
@ ( collect @ A
@ ^ [X2: A] :
( ( Y6 @ X2 )
!= ( zero_zero @ real ) ) )
@ B3 )
=> ( ( ( groups7311177749621191930dd_sum @ A @ A
@ ^ [X2: A] : ( real_V8093663219630862766scaleR @ A @ ( X7 @ X2 ) @ X2 )
@ ( collect @ A
@ ^ [X2: A] :
( ( X7 @ X2 )
!= ( zero_zero @ real ) ) ) )
= ( groups7311177749621191930dd_sum @ A @ A
@ ^ [X2: A] : ( real_V8093663219630862766scaleR @ A @ ( Y6 @ X2 ) @ X2 )
@ ( collect @ A
@ ^ [X2: A] :
( ( Y6 @ X2 )
!= ( zero_zero @ real ) ) ) ) )
=> ( X7 = Y6 ) ) ) ) ) ) ) ) ).
% independentD_unique
thf(fact_7321_eventually__uniformity__metric,axiom,
! [A: $tType] :
( ( real_V768167426530841204y_dist @ A )
=> ! [P2: ( product_prod @ A @ A ) > $o] :
( ( eventually @ ( product_prod @ A @ A ) @ P2 @ ( topolo7806501430040627800ormity @ A ) )
= ( ? [E4: real] :
( ( ord_less @ real @ ( zero_zero @ real ) @ E4 )
& ! [X2: A,Y2: A] :
( ( ord_less @ real @ ( real_V557655796197034286t_dist @ A @ X2 @ Y2 ) @ E4 )
=> ( P2 @ ( product_Pair @ A @ A @ X2 @ Y2 ) ) ) ) ) ) ) ).
% eventually_uniformity_metric
thf(fact_7322_independent__explicit__finite__subsets,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A4: set @ A] :
( ( ~ ( real_V358717886546972837endent @ A @ A4 ) )
= ( ! [S8: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ S8 @ A4 )
=> ( ( finite_finite @ A @ S8 )
=> ! [U2: A > real] :
( ( ( groups7311177749621191930dd_sum @ A @ A
@ ^ [V5: A] : ( real_V8093663219630862766scaleR @ A @ ( U2 @ V5 ) @ V5 )
@ S8 )
= ( zero_zero @ A ) )
=> ! [X2: A] :
( ( member2 @ A @ X2 @ S8 )
=> ( ( U2 @ X2 )
= ( zero_zero @ real ) ) ) ) ) ) ) ) ) ).
% independent_explicit_finite_subsets
thf(fact_7323_independent__explicit__module,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S: set @ A] :
( ( ~ ( real_V358717886546972837endent @ A @ S ) )
= ( ! [T3: set @ A,U2: A > real,V5: A] :
( ( finite_finite @ A @ T3 )
=> ( ( ord_less_eq @ ( set @ A ) @ T3 @ S )
=> ( ( ( groups7311177749621191930dd_sum @ A @ A
@ ^ [W3: A] : ( real_V8093663219630862766scaleR @ A @ ( U2 @ W3 ) @ W3 )
@ T3 )
= ( zero_zero @ A ) )
=> ( ( member2 @ A @ V5 @ T3 )
=> ( ( U2 @ V5 )
= ( zero_zero @ real ) ) ) ) ) ) ) ) ) ).
% independent_explicit_module
thf(fact_7324_dependent__explicit,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ( ( real_V358717886546972837endent @ A )
= ( ^ [S7: set @ A] :
? [T3: set @ A] :
( ( finite_finite @ A @ T3 )
& ( ord_less_eq @ ( set @ A ) @ T3 @ S7 )
& ? [U2: A > real] :
( ( ( groups7311177749621191930dd_sum @ A @ A
@ ^ [V5: A] : ( real_V8093663219630862766scaleR @ A @ ( U2 @ V5 ) @ V5 )
@ T3 )
= ( zero_zero @ A ) )
& ? [X2: A] :
( ( member2 @ A @ X2 @ T3 )
& ( ( U2 @ X2 )
!= ( zero_zero @ real ) ) ) ) ) ) ) ) ).
% dependent_explicit
thf(fact_7325_independentD__alt,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [B3: set @ A,X7: A > real,X: A] :
( ~ ( real_V358717886546972837endent @ A @ B3 )
=> ( ( finite_finite @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( X7 @ X2 )
!= ( zero_zero @ real ) ) ) )
=> ( ( ord_less_eq @ ( set @ A )
@ ( collect @ A
@ ^ [X2: A] :
( ( X7 @ X2 )
!= ( zero_zero @ real ) ) )
@ B3 )
=> ( ( ( groups7311177749621191930dd_sum @ A @ A
@ ^ [X2: A] : ( real_V8093663219630862766scaleR @ A @ ( X7 @ X2 ) @ X2 )
@ ( collect @ A
@ ^ [X2: A] :
( ( X7 @ X2 )
!= ( zero_zero @ real ) ) ) )
= ( zero_zero @ A ) )
=> ( ( X7 @ X )
= ( zero_zero @ real ) ) ) ) ) ) ) ).
% independentD_alt
thf(fact_7326_independent__alt,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [B3: set @ A] :
( ( ~ ( real_V358717886546972837endent @ A @ B3 ) )
= ( ! [X8: A > real] :
( ( finite_finite @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( X8 @ X2 )
!= ( zero_zero @ real ) ) ) )
=> ( ( ord_less_eq @ ( set @ A )
@ ( collect @ A
@ ^ [X2: A] :
( ( X8 @ X2 )
!= ( zero_zero @ real ) ) )
@ B3 )
=> ( ( ( groups7311177749621191930dd_sum @ A @ A
@ ^ [X2: A] : ( real_V8093663219630862766scaleR @ A @ ( X8 @ X2 ) @ X2 )
@ ( collect @ A
@ ^ [X2: A] :
( ( X8 @ X2 )
!= ( zero_zero @ real ) ) ) )
= ( zero_zero @ A ) )
=> ! [X2: A] :
( ( X8 @ X2 )
= ( zero_zero @ real ) ) ) ) ) ) ) ) ).
% independent_alt
thf(fact_7327_dependent__alt,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ( ( real_V358717886546972837endent @ A )
= ( ^ [B6: set @ A] :
? [X8: A > real] :
( ( finite_finite @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( X8 @ X2 )
!= ( zero_zero @ real ) ) ) )
& ( ord_less_eq @ ( set @ A )
@ ( collect @ A
@ ^ [X2: A] :
( ( X8 @ X2 )
!= ( zero_zero @ real ) ) )
@ B6 )
& ( ( groups7311177749621191930dd_sum @ A @ A
@ ^ [X2: A] : ( real_V8093663219630862766scaleR @ A @ ( X8 @ X2 ) @ X2 )
@ ( collect @ A
@ ^ [X2: A] :
( ( X8 @ X2 )
!= ( zero_zero @ real ) ) ) )
= ( zero_zero @ A ) )
& ? [X2: A] :
( ( X8 @ X2 )
!= ( zero_zero @ real ) ) ) ) ) ) ).
% dependent_alt
thf(fact_7328_uniformity__trans_H,axiom,
! [A: $tType] :
( ( topolo7287701948861334536_space @ A )
=> ! [E5: ( product_prod @ A @ A ) > $o] :
( ( eventually @ ( product_prod @ A @ A ) @ E5 @ ( topolo7806501430040627800ormity @ A ) )
=> ( eventually @ ( product_prod @ ( product_prod @ A @ A ) @ ( product_prod @ A @ A ) )
@ ( product_case_prod @ ( product_prod @ A @ A ) @ ( product_prod @ A @ A ) @ $o
@ ( product_case_prod @ A @ A @ ( ( product_prod @ A @ A ) > $o )
@ ^ [X2: A,Y2: A] :
( product_case_prod @ A @ A @ $o
@ ^ [Y7: A,Z6: A] :
( ( Y2 = Y7 )
=> ( E5 @ ( product_Pair @ A @ A @ X2 @ Z6 ) ) ) ) ) )
@ ( prod_filter @ ( product_prod @ A @ A ) @ ( product_prod @ A @ A ) @ ( topolo7806501430040627800ormity @ A ) @ ( topolo7806501430040627800ormity @ A ) ) ) ) ) ).
% uniformity_trans'
thf(fact_7329_uniformly__continuous__onD,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo7287701948861334536_space @ A )
& ( topolo7287701948861334536_space @ B ) )
=> ! [S: set @ A,F2: A > B,E5: ( product_prod @ B @ B ) > $o] :
( ( topolo6026614971017936543ous_on @ A @ B @ S @ F2 )
=> ( ( eventually @ ( product_prod @ B @ B ) @ E5 @ ( topolo7806501430040627800ormity @ B ) )
=> ( eventually @ ( product_prod @ A @ A )
@ ( product_case_prod @ A @ A @ $o
@ ^ [X2: A,Y2: A] :
( ( member2 @ A @ X2 @ S )
=> ( ( member2 @ A @ Y2 @ S )
=> ( E5 @ ( product_Pair @ B @ B @ ( F2 @ X2 ) @ ( F2 @ Y2 ) ) ) ) ) )
@ ( topolo7806501430040627800ormity @ A ) ) ) ) ) ).
% uniformly_continuous_onD
thf(fact_7330_prod__filter__mono__iff,axiom,
! [A: $tType,B: $tType,A4: filter @ A,B3: filter @ B,C5: filter @ A,D6: filter @ B] :
( ( A4
!= ( bot_bot @ ( filter @ A ) ) )
=> ( ( B3
!= ( bot_bot @ ( filter @ B ) ) )
=> ( ( ord_less_eq @ ( filter @ ( product_prod @ A @ B ) ) @ ( prod_filter @ A @ B @ A4 @ B3 ) @ ( prod_filter @ A @ B @ C5 @ D6 ) )
= ( ( ord_less_eq @ ( filter @ A ) @ A4 @ C5 )
& ( ord_less_eq @ ( filter @ B ) @ B3 @ D6 ) ) ) ) ) ).
% prod_filter_mono_iff
thf(fact_7331_prod__filter__eq__bot,axiom,
! [A: $tType,B: $tType,A4: filter @ A,B3: filter @ B] :
( ( ( prod_filter @ A @ B @ A4 @ B3 )
= ( bot_bot @ ( filter @ ( product_prod @ A @ B ) ) ) )
= ( ( A4
= ( bot_bot @ ( filter @ A ) ) )
| ( B3
= ( bot_bot @ ( filter @ B ) ) ) ) ) ).
% prod_filter_eq_bot
thf(fact_7332_eventually__prod__same,axiom,
! [A: $tType,P2: ( product_prod @ A @ A ) > $o,F5: filter @ A] :
( ( eventually @ ( product_prod @ A @ A ) @ P2 @ ( prod_filter @ A @ A @ F5 @ F5 ) )
= ( ? [Q6: A > $o] :
( ( eventually @ A @ Q6 @ F5 )
& ! [X2: A,Y2: A] :
( ( Q6 @ X2 )
=> ( ( Q6 @ Y2 )
=> ( P2 @ ( product_Pair @ A @ A @ X2 @ Y2 ) ) ) ) ) ) ) ).
% eventually_prod_same
thf(fact_7333_eventually__prod__filter,axiom,
! [B: $tType,A: $tType,P2: ( product_prod @ A @ B ) > $o,F5: filter @ A,G7: filter @ B] :
( ( eventually @ ( product_prod @ A @ B ) @ P2 @ ( prod_filter @ A @ B @ F5 @ G7 ) )
= ( ? [Pf: A > $o,Pg: B > $o] :
( ( eventually @ A @ Pf @ F5 )
& ( eventually @ B @ Pg @ G7 )
& ! [X2: A,Y2: B] :
( ( Pf @ X2 )
=> ( ( Pg @ Y2 )
=> ( P2 @ ( product_Pair @ A @ B @ X2 @ Y2 ) ) ) ) ) ) ) ).
% eventually_prod_filter
thf(fact_7334_prod__filter__INF,axiom,
! [C: $tType,D: $tType,B: $tType,A: $tType,I6: set @ A,J4: set @ B,A4: A > ( filter @ C ),B3: B > ( filter @ D )] :
( ( I6
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( J4
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( prod_filter @ C @ D @ ( complete_Inf_Inf @ ( filter @ C ) @ ( image2 @ A @ ( filter @ C ) @ A4 @ I6 ) ) @ ( complete_Inf_Inf @ ( filter @ D ) @ ( image2 @ B @ ( filter @ D ) @ B3 @ J4 ) ) )
= ( complete_Inf_Inf @ ( filter @ ( product_prod @ C @ D ) )
@ ( image2 @ A @ ( filter @ ( product_prod @ C @ D ) )
@ ^ [I5: A] :
( complete_Inf_Inf @ ( filter @ ( product_prod @ C @ D ) )
@ ( image2 @ B @ ( filter @ ( product_prod @ C @ D ) )
@ ^ [J3: B] : ( prod_filter @ C @ D @ ( A4 @ I5 ) @ ( B3 @ J3 ) )
@ J4 ) )
@ I6 ) ) ) ) ) ).
% prod_filter_INF
thf(fact_7335_prod__filter__INF1,axiom,
! [B: $tType,C: $tType,A: $tType,I6: set @ A,A4: A > ( filter @ B ),B3: filter @ C] :
( ( I6
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( prod_filter @ B @ C @ ( complete_Inf_Inf @ ( filter @ B ) @ ( image2 @ A @ ( filter @ B ) @ A4 @ I6 ) ) @ B3 )
= ( complete_Inf_Inf @ ( filter @ ( product_prod @ B @ C ) )
@ ( image2 @ A @ ( filter @ ( product_prod @ B @ C ) )
@ ^ [I5: A] : ( prod_filter @ B @ C @ ( A4 @ I5 ) @ B3 )
@ I6 ) ) ) ) ).
% prod_filter_INF1
thf(fact_7336_prod__filter__INF2,axiom,
! [B: $tType,C: $tType,A: $tType,J4: set @ A,A4: filter @ B,B3: A > ( filter @ C )] :
( ( J4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( prod_filter @ B @ C @ A4 @ ( complete_Inf_Inf @ ( filter @ C ) @ ( image2 @ A @ ( filter @ C ) @ B3 @ J4 ) ) )
= ( complete_Inf_Inf @ ( filter @ ( product_prod @ B @ C ) )
@ ( image2 @ A @ ( filter @ ( product_prod @ B @ C ) )
@ ^ [I5: A] : ( prod_filter @ B @ C @ A4 @ ( B3 @ I5 ) )
@ J4 ) ) ) ) ).
% prod_filter_INF2
thf(fact_7337_nhds__prod,axiom,
! [A: $tType,B: $tType] :
( ( ( topolo4958980785337419405_space @ B )
& ( topolo4958980785337419405_space @ A ) )
=> ! [A3: A,B2: B] :
( ( topolo7230453075368039082e_nhds @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) )
= ( prod_filter @ A @ B @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ ( topolo7230453075368039082e_nhds @ B @ B2 ) ) ) ) ).
% nhds_prod
thf(fact_7338_filterlim__Pair,axiom,
! [C: $tType,B: $tType,A: $tType,F2: A > B,G7: filter @ B,F5: filter @ A,G: A > C,H6: filter @ C] :
( ( filterlim @ A @ B @ F2 @ G7 @ F5 )
=> ( ( filterlim @ A @ C @ G @ H6 @ F5 )
=> ( filterlim @ A @ ( product_prod @ B @ C )
@ ^ [X2: A] : ( product_Pair @ B @ C @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( prod_filter @ B @ C @ G7 @ H6 )
@ F5 ) ) ) ).
% filterlim_Pair
thf(fact_7339_tendsto__add__Pair,axiom,
! [A: $tType] :
( ( topolo6943815403480290642id_add @ A )
=> ! [A3: A,B2: A] :
( filterlim @ ( product_prod @ A @ A ) @ A
@ ^ [X2: product_prod @ A @ A] : ( plus_plus @ A @ ( product_fst @ A @ A @ X2 ) @ ( product_snd @ A @ A @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ A @ ( plus_plus @ A @ A3 @ B2 ) )
@ ( prod_filter @ A @ A @ ( topolo7230453075368039082e_nhds @ A @ A3 ) @ ( topolo7230453075368039082e_nhds @ A @ B2 ) ) ) ) ).
% tendsto_add_Pair
thf(fact_7340_eventually__prod2,axiom,
! [A: $tType,B: $tType,A4: filter @ A,P2: B > $o,B3: filter @ B] :
( ( A4
!= ( bot_bot @ ( filter @ A ) ) )
=> ( ( eventually @ ( product_prod @ A @ B )
@ ( product_case_prod @ A @ B @ $o
@ ^ [X2: A] : P2 )
@ ( prod_filter @ A @ B @ A4 @ B3 ) )
= ( eventually @ B @ P2 @ B3 ) ) ) ).
% eventually_prod2
thf(fact_7341_eventually__prod1,axiom,
! [A: $tType,B: $tType,B3: filter @ A,P2: B > $o,A4: filter @ B] :
( ( B3
!= ( bot_bot @ ( filter @ A ) ) )
=> ( ( eventually @ ( product_prod @ B @ A )
@ ( product_case_prod @ B @ A @ $o
@ ^ [X2: B,Y2: A] : ( P2 @ X2 ) )
@ ( prod_filter @ B @ A @ A4 @ B3 ) )
= ( eventually @ B @ P2 @ A4 ) ) ) ).
% eventually_prod1
thf(fact_7342_uniformly__continuous__on__uniformity,axiom,
! [B: $tType,A: $tType] :
( ( ( topolo7287701948861334536_space @ A )
& ( topolo7287701948861334536_space @ B ) )
=> ( ( topolo6026614971017936543ous_on @ A @ B )
= ( ^ [S7: set @ A,F3: A > B] :
( filterlim @ ( product_prod @ A @ A ) @ ( product_prod @ B @ B )
@ ( product_case_prod @ A @ A @ ( product_prod @ B @ B )
@ ^ [X2: A,Y2: A] : ( product_Pair @ B @ B @ ( F3 @ X2 ) @ ( F3 @ Y2 ) ) )
@ ( topolo7806501430040627800ormity @ B )
@ ( inf_inf @ ( filter @ ( product_prod @ A @ A ) ) @ ( topolo7806501430040627800ormity @ A )
@ ( principal @ ( product_prod @ A @ A )
@ ( product_Sigma @ A @ A @ S7
@ ^ [Uu3: A] : S7 ) ) ) ) ) ) ) ).
% uniformly_continuous_on_uniformity
thf(fact_7343_prod__filter__assoc,axiom,
! [A: $tType,B: $tType,C: $tType,F5: filter @ A,G7: filter @ B,H6: filter @ C] :
( ( prod_filter @ ( product_prod @ A @ B ) @ C @ ( prod_filter @ A @ B @ F5 @ G7 ) @ H6 )
= ( filtermap @ ( product_prod @ A @ ( product_prod @ B @ C ) ) @ ( product_prod @ ( product_prod @ A @ B ) @ C )
@ ( product_case_prod @ A @ ( product_prod @ B @ C ) @ ( product_prod @ ( product_prod @ A @ B ) @ C )
@ ^ [X2: A] :
( product_case_prod @ B @ C @ ( product_prod @ ( product_prod @ A @ B ) @ C )
@ ^ [Y2: B] : ( product_Pair @ ( product_prod @ A @ B ) @ C @ ( product_Pair @ A @ B @ X2 @ Y2 ) ) ) )
@ ( prod_filter @ A @ ( product_prod @ B @ C ) @ F5 @ ( prod_filter @ B @ C @ G7 @ H6 ) ) ) ) ).
% prod_filter_assoc
thf(fact_7344_dbl__inc__simps_I2_J,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ( ( neg_numeral_dbl_inc @ A @ ( zero_zero @ A ) )
= ( one_one @ A ) ) ) ).
% dbl_inc_simps(2)
thf(fact_7345_filtermap__bot,axiom,
! [B: $tType,A: $tType,F2: B > A] :
( ( filtermap @ B @ A @ F2 @ ( bot_bot @ ( filter @ B ) ) )
= ( bot_bot @ ( filter @ A ) ) ) ).
% filtermap_bot
thf(fact_7346_filtermap__Pair,axiom,
! [A: $tType,B: $tType,C: $tType,F2: C > A,G: C > B,F5: filter @ C] :
( ord_less_eq @ ( filter @ ( product_prod @ A @ B ) )
@ ( filtermap @ C @ ( product_prod @ A @ B )
@ ^ [X2: C] : ( product_Pair @ A @ B @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ F5 )
@ ( prod_filter @ A @ B @ ( filtermap @ C @ A @ F2 @ F5 ) @ ( filtermap @ C @ B @ G @ F5 ) ) ) ).
% filtermap_Pair
thf(fact_7347_filtermap__bot__iff,axiom,
! [A: $tType,B: $tType,F2: B > A,F5: filter @ B] :
( ( ( filtermap @ B @ A @ F2 @ F5 )
= ( bot_bot @ ( filter @ A ) ) )
= ( F5
= ( bot_bot @ ( filter @ B ) ) ) ) ).
% filtermap_bot_iff
thf(fact_7348_filtermap__nhds__times,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ! [C2: A,A3: A] :
( ( C2
!= ( zero_zero @ A ) )
=> ( ( filtermap @ A @ A @ ( times_times @ A @ C2 ) @ ( topolo7230453075368039082e_nhds @ A @ A3 ) )
= ( topolo7230453075368039082e_nhds @ A @ ( times_times @ A @ C2 @ A3 ) ) ) ) ) ).
% filtermap_nhds_times
thf(fact_7349_eventually__prod__sequentially,axiom,
! [P2: ( product_prod @ nat @ nat ) > $o] :
( ( eventually @ ( product_prod @ nat @ nat ) @ P2 @ ( prod_filter @ nat @ nat @ ( at_top @ nat ) @ ( at_top @ nat ) ) )
= ( ? [N6: nat] :
! [M2: nat] :
( ( ord_less_eq @ nat @ N6 @ M2 )
=> ! [N: nat] :
( ( ord_less_eq @ nat @ N6 @ N )
=> ( P2 @ ( product_Pair @ nat @ nat @ N @ M2 ) ) ) ) ) ) ).
% eventually_prod_sequentially
thf(fact_7350_dbl__inc__def,axiom,
! [A: $tType] :
( ( neg_numeral @ A )
=> ( ( neg_numeral_dbl_inc @ A )
= ( ^ [X2: A] : ( plus_plus @ A @ ( plus_plus @ A @ X2 @ X2 ) @ ( one_one @ A ) ) ) ) ) ).
% dbl_inc_def
thf(fact_7351_at__to__0,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [A3: A] :
( ( topolo174197925503356063within @ A @ A3 @ ( top_top @ ( set @ A ) ) )
= ( filtermap @ A @ A
@ ^ [X2: A] : ( plus_plus @ A @ X2 @ A3 )
@ ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) ) ) ) ) ).
% at_to_0
thf(fact_7352_filtermap__times__pos__at__right,axiom,
! [A: $tType] :
( ( ( linordered_field @ A )
& ( topolo1944317154257567458pology @ A ) )
=> ! [C2: A,P4: A] :
( ( ord_less @ A @ ( zero_zero @ A ) @ C2 )
=> ( ( filtermap @ A @ A @ ( times_times @ A @ C2 ) @ ( topolo174197925503356063within @ A @ P4 @ ( set_ord_greaterThan @ A @ P4 ) ) )
= ( topolo174197925503356063within @ A @ ( times_times @ A @ C2 @ P4 ) @ ( set_ord_greaterThan @ A @ ( times_times @ A @ C2 @ P4 ) ) ) ) ) ) ).
% filtermap_times_pos_at_right
thf(fact_7353_at__to__infinity,axiom,
! [A: $tType] :
( ( real_V3459762299906320749_field @ A )
=> ( ( topolo174197925503356063within @ A @ ( zero_zero @ A ) @ ( top_top @ ( set @ A ) ) )
= ( filtermap @ A @ A @ ( inverse_inverse @ A ) @ ( at_infinity @ A ) ) ) ) ).
% at_to_infinity
thf(fact_7354_prod__filter__principal__singleton,axiom,
! [A: $tType,B: $tType,X: A,F5: filter @ B] :
( ( prod_filter @ A @ B @ ( principal @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) @ F5 )
= ( filtermap @ B @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X ) @ F5 ) ) ).
% prod_filter_principal_singleton
thf(fact_7355_prod__filter__principal__singleton2,axiom,
! [B: $tType,A: $tType,F5: filter @ A,X: B] :
( ( prod_filter @ A @ B @ F5 @ ( principal @ B @ ( insert2 @ B @ X @ ( bot_bot @ ( set @ B ) ) ) ) )
= ( filtermap @ A @ ( product_prod @ A @ B )
@ ^ [A5: A] : ( product_Pair @ A @ B @ A5 @ X )
@ F5 ) ) ).
% prod_filter_principal_singleton2
thf(fact_7356_relation__of__def,axiom,
! [A: $tType] :
( ( order_relation_of @ A )
= ( ^ [P: A > A > $o,A6: set @ A] :
( collect @ ( product_prod @ A @ A )
@ ( product_case_prod @ A @ A @ $o
@ ^ [A5: A,B4: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A5 @ B4 )
@ ( product_Sigma @ A @ A @ A6
@ ^ [Uu3: A] : A6 ) )
& ( P @ A5 @ B4 ) ) ) ) ) ) ).
% relation_of_def
thf(fact_7357_possible__bit__def,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ( ( bit_se6407376104438227557le_bit @ A )
= ( ^ [Tyrep: itself @ A,N: nat] :
( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N )
!= ( zero_zero @ A ) ) ) ) ) ).
% possible_bit_def
thf(fact_7358_filtermap__sequentually__ne__bot,axiom,
! [A: $tType,F2: nat > A] :
( ( filtermap @ nat @ A @ F2 @ ( at_top @ nat ) )
!= ( bot_bot @ ( filter @ A ) ) ) ).
% filtermap_sequentually_ne_bot
thf(fact_7359_possible__bit__less__imp,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [Tyrep2: itself @ A,I: nat,J: nat] :
( ( bit_se6407376104438227557le_bit @ A @ Tyrep2 @ I )
=> ( ( ord_less_eq @ nat @ J @ I )
=> ( bit_se6407376104438227557le_bit @ A @ Tyrep2 @ J ) ) ) ) ).
% possible_bit_less_imp
thf(fact_7360_possible__bit__0,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [Ty: itself @ A] : ( bit_se6407376104438227557le_bit @ A @ Ty @ ( zero_zero @ nat ) ) ) ).
% possible_bit_0
thf(fact_7361_drop__bit__exp__eq,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,N2: nat] :
( ( bit_se4197421643247451524op_bit @ A @ M @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 ) )
= ( times_times @ A
@ ( zero_neq_one_of_bool @ A
@ ( ( ord_less_eq @ nat @ M @ N2 )
& ( bit_se6407376104438227557le_bit @ A @ ( type2 @ A ) @ N2 ) ) )
@ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ) ).
% drop_bit_exp_eq
thf(fact_7362_bit__minus__2__iff,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( uminus_uminus @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) ) @ N2 )
= ( ( bit_se6407376104438227557le_bit @ A @ ( type2 @ A ) @ N2 )
& ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 ) ) ) ) ).
% bit_minus_2_iff
thf(fact_7363_CHAR__eq__0,axiom,
! [A: $tType] :
( ( semiring_char_0 @ A )
=> ( ( semiri4206861660011772517g_char @ A @ ( type2 @ A ) )
= ( zero_zero @ nat ) ) ) ).
% CHAR_eq_0
thf(fact_7364_of__nat__CHAR,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( semiring_1_of_nat @ A @ ( semiri4206861660011772517g_char @ A @ ( type2 @ A ) ) )
= ( zero_zero @ A ) ) ) ).
% of_nat_CHAR
thf(fact_7365_bit__mask__iff,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( bit_se2239418461657761734s_mask @ A @ M ) @ N2 )
= ( ( bit_se6407376104438227557le_bit @ A @ ( type2 @ A ) @ N2 )
& ( ord_less @ nat @ N2 @ M ) ) ) ) ).
% bit_mask_iff
thf(fact_7366_of__nat__eq__0__iff__char__dvd,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [N2: nat] :
( ( ( semiring_1_of_nat @ A @ N2 )
= ( zero_zero @ A ) )
= ( dvd_dvd @ nat @ ( semiri4206861660011772517g_char @ A @ ( type2 @ A ) ) @ N2 ) ) ) ).
% of_nat_eq_0_iff_char_dvd
thf(fact_7367_CHAR__eqI,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [C2: nat] :
( ( ( semiring_1_of_nat @ A @ C2 )
= ( zero_zero @ A ) )
=> ( ! [X5: nat] :
( ( ( semiring_1_of_nat @ A @ X5 )
= ( zero_zero @ A ) )
=> ( dvd_dvd @ nat @ C2 @ X5 ) )
=> ( ( semiri4206861660011772517g_char @ A @ ( type2 @ A ) )
= C2 ) ) ) ) ).
% CHAR_eqI
thf(fact_7368_CHAR__eq0__iff,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( ( semiri4206861660011772517g_char @ A @ ( type2 @ A ) )
= ( zero_zero @ nat ) )
= ( ! [N: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N )
=> ( ( semiring_1_of_nat @ A @ N )
!= ( zero_zero @ A ) ) ) ) ) ) ).
% CHAR_eq0_iff
thf(fact_7369_CHAR__eq__posI,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ! [C2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ C2 )
=> ( ( ( semiring_1_of_nat @ A @ C2 )
= ( zero_zero @ A ) )
=> ( ! [X5: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ X5 )
=> ( ( ord_less @ nat @ X5 @ C2 )
=> ( ( semiring_1_of_nat @ A @ X5 )
!= ( zero_zero @ A ) ) ) )
=> ( ( semiri4206861660011772517g_char @ A @ ( type2 @ A ) )
= C2 ) ) ) ) ) ).
% CHAR_eq_posI
thf(fact_7370_CHAR__pos__iff,axiom,
! [A: $tType] :
( ( semiring_1 @ A )
=> ( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( semiri4206861660011772517g_char @ A @ ( type2 @ A ) ) )
= ( ? [N: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N )
& ( ( semiring_1_of_nat @ A @ N )
= ( zero_zero @ A ) ) ) ) ) ) ).
% CHAR_pos_iff
thf(fact_7371_bit__push__bit__iff,axiom,
! [A: $tType] :
( ( bit_se359711467146920520ations @ A )
=> ! [M: nat,A3: A,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( bit_se4730199178511100633sh_bit @ A @ M @ A3 ) @ N2 )
= ( ( ord_less_eq @ nat @ M @ N2 )
& ( bit_se6407376104438227557le_bit @ A @ ( type2 @ A ) @ N2 )
& ( bit_se5641148757651400278ts_bit @ A @ A3 @ ( minus_minus @ nat @ N2 @ M ) ) ) ) ) ).
% bit_push_bit_iff
thf(fact_7372_fold__possible__bit,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [N2: nat] :
( ( ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ N2 )
= ( zero_zero @ A ) )
= ( ~ ( bit_se6407376104438227557le_bit @ A @ ( type2 @ A ) @ N2 ) ) ) ) ).
% fold_possible_bit
thf(fact_7373_bit__minus__exp__iff,axiom,
! [A: $tType] :
( ( bit_ri3973907225187159222ations @ A )
=> ! [M: nat,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( uminus_uminus @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) ) @ N2 )
= ( ( bit_se6407376104438227557le_bit @ A @ ( type2 @ A ) @ N2 )
& ( ord_less_eq @ nat @ M @ N2 ) ) ) ) ).
% bit_minus_exp_iff
thf(fact_7374_bit__mask__sub__iff,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [M: nat,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( minus_minus @ A @ ( power_power @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ M ) @ ( one_one @ A ) ) @ N2 )
= ( ( bit_se6407376104438227557le_bit @ A @ ( type2 @ A ) @ N2 )
& ( ord_less @ nat @ N2 @ M ) ) ) ) ).
% bit_mask_sub_iff
thf(fact_7375_bit__double__iff,axiom,
! [A: $tType] :
( ( bit_semiring_bits @ A )
=> ! [A3: A,N2: nat] :
( ( bit_se5641148757651400278ts_bit @ A @ ( times_times @ A @ ( numeral_numeral @ A @ ( bit0 @ one2 ) ) @ A3 ) @ N2 )
= ( ( bit_se5641148757651400278ts_bit @ A @ A3 @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) )
& ( N2
!= ( zero_zero @ nat ) )
& ( bit_se6407376104438227557le_bit @ A @ ( type2 @ A ) @ N2 ) ) ) ) ).
% bit_double_iff
thf(fact_7376_graph__map__add,axiom,
! [B: $tType,A: $tType,M1: A > ( option @ B ),M22: A > ( option @ B )] :
( ( ( inf_inf @ ( set @ A ) @ ( dom @ A @ B @ M1 ) @ ( dom @ A @ B @ M22 ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( graph @ A @ B @ ( map_add @ A @ B @ M1 @ M22 ) )
= ( sup_sup @ ( set @ ( product_prod @ A @ B ) ) @ ( graph @ A @ B @ M1 ) @ ( graph @ A @ B @ M22 ) ) ) ) ).
% graph_map_add
thf(fact_7377_map__rec,axiom,
! [A: $tType,B: $tType] :
( ( map @ B @ A )
= ( ^ [F3: B > A] :
( rec_list @ ( list @ A ) @ B @ ( nil @ A )
@ ^ [X2: B,Uu3: list @ B] : ( cons @ A @ ( F3 @ X2 ) ) ) ) ) ).
% map_rec
thf(fact_7378_map__add__find__right,axiom,
! [B: $tType,A: $tType,N2: B > ( option @ A ),K: B,Xx: A,M: B > ( option @ A )] :
( ( ( N2 @ K )
= ( some @ A @ Xx ) )
=> ( ( map_add @ B @ A @ M @ N2 @ K )
= ( some @ A @ Xx ) ) ) ).
% map_add_find_right
thf(fact_7379_map__add__upd,axiom,
! [A: $tType,B: $tType,F2: A > ( option @ B ),G: A > ( option @ B ),X: A,Y: B] :
( ( map_add @ A @ B @ F2 @ ( fun_upd @ A @ ( option @ B ) @ G @ X @ ( some @ B @ Y ) ) )
= ( fun_upd @ A @ ( option @ B ) @ ( map_add @ A @ B @ F2 @ G ) @ X @ ( some @ B @ Y ) ) ) ).
% map_add_upd
thf(fact_7380_list_Osimps_I6_J,axiom,
! [A: $tType,C: $tType,F1: C,F22: A > ( list @ A ) > C > C] :
( ( rec_list @ C @ A @ F1 @ F22 @ ( nil @ A ) )
= F1 ) ).
% list.simps(6)
thf(fact_7381_list_Osimps_I7_J,axiom,
! [C: $tType,A: $tType,F1: C,F22: A > ( list @ A ) > C > C,X21: A,X222: list @ A] :
( ( rec_list @ C @ A @ F1 @ F22 @ ( cons @ A @ X21 @ X222 ) )
= ( F22 @ X21 @ X222 @ ( rec_list @ C @ A @ F1 @ F22 @ X222 ) ) ) ).
% list.simps(7)
thf(fact_7382_map__add__SomeD,axiom,
! [B: $tType,A: $tType,M: B > ( option @ A ),N2: B > ( option @ A ),K: B,X: A] :
( ( ( map_add @ B @ A @ M @ N2 @ K )
= ( some @ A @ X ) )
=> ( ( ( N2 @ K )
= ( some @ A @ X ) )
| ( ( ( N2 @ K )
= ( none @ A ) )
& ( ( M @ K )
= ( some @ A @ X ) ) ) ) ) ).
% map_add_SomeD
thf(fact_7383_map__add__Some__iff,axiom,
! [B: $tType,A: $tType,M: B > ( option @ A ),N2: B > ( option @ A ),K: B,X: A] :
( ( ( map_add @ B @ A @ M @ N2 @ K )
= ( some @ A @ X ) )
= ( ( ( N2 @ K )
= ( some @ A @ X ) )
| ( ( ( N2 @ K )
= ( none @ A ) )
& ( ( M @ K )
= ( some @ A @ X ) ) ) ) ) ).
% map_add_Some_iff
thf(fact_7384_map__add__def,axiom,
! [B: $tType,A: $tType] :
( ( map_add @ A @ B )
= ( ^ [M12: A > ( option @ B ),M23: A > ( option @ B ),X2: A] : ( case_option @ ( option @ B ) @ B @ ( M12 @ X2 ) @ ( some @ B ) @ ( M23 @ X2 ) ) ) ) ).
% map_add_def
thf(fact_7385_map__add__comm,axiom,
! [B: $tType,A: $tType,M1: A > ( option @ B ),M22: A > ( option @ B )] :
( ( ( inf_inf @ ( set @ A ) @ ( dom @ A @ B @ M1 ) @ ( dom @ A @ B @ M22 ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( map_add @ A @ B @ M1 @ M22 )
= ( map_add @ A @ B @ M22 @ M1 ) ) ) ).
% map_add_comm
thf(fact_7386_map__add__upd__left,axiom,
! [A: $tType,B: $tType,M: A,E22: A > ( option @ B ),E1: A > ( option @ B ),U1: B] :
( ~ ( member2 @ A @ M @ ( dom @ A @ B @ E22 ) )
=> ( ( map_add @ A @ B @ ( fun_upd @ A @ ( option @ B ) @ E1 @ M @ ( some @ B @ U1 ) ) @ E22 )
= ( fun_upd @ A @ ( option @ B ) @ ( map_add @ A @ B @ E1 @ E22 ) @ M @ ( some @ B @ U1 ) ) ) ) ).
% map_add_upd_left
thf(fact_7387_map__add__map__of__foldr,axiom,
! [B: $tType,A: $tType,M: A > ( option @ B ),Ps: list @ ( product_prod @ A @ B )] :
( ( map_add @ A @ B @ M @ ( map_of @ A @ B @ Ps ) )
= ( foldr @ ( product_prod @ A @ B ) @ ( A > ( option @ B ) )
@ ( product_case_prod @ A @ B @ ( ( A > ( option @ B ) ) > A > ( option @ B ) )
@ ^ [K2: A,V5: B,M2: A > ( option @ B )] : ( fun_upd @ A @ ( option @ B ) @ M2 @ K2 @ ( some @ B @ V5 ) ) )
@ Ps
@ M ) ) ).
% map_add_map_of_foldr
thf(fact_7388_list_Orec__o__map,axiom,
! [C: $tType,B: $tType,A: $tType,G: C,Ga: B > ( list @ B ) > C > C,F2: A > B] :
( ( comp @ ( list @ B ) @ C @ ( list @ A ) @ ( rec_list @ C @ B @ G @ Ga ) @ ( map @ A @ B @ F2 ) )
= ( rec_list @ C @ A @ G
@ ^ [X2: A,Xa3: list @ A] : ( Ga @ ( F2 @ X2 ) @ ( map @ A @ B @ F2 @ Xa3 ) ) ) ) ).
% list.rec_o_map
thf(fact_7389_ran__map__add,axiom,
! [B: $tType,A: $tType,M1: A > ( option @ B ),M22: A > ( option @ B )] :
( ( ( inf_inf @ ( set @ A ) @ ( dom @ A @ B @ M1 ) @ ( dom @ A @ B @ M22 ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( ran @ A @ B @ ( map_add @ A @ B @ M1 @ M22 ) )
= ( sup_sup @ ( set @ B ) @ ( ran @ A @ B @ M1 ) @ ( ran @ A @ B @ M22 ) ) ) ) ).
% ran_map_add
thf(fact_7390_acyclic__insert,axiom,
! [A: $tType,Y: A,X: A,R2: set @ ( product_prod @ A @ A )] :
( ( transitive_acyclic @ A @ ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ X ) @ R2 ) )
= ( ( transitive_acyclic @ A @ R2 )
& ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ).
% acyclic_insert
thf(fact_7391_append__butlast__last__id,axiom,
! [A: $tType,Xs: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( append @ A @ ( butlast @ A @ Xs ) @ ( cons @ A @ ( last @ A @ Xs ) @ ( nil @ A ) ) )
= Xs ) ) ).
% append_butlast_last_id
thf(fact_7392_last__remdups__adj,axiom,
! [A: $tType,Xs: list @ A] :
( ( last @ A @ ( remdups_adj @ A @ Xs ) )
= ( last @ A @ Xs ) ) ).
% last_remdups_adj
thf(fact_7393_last__appendR,axiom,
! [A: $tType,Ys: list @ A,Xs: list @ A] :
( ( Ys
!= ( nil @ A ) )
=> ( ( last @ A @ ( append @ A @ Xs @ Ys ) )
= ( last @ A @ Ys ) ) ) ).
% last_appendR
thf(fact_7394_last__appendL,axiom,
! [A: $tType,Ys: list @ A,Xs: list @ A] :
( ( Ys
= ( nil @ A ) )
=> ( ( last @ A @ ( append @ A @ Xs @ Ys ) )
= ( last @ A @ Xs ) ) ) ).
% last_appendL
thf(fact_7395_last__replicate,axiom,
! [A: $tType,N2: nat,X: A] :
( ( N2
!= ( zero_zero @ nat ) )
=> ( ( last @ A @ ( replicate @ A @ N2 @ X ) )
= X ) ) ).
% last_replicate
thf(fact_7396_last__upt,axiom,
! [I: nat,J: nat] :
( ( ord_less @ nat @ I @ J )
=> ( ( last @ nat @ ( upt @ I @ J ) )
= ( minus_minus @ nat @ J @ ( one_one @ nat ) ) ) ) ).
% last_upt
thf(fact_7397_last__snoc,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( last @ A @ ( append @ A @ Xs @ ( cons @ A @ X @ ( nil @ A ) ) ) )
= X ) ).
% last_snoc
thf(fact_7398_last__drop,axiom,
! [A: $tType,N2: nat,Xs: list @ A] :
( ( ord_less @ nat @ N2 @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( ( last @ A @ ( drop @ A @ N2 @ Xs ) )
= ( last @ A @ Xs ) ) ) ).
% last_drop
thf(fact_7399_dropWhile__last,axiom,
! [A: $tType,X: A,Xs: list @ A,P2: A > $o] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ~ ( P2 @ X )
=> ( ( last @ A @ ( dropWhile @ A @ P2 @ Xs ) )
= ( last @ A @ Xs ) ) ) ) ).
% dropWhile_last
thf(fact_7400_last__map,axiom,
! [B: $tType,A: $tType,Xs: list @ A,F2: A > B] :
( ( Xs
!= ( nil @ A ) )
=> ( ( last @ B @ ( map @ A @ B @ F2 @ Xs ) )
= ( F2 @ ( last @ A @ Xs ) ) ) ) ).
% last_map
thf(fact_7401_hd__Nil__eq__last,axiom,
! [A: $tType] :
( ( hd @ A @ ( nil @ A ) )
= ( last @ A @ ( nil @ A ) ) ) ).
% hd_Nil_eq_last
thf(fact_7402_last__tl,axiom,
! [A: $tType,Xs: list @ A] :
( ( ( Xs
= ( nil @ A ) )
| ( ( tl @ A @ Xs )
!= ( nil @ A ) ) )
=> ( ( last @ A @ ( tl @ A @ Xs ) )
= ( last @ A @ Xs ) ) ) ).
% last_tl
thf(fact_7403_longest__common__suffix,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
? [Ss: list @ A,Xs4: list @ A,Ys5: list @ A] :
( ( Xs
= ( append @ A @ Xs4 @ Ss ) )
& ( Ys
= ( append @ A @ Ys5 @ Ss ) )
& ( ( Xs4
= ( nil @ A ) )
| ( Ys5
= ( nil @ A ) )
| ( ( last @ A @ Xs4 )
!= ( last @ A @ Ys5 ) ) ) ) ).
% longest_common_suffix
thf(fact_7404_last__append,axiom,
! [A: $tType,Ys: list @ A,Xs: list @ A] :
( ( ( Ys
= ( nil @ A ) )
=> ( ( last @ A @ ( append @ A @ Xs @ Ys ) )
= ( last @ A @ Xs ) ) )
& ( ( Ys
!= ( nil @ A ) )
=> ( ( last @ A @ ( append @ A @ Xs @ Ys ) )
= ( last @ A @ Ys ) ) ) ) ).
% last_append
thf(fact_7405_last__ConsR,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( last @ A @ ( cons @ A @ X @ Xs ) )
= ( last @ A @ Xs ) ) ) ).
% last_ConsR
thf(fact_7406_last__ConsL,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( Xs
= ( nil @ A ) )
=> ( ( last @ A @ ( cons @ A @ X @ Xs ) )
= X ) ) ).
% last_ConsL
thf(fact_7407_last_Osimps,axiom,
! [A: $tType,Xs: list @ A,X: A] :
( ( ( Xs
= ( nil @ A ) )
=> ( ( last @ A @ ( cons @ A @ X @ Xs ) )
= X ) )
& ( ( Xs
!= ( nil @ A ) )
=> ( ( last @ A @ ( cons @ A @ X @ Xs ) )
= ( last @ A @ Xs ) ) ) ) ).
% last.simps
thf(fact_7408_last__in__set,axiom,
! [A: $tType,As: list @ A] :
( ( As
!= ( nil @ A ) )
=> ( member2 @ A @ ( last @ A @ As ) @ ( set2 @ A @ As ) ) ) ).
% last_in_set
thf(fact_7409_last__rev,axiom,
! [A: $tType,Xs: list @ A] :
( ( last @ A @ ( rev @ A @ Xs ) )
= ( hd @ A @ Xs ) ) ).
% last_rev
thf(fact_7410_hd__rev,axiom,
! [A: $tType,Xs: list @ A] :
( ( hd @ A @ ( rev @ A @ Xs ) )
= ( last @ A @ Xs ) ) ).
% hd_rev
thf(fact_7411_acyclicI__order,axiom,
! [A: $tType,B: $tType] :
( ( preorder @ A )
=> ! [R2: set @ ( product_prod @ B @ B ),F2: B > A] :
( ! [A7: B,B5: B] :
( ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ A7 @ B5 ) @ R2 )
=> ( ord_less @ A @ ( F2 @ B5 ) @ ( F2 @ A7 ) ) )
=> ( transitive_acyclic @ B @ R2 ) ) ) ).
% acyclicI_order
thf(fact_7412_last__zip,axiom,
! [A: $tType,B: $tType,Xs: list @ A,Ys: list @ B] :
( ( Xs
!= ( nil @ A ) )
=> ( ( Ys
!= ( nil @ B ) )
=> ( ( ( size_size @ ( list @ A ) @ Xs )
= ( size_size @ ( list @ B ) @ Ys ) )
=> ( ( last @ ( product_prod @ A @ B ) @ ( zip @ A @ B @ Xs @ Ys ) )
= ( product_Pair @ A @ B @ ( last @ A @ Xs ) @ ( last @ B @ Ys ) ) ) ) ) ) ).
% last_zip
thf(fact_7413_acyclicI,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ! [X5: A] :
~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ X5 ) @ ( transitive_trancl @ A @ R2 ) )
=> ( transitive_acyclic @ A @ R2 ) ) ).
% acyclicI
thf(fact_7414_acyclic__def,axiom,
! [A: $tType] :
( ( transitive_acyclic @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
! [X2: A] :
~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ X2 ) @ ( transitive_trancl @ A @ R4 ) ) ) ) ).
% acyclic_def
thf(fact_7415_wf__set,axiom,
! [A: $tType,Xs: list @ ( product_prod @ A @ A )] :
( ( wf @ A @ ( set2 @ ( product_prod @ A @ A ) @ Xs ) )
= ( transitive_acyclic @ A @ ( set2 @ ( product_prod @ A @ A ) @ Xs ) ) ) ).
% wf_set
thf(fact_7416_takeWhile__not__last,axiom,
! [A: $tType,Xs: list @ A] :
( ( distinct @ A @ Xs )
=> ( ( takeWhile @ A
@ ^ [Y2: A] :
( Y2
!= ( last @ A @ Xs ) )
@ Xs )
= ( butlast @ A @ Xs ) ) ) ).
% takeWhile_not_last
thf(fact_7417_snoc__eq__iff__butlast,axiom,
! [A: $tType,Xs: list @ A,X: A,Ys: list @ A] :
( ( ( append @ A @ Xs @ ( cons @ A @ X @ ( nil @ A ) ) )
= Ys )
= ( ( Ys
!= ( nil @ A ) )
& ( ( butlast @ A @ Ys )
= Xs )
& ( ( last @ A @ Ys )
= X ) ) ) ).
% snoc_eq_iff_butlast
thf(fact_7418_remdups__adj__append_H,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( ( Xs
= ( nil @ A ) )
| ( Ys
= ( nil @ A ) )
| ( ( last @ A @ Xs )
!= ( hd @ A @ Ys ) ) )
=> ( ( remdups_adj @ A @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ ( remdups_adj @ A @ Xs ) @ ( remdups_adj @ A @ Ys ) ) ) ) ).
% remdups_adj_append'
thf(fact_7419_remdups__adj__append_H_H,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( remdups_adj @ A @ ( append @ A @ Xs @ Ys ) )
= ( append @ A @ ( remdups_adj @ A @ Xs )
@ ( remdups_adj @ A
@ ( dropWhile @ A
@ ^ [Y2: A] :
( Y2
= ( last @ A @ Xs ) )
@ Ys ) ) ) ) ) ).
% remdups_adj_append''
thf(fact_7420_last__conv__nth,axiom,
! [A: $tType,Xs: list @ A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( last @ A @ Xs )
= ( nth @ A @ Xs @ ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) ) ) ) ) ).
% last_conv_nth
thf(fact_7421_last__list__update,axiom,
! [A: $tType,Xs: list @ A,K: nat,X: A] :
( ( Xs
!= ( nil @ A ) )
=> ( ( ( K
= ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) ) )
=> ( ( last @ A @ ( list_update @ A @ Xs @ K @ X ) )
= X ) )
& ( ( K
!= ( minus_minus @ nat @ ( size_size @ ( list @ A ) @ Xs ) @ ( one_one @ nat ) ) )
=> ( ( last @ A @ ( list_update @ A @ Xs @ K @ X ) )
= ( last @ A @ Xs ) ) ) ) ) ).
% last_list_update
thf(fact_7422_set__rec,axiom,
! [A: $tType] :
( ( set2 @ A )
= ( rec_list @ ( set @ A ) @ A @ ( bot_bot @ ( set @ A ) )
@ ^ [X2: A,Uu3: list @ A] : ( insert2 @ A @ X2 ) ) ) ).
% set_rec
thf(fact_7423_numeral__xor__num,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [M: num,N2: num] :
( ( bit_se5824344971392196577ns_xor @ A @ ( numeral_numeral @ A @ M ) @ ( numeral_numeral @ A @ N2 ) )
= ( case_option @ A @ num @ ( zero_zero @ A ) @ ( numeral_numeral @ A ) @ ( bit_un2480387367778600638or_num @ M @ N2 ) ) ) ) ).
% numeral_xor_num
thf(fact_7424_numeral__and__num,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [M: num,N2: num] :
( ( bit_se5824344872417868541ns_and @ A @ ( numeral_numeral @ A @ M ) @ ( numeral_numeral @ A @ N2 ) )
= ( case_option @ A @ num @ ( zero_zero @ A ) @ ( numeral_numeral @ A ) @ ( bit_un7362597486090784418nd_num @ M @ N2 ) ) ) ) ).
% numeral_and_num
thf(fact_7425_and__num__eq__None__iff,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [M: num,N2: num] :
( ( ( bit_un7362597486090784418nd_num @ M @ N2 )
= ( none @ num ) )
= ( ( bit_se5824344872417868541ns_and @ A @ ( numeral_numeral @ A @ M ) @ ( numeral_numeral @ A @ N2 ) )
= ( zero_zero @ A ) ) ) ) ).
% and_num_eq_None_iff
thf(fact_7426_xor__num__eq__None__iff,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [M: num,N2: num] :
( ( ( bit_un2480387367778600638or_num @ M @ N2 )
= ( none @ num ) )
= ( ( bit_se5824344971392196577ns_xor @ A @ ( numeral_numeral @ A @ M ) @ ( numeral_numeral @ A @ N2 ) )
= ( zero_zero @ A ) ) ) ) ).
% xor_num_eq_None_iff
thf(fact_7427_Gcd__fin__0__iff,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [A4: set @ A] :
( ( ( semiring_gcd_Gcd_fin @ A @ A4 )
= ( zero_zero @ A ) )
= ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( insert2 @ A @ ( zero_zero @ A ) @ ( bot_bot @ ( set @ A ) ) ) )
& ( finite_finite @ A @ A4 ) ) ) ) ).
% Gcd_fin_0_iff
thf(fact_7428_connected__closedD,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S: set @ A,A4: set @ A,B3: set @ A] :
( ( topolo1966860045006549960nected @ A @ S )
=> ( ( ( inf_inf @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) @ S )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ S @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
=> ( ( topolo7761053866217962861closed @ A @ A4 )
=> ( ( topolo7761053866217962861closed @ A @ B3 )
=> ( ( ( inf_inf @ ( set @ A ) @ A4 @ S )
= ( bot_bot @ ( set @ A ) ) )
| ( ( inf_inf @ ( set @ A ) @ B3 @ S )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ).
% connected_closedD
thf(fact_7429_Gcd__fin_Oempty,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ( ( semiring_gcd_Gcd_fin @ A @ ( bot_bot @ ( set @ A ) ) )
= ( zero_zero @ A ) ) ) ).
% Gcd_fin.empty
thf(fact_7430_connected__Times__eq,axiom,
! [A: $tType,B: $tType] :
( ( ( topolo4958980785337419405_space @ B )
& ( topolo4958980785337419405_space @ A ) )
=> ! [S3: set @ A,T4: set @ B] :
( ( topolo1966860045006549960nected @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ S3
@ ^ [Uu3: A] : T4 ) )
= ( ( S3
= ( bot_bot @ ( set @ A ) ) )
| ( T4
= ( bot_bot @ ( set @ B ) ) )
| ( ( topolo1966860045006549960nected @ A @ S3 )
& ( topolo1966860045006549960nected @ B @ T4 ) ) ) ) ) ).
% connected_Times_eq
thf(fact_7431_connected__sing,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [X: A] : ( topolo1966860045006549960nected @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% connected_sing
thf(fact_7432_connected__empty,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ( topolo1966860045006549960nected @ A @ ( bot_bot @ ( set @ A ) ) ) ) ).
% connected_empty
thf(fact_7433_dvd__gcd__list__iff,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [B2: A,Xs: list @ A] :
( ( dvd_dvd @ A @ B2 @ ( semiring_gcd_Gcd_fin @ A @ ( set2 @ A @ Xs ) ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ( dvd_dvd @ A @ B2 @ X2 ) ) ) ) ) ).
% dvd_gcd_list_iff
thf(fact_7434_gcd__list__greatest,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [Bs: list @ A,A3: A] :
( ! [B5: A] :
( ( member2 @ A @ B5 @ ( set2 @ A @ Bs ) )
=> ( dvd_dvd @ A @ A3 @ B5 ) )
=> ( dvd_dvd @ A @ A3 @ ( semiring_gcd_Gcd_fin @ A @ ( set2 @ A @ Bs ) ) ) ) ) ).
% gcd_list_greatest
thf(fact_7435_connected__contains__Icc,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [A4: set @ A,A3: A,B2: A] :
( ( topolo1966860045006549960nected @ A @ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( ( member2 @ A @ B2 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ ( set_or1337092689740270186AtMost @ A @ A3 @ B2 ) @ A4 ) ) ) ) ) ).
% connected_contains_Icc
thf(fact_7436_connected__iff__interval,axiom,
! [A: $tType] :
( ( topolo8458572112393995274pology @ A )
=> ( ( topolo1966860045006549960nected @ A )
= ( ^ [U5: set @ A] :
! [X2: A] :
( ( member2 @ A @ X2 @ U5 )
=> ! [Y2: A] :
( ( member2 @ A @ Y2 @ U5 )
=> ! [Z6: A] :
( ( ord_less_eq @ A @ X2 @ Z6 )
=> ( ( ord_less_eq @ A @ Z6 @ Y2 )
=> ( member2 @ A @ Z6 @ U5 ) ) ) ) ) ) ) ) ).
% connected_iff_interval
thf(fact_7437_connectedI__interval,axiom,
! [A: $tType] :
( ( topolo8458572112393995274pology @ A )
=> ! [U3: set @ A] :
( ! [X5: A,Y4: A,Z2: A] :
( ( member2 @ A @ X5 @ U3 )
=> ( ( member2 @ A @ Y4 @ U3 )
=> ( ( ord_less_eq @ A @ X5 @ Z2 )
=> ( ( ord_less_eq @ A @ Z2 @ Y4 )
=> ( member2 @ A @ Z2 @ U3 ) ) ) ) )
=> ( topolo1966860045006549960nected @ A @ U3 ) ) ) ).
% connectedI_interval
thf(fact_7438_connectedD__interval,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [U3: set @ A,X: A,Y: A,Z: A] :
( ( topolo1966860045006549960nected @ A @ U3 )
=> ( ( member2 @ A @ X @ U3 )
=> ( ( member2 @ A @ Y @ U3 )
=> ( ( ord_less_eq @ A @ X @ Z )
=> ( ( ord_less_eq @ A @ Z @ Y )
=> ( member2 @ A @ Z @ U3 ) ) ) ) ) ) ) ).
% connectedD_interval
thf(fact_7439_connected__contains__Ioo,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [A4: set @ A,A3: A,B2: A] :
( ( topolo1966860045006549960nected @ A @ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( ( member2 @ A @ B2 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ ( set_or5935395276787703475ssThan @ A @ A3 @ B2 ) @ A4 ) ) ) ) ) ).
% connected_contains_Ioo
thf(fact_7440_connected__Un,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S: set @ A,T2: set @ A] :
( ( topolo1966860045006549960nected @ A @ S )
=> ( ( topolo1966860045006549960nected @ A @ T2 )
=> ( ( ( inf_inf @ ( set @ A ) @ S @ T2 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( topolo1966860045006549960nected @ A @ ( sup_sup @ ( set @ A ) @ S @ T2 ) ) ) ) ) ) ).
% connected_Un
thf(fact_7441_connected__Union,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S3: set @ ( set @ A )] :
( ! [S2: set @ A] :
( ( member2 @ ( set @ A ) @ S2 @ S3 )
=> ( topolo1966860045006549960nected @ A @ S2 ) )
=> ( ( ( complete_Inf_Inf @ ( set @ A ) @ S3 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( topolo1966860045006549960nected @ A @ ( complete_Sup_Sup @ ( set @ A ) @ S3 ) ) ) ) ) ).
% connected_Union
thf(fact_7442_not__in__connected__cases,axiom,
! [A: $tType] :
( ( topolo1944317154257567458pology @ A )
=> ! [S3: set @ A,X: A] :
( ( topolo1966860045006549960nected @ A @ S3 )
=> ( ~ ( member2 @ A @ X @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ( condit941137186595557371_above @ A @ S3 )
=> ~ ! [Y3: A] :
( ( member2 @ A @ Y3 @ S3 )
=> ( ord_less_eq @ A @ Y3 @ X ) ) )
=> ~ ( ( condit1013018076250108175_below @ A @ S3 )
=> ~ ! [Y3: A] :
( ( member2 @ A @ Y3 @ S3 )
=> ( ord_less_eq @ A @ X @ Y3 ) ) ) ) ) ) ) ) ).
% not_in_connected_cases
thf(fact_7443_connected__diff__open__from__closed,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [S: set @ A,T2: set @ A,U: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ S @ T2 )
=> ( ( ord_less_eq @ ( set @ A ) @ T2 @ U )
=> ( ( topolo1002775350975398744n_open @ A @ S )
=> ( ( topolo7761053866217962861closed @ A @ T2 )
=> ( ( topolo1966860045006549960nected @ A @ U )
=> ( ( topolo1966860045006549960nected @ A @ ( minus_minus @ ( set @ A ) @ T2 @ S ) )
=> ( topolo1966860045006549960nected @ A @ ( minus_minus @ ( set @ A ) @ U @ S ) ) ) ) ) ) ) ) ) ).
% connected_diff_open_from_closed
thf(fact_7444_connectedD,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [A4: set @ A,U3: set @ A,V: set @ A] :
( ( topolo1966860045006549960nected @ A @ A4 )
=> ( ( topolo1002775350975398744n_open @ A @ U3 )
=> ( ( topolo1002775350975398744n_open @ A @ V )
=> ( ( ( inf_inf @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ U3 @ V ) @ A4 )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( sup_sup @ ( set @ A ) @ U3 @ V ) )
=> ( ( ( inf_inf @ ( set @ A ) @ U3 @ A4 )
= ( bot_bot @ ( set @ A ) ) )
| ( ( inf_inf @ ( set @ A ) @ V @ A4 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ).
% connectedD
thf(fact_7445_connectedI,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ! [U3: set @ A] :
( ! [A9: set @ A] :
( ( topolo1002775350975398744n_open @ A @ A9 )
=> ! [B8: set @ A] :
( ( topolo1002775350975398744n_open @ A @ B8 )
=> ( ( ( inf_inf @ ( set @ A ) @ A9 @ U3 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ( inf_inf @ ( set @ A ) @ B8 @ U3 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ( inf_inf @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ A9 @ B8 ) @ U3 )
= ( bot_bot @ ( set @ A ) ) )
=> ~ ( ord_less_eq @ ( set @ A ) @ U3 @ ( sup_sup @ ( set @ A ) @ A9 @ B8 ) ) ) ) ) ) )
=> ( topolo1966860045006549960nected @ A @ U3 ) ) ) ).
% connectedI
thf(fact_7446_connected__def,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ( ( topolo1966860045006549960nected @ A )
= ( ^ [S8: set @ A] :
~ ? [A6: set @ A,B6: set @ A] :
( ( topolo1002775350975398744n_open @ A @ A6 )
& ( topolo1002775350975398744n_open @ A @ B6 )
& ( ord_less_eq @ ( set @ A ) @ S8 @ ( sup_sup @ ( set @ A ) @ A6 @ B6 ) )
& ( ( inf_inf @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ A6 @ B6 ) @ S8 )
= ( bot_bot @ ( set @ A ) ) )
& ( ( inf_inf @ ( set @ A ) @ A6 @ S8 )
!= ( bot_bot @ ( set @ A ) ) )
& ( ( inf_inf @ ( set @ A ) @ B6 @ S8 )
!= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% connected_def
thf(fact_7447_connected__closed,axiom,
! [A: $tType] :
( ( topolo4958980785337419405_space @ A )
=> ( ( topolo1966860045006549960nected @ A )
= ( ^ [S7: set @ A] :
~ ? [A6: set @ A,B6: set @ A] :
( ( topolo7761053866217962861closed @ A @ A6 )
& ( topolo7761053866217962861closed @ A @ B6 )
& ( ord_less_eq @ ( set @ A ) @ S7 @ ( sup_sup @ ( set @ A ) @ A6 @ B6 ) )
& ( ( inf_inf @ ( set @ A ) @ ( inf_inf @ ( set @ A ) @ A6 @ B6 ) @ S7 )
= ( bot_bot @ ( set @ A ) ) )
& ( ( inf_inf @ ( set @ A ) @ A6 @ S7 )
!= ( bot_bot @ ( set @ A ) ) )
& ( ( inf_inf @ ( set @ A ) @ B6 @ S7 )
!= ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ).
% connected_closed
thf(fact_7448_irreflp__irrefl__eq,axiom,
! [A: $tType,R: set @ ( product_prod @ A @ A )] :
( ( irreflp @ A
@ ^ [A5: A,B4: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A5 @ B4 ) @ R ) )
= ( irrefl @ A @ R ) ) ).
% irreflp_irrefl_eq
thf(fact_7449_disjnt__equiv__class,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( equiv_equiv @ A @ A4 @ R2 )
=> ( ( disjnt @ A @ ( image @ A @ A @ R2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) @ ( image @ A @ A @ R2 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 ) ) ) ) ).
% disjnt_equiv_class
thf(fact_7450_disjnt__self__iff__empty,axiom,
! [A: $tType,S3: set @ A] :
( ( disjnt @ A @ S3 @ S3 )
= ( S3
= ( bot_bot @ ( set @ A ) ) ) ) ).
% disjnt_self_iff_empty
thf(fact_7451_disjnt__Times1__iff,axiom,
! [A: $tType,B: $tType,C5: set @ A,A4: set @ B,B3: set @ B] :
( ( disjnt @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ C5
@ ^ [Uu3: A] : A4 )
@ ( product_Sigma @ A @ B @ C5
@ ^ [Uu3: A] : B3 ) )
= ( ( C5
= ( bot_bot @ ( set @ A ) ) )
| ( disjnt @ B @ A4 @ B3 ) ) ) ).
% disjnt_Times1_iff
thf(fact_7452_disjnt__Times2__iff,axiom,
! [B: $tType,A: $tType,A4: set @ A,C5: set @ B,B3: set @ A] :
( ( disjnt @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : C5 )
@ ( product_Sigma @ A @ B @ B3
@ ^ [Uu3: A] : C5 ) )
= ( ( C5
= ( bot_bot @ ( set @ B ) ) )
| ( disjnt @ A @ A4 @ B3 ) ) ) ).
% disjnt_Times2_iff
thf(fact_7453_disjnt__Sigma__iff,axiom,
! [B: $tType,A: $tType,A4: set @ A,C5: A > ( set @ B ),B3: set @ A] :
( ( disjnt @ ( product_prod @ A @ B ) @ ( product_Sigma @ A @ B @ A4 @ C5 ) @ ( product_Sigma @ A @ B @ B3 @ C5 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( inf_inf @ ( set @ A ) @ A4 @ B3 ) )
=> ( ( C5 @ X2 )
= ( bot_bot @ ( set @ B ) ) ) )
| ( disjnt @ A @ A4 @ B3 ) ) ) ).
% disjnt_Sigma_iff
thf(fact_7454_disjnt__def,axiom,
! [A: $tType] :
( ( disjnt @ A )
= ( ^ [A6: set @ A,B6: set @ A] :
( ( inf_inf @ ( set @ A ) @ A6 @ B6 )
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% disjnt_def
thf(fact_7455_disjnt__subset1,axiom,
! [A: $tType,X7: set @ A,Y6: set @ A,Z5: set @ A] :
( ( disjnt @ A @ X7 @ Y6 )
=> ( ( ord_less_eq @ ( set @ A ) @ Z5 @ X7 )
=> ( disjnt @ A @ Z5 @ Y6 ) ) ) ).
% disjnt_subset1
thf(fact_7456_disjnt__subset2,axiom,
! [A: $tType,X7: set @ A,Y6: set @ A,Z5: set @ A] :
( ( disjnt @ A @ X7 @ Y6 )
=> ( ( ord_less_eq @ ( set @ A ) @ Z5 @ Y6 )
=> ( disjnt @ A @ X7 @ Z5 ) ) ) ).
% disjnt_subset2
thf(fact_7457_irreflp__less,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( irreflp @ A @ ( ord_less @ A ) ) ) ).
% irreflp_less
thf(fact_7458_disjnt__empty1,axiom,
! [A: $tType,A4: set @ A] : ( disjnt @ A @ ( bot_bot @ ( set @ A ) ) @ A4 ) ).
% disjnt_empty1
thf(fact_7459_disjnt__empty2,axiom,
! [A: $tType,A4: set @ A] : ( disjnt @ A @ A4 @ ( bot_bot @ ( set @ A ) ) ) ).
% disjnt_empty2
thf(fact_7460_irreflp__greater,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( irreflp @ A
@ ^ [X2: A,Y2: A] : ( ord_less @ A @ Y2 @ X2 ) ) ) ).
% irreflp_greater
thf(fact_7461_disjnt__ge__max,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Y6: set @ A,X7: set @ A] :
( ( finite_finite @ A @ Y6 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ X7 )
=> ( ord_less @ A @ ( lattic643756798349783984er_Max @ A @ Y6 ) @ X5 ) )
=> ( disjnt @ A @ X7 @ Y6 ) ) ) ) ).
% disjnt_ge_max
thf(fact_7462_card__Un__disjnt,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ A @ B3 )
=> ( ( disjnt @ A @ A4 @ B3 )
=> ( ( finite_card @ A @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( plus_plus @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ A @ B3 ) ) ) ) ) ) ).
% card_Un_disjnt
thf(fact_7463_infinite__infinite__partition,axiom,
! [A: $tType,A4: set @ A] :
( ~ ( finite_finite @ A @ A4 )
=> ~ ! [C6: nat > ( set @ A )] :
( ( pairwise @ nat
@ ^ [I5: nat,J3: nat] : ( disjnt @ A @ ( C6 @ I5 ) @ ( C6 @ J3 ) )
@ ( top_top @ ( set @ nat ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ ( image2 @ nat @ ( set @ A ) @ C6 @ ( top_top @ ( set @ nat ) ) ) ) @ A4 )
=> ~ ! [I4: nat] :
~ ( finite_finite @ A @ ( C6 @ I4 ) ) ) ) ) ).
% infinite_infinite_partition
thf(fact_7464_init__seg__of__def,axiom,
! [A: $tType] :
( ( init_seg_of @ A )
= ( collect @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) )
@ ( product_case_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) @ $o
@ ^ [R4: set @ ( product_prod @ A @ A ),S7: set @ ( product_prod @ A @ A )] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ A ) ) @ R4 @ S7 )
& ! [A5: A,B4: A,C3: A] :
( ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A5 @ B4 ) @ S7 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B4 @ C3 ) @ R4 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A5 @ B4 ) @ R4 ) ) ) ) ) ) ).
% init_seg_of_def
thf(fact_7465_pairwise__singleton,axiom,
! [A: $tType,P2: A > A > $o,A4: A] : ( pairwise @ A @ P2 @ ( insert2 @ A @ A4 @ ( bot_bot @ ( set @ A ) ) ) ) ).
% pairwise_singleton
thf(fact_7466_pairwise__empty,axiom,
! [A: $tType,P2: A > A > $o] : ( pairwise @ A @ P2 @ ( bot_bot @ ( set @ A ) ) ) ).
% pairwise_empty
thf(fact_7467_pairwise__subset,axiom,
! [A: $tType,P2: A > A > $o,S3: set @ A,T4: set @ A] :
( ( pairwise @ A @ P2 @ S3 )
=> ( ( ord_less_eq @ ( set @ A ) @ T4 @ S3 )
=> ( pairwise @ A @ P2 @ T4 ) ) ) ).
% pairwise_subset
thf(fact_7468_pairwise__mono,axiom,
! [A: $tType,P2: A > A > $o,A4: set @ A,Q: A > A > $o,B3: set @ A] :
( ( pairwise @ A @ P2 @ A4 )
=> ( ! [X5: A,Y4: A] :
( ( P2 @ X5 @ Y4 )
=> ( Q @ X5 @ Y4 ) )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( pairwise @ A @ Q @ B3 ) ) ) ) ).
% pairwise_mono
thf(fact_7469_pairwise__alt,axiom,
! [A: $tType] :
( ( pairwise @ A )
= ( ^ [R5: A > A > $o,S8: set @ A] :
! [X2: A] :
( ( member2 @ A @ X2 @ S8 )
=> ! [Y2: A] :
( ( member2 @ A @ Y2 @ ( minus_minus @ ( set @ A ) @ S8 @ ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( R5 @ X2 @ Y2 ) ) ) ) ) ).
% pairwise_alt
thf(fact_7470_map__tailrec__rev,axiom,
! [A: $tType,B: $tType] :
( ( map_tailrec_rev @ B @ A )
= ( ^ [F3: B > A,As5: list @ B] : ( append @ A @ ( rev @ A @ ( map @ B @ A @ F3 @ As5 ) ) ) ) ) ).
% map_tailrec_rev
thf(fact_7471_insort__insert__key__def,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ( ( linord329482645794927042rt_key @ B @ A )
= ( ^ [F3: B > A,X2: B,Xs2: list @ B] : ( if @ ( list @ B ) @ ( member2 @ A @ ( F3 @ X2 ) @ ( image2 @ B @ A @ F3 @ ( set2 @ B @ Xs2 ) ) ) @ Xs2 @ ( linorder_insort_key @ B @ A @ F3 @ X2 @ Xs2 ) ) ) ) ) ).
% insort_insert_key_def
thf(fact_7472_distinct__insort__insert,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ B,F2: B > A,X: B] :
( ( distinct @ B @ Xs )
=> ( distinct @ B @ ( linord329482645794927042rt_key @ B @ A @ F2 @ X @ Xs ) ) ) ) ).
% distinct_insort_insert
thf(fact_7473_map__tailrec__rev_Osimps_I1_J,axiom,
! [A: $tType,B: $tType,F2: A > B,Bs: list @ B] :
( ( map_tailrec_rev @ A @ B @ F2 @ ( nil @ A ) @ Bs )
= Bs ) ).
% map_tailrec_rev.simps(1)
thf(fact_7474_map__tailrec__rev_Osimps_I2_J,axiom,
! [A: $tType,B: $tType,F2: A > B,A3: A,As: list @ A,Bs: list @ B] :
( ( map_tailrec_rev @ A @ B @ F2 @ ( cons @ A @ A3 @ As ) @ Bs )
= ( map_tailrec_rev @ A @ B @ F2 @ As @ ( cons @ B @ ( F2 @ A3 ) @ Bs ) ) ) ).
% map_tailrec_rev.simps(2)
thf(fact_7475_insort__insert__triv,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Xs: list @ A] :
( ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( linord329482645794927042rt_key @ A @ A
@ ^ [X2: A] : X2
@ X
@ Xs )
= Xs ) ) ) ).
% insort_insert_triv
thf(fact_7476_insort__insert__key__triv,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,X: B,Xs: list @ B] :
( ( member2 @ A @ ( F2 @ X ) @ ( image2 @ B @ A @ F2 @ ( set2 @ B @ Xs ) ) )
=> ( ( linord329482645794927042rt_key @ B @ A @ F2 @ X @ Xs )
= Xs ) ) ) ).
% insort_insert_key_triv
thf(fact_7477_map__tailrec__rev_Oelims,axiom,
! [A: $tType,B: $tType,X: A > B,Xa2: list @ A,Xb: list @ B,Y: list @ B] :
( ( ( map_tailrec_rev @ A @ B @ X @ Xa2 @ Xb )
= Y )
=> ( ( ( Xa2
= ( nil @ A ) )
=> ( Y != Xb ) )
=> ~ ! [A7: A,As2: list @ A] :
( ( Xa2
= ( cons @ A @ A7 @ As2 ) )
=> ( Y
!= ( map_tailrec_rev @ A @ B @ X @ As2 @ ( cons @ B @ ( X @ A7 ) @ Xb ) ) ) ) ) ) ).
% map_tailrec_rev.elims
thf(fact_7478_disjoint__image__subset,axiom,
! [A: $tType,A27: set @ ( set @ A ),F2: ( set @ A ) > ( set @ A )] :
( ( pairwise @ ( set @ A ) @ ( disjnt @ A ) @ A27 )
=> ( ! [X9: set @ A] :
( ( member2 @ ( set @ A ) @ X9 @ A27 )
=> ( ord_less_eq @ ( set @ A ) @ ( F2 @ X9 ) @ X9 ) )
=> ( pairwise @ ( set @ A ) @ ( disjnt @ A ) @ ( image2 @ ( set @ A ) @ ( set @ A ) @ F2 @ A27 ) ) ) ) ).
% disjoint_image_subset
thf(fact_7479_set__insort__insert,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Xs: list @ A] :
( ( set2 @ A
@ ( linord329482645794927042rt_key @ A @ A
@ ^ [X2: A] : X2
@ X
@ Xs ) )
= ( insert2 @ A @ X @ ( set2 @ A @ Xs ) ) ) ) ).
% set_insort_insert
thf(fact_7480_sorted__insort__insert,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [Xs: list @ A,X: A] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ Xs )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A )
@ ( linord329482645794927042rt_key @ A @ A
@ ^ [X2: A] : X2
@ X
@ Xs ) ) ) ) ).
% sorted_insort_insert
thf(fact_7481_insort__insert__insort,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [X: A,Xs: list @ A] :
( ~ ( member2 @ A @ X @ ( set2 @ A @ Xs ) )
=> ( ( linord329482645794927042rt_key @ A @ A
@ ^ [X2: A] : X2
@ X
@ Xs )
= ( linorder_insort_key @ A @ A
@ ^ [X2: A] : X2
@ X
@ Xs ) ) ) ) ).
% insort_insert_insort
thf(fact_7482_sorted__insort__insert__key,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,Xs: list @ B,X: B] :
( ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ Xs ) )
=> ( sorted_wrt @ A @ ( ord_less_eq @ A ) @ ( map @ B @ A @ F2 @ ( linord329482645794927042rt_key @ B @ A @ F2 @ X @ Xs ) ) ) ) ) ).
% sorted_insort_insert_key
thf(fact_7483_insort__insert__insort__key,axiom,
! [A: $tType,B: $tType] :
( ( linorder @ A )
=> ! [F2: B > A,X: B,Xs: list @ B] :
( ~ ( member2 @ A @ ( F2 @ X ) @ ( image2 @ B @ A @ F2 @ ( set2 @ B @ Xs ) ) )
=> ( ( linord329482645794927042rt_key @ B @ A @ F2 @ X @ Xs )
= ( linorder_insort_key @ B @ A @ F2 @ X @ Xs ) ) ) ) ).
% insort_insert_insort_key
thf(fact_7484_map__tailrec__def,axiom,
! [B: $tType,A: $tType] :
( ( map_tailrec @ A @ B )
= ( ^ [F3: A > B,As5: list @ A] : ( rev @ B @ ( map_tailrec_rev @ A @ B @ F3 @ As5 @ ( nil @ B ) ) ) ) ) ).
% map_tailrec_def
thf(fact_7485_differentiable__cmult__left__iff,axiom,
! [A: $tType,B: $tType] :
( ( ( real_V822414075346904944vector @ B )
& ( real_V3459762299906320749_field @ A ) )
=> ! [C2: A,Q2: B > A,T2: B] :
( ( differentiable @ B @ A
@ ^ [T3: B] : ( times_times @ A @ C2 @ ( Q2 @ T3 ) )
@ ( topolo174197925503356063within @ B @ T2 @ ( top_top @ ( set @ B ) ) ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( differentiable @ B @ A @ Q2 @ ( topolo174197925503356063within @ B @ T2 @ ( top_top @ ( set @ B ) ) ) ) ) ) ) ).
% differentiable_cmult_left_iff
thf(fact_7486_differentiable__cmult__right__iff,axiom,
! [A: $tType,B: $tType] :
( ( ( real_V822414075346904944vector @ B )
& ( real_V3459762299906320749_field @ A ) )
=> ! [Q2: B > A,C2: A,T2: B] :
( ( differentiable @ B @ A
@ ^ [T3: B] : ( times_times @ A @ ( Q2 @ T3 ) @ C2 )
@ ( topolo174197925503356063within @ B @ T2 @ ( top_top @ ( set @ B ) ) ) )
= ( ( C2
= ( zero_zero @ A ) )
| ( differentiable @ B @ A @ Q2 @ ( topolo174197925503356063within @ B @ T2 @ ( top_top @ ( set @ B ) ) ) ) ) ) ) ).
% differentiable_cmult_right_iff
thf(fact_7487_differentiable__add,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,F5: filter @ A,G: A > B] :
( ( differentiable @ A @ B @ F2 @ F5 )
=> ( ( differentiable @ A @ B @ G @ F5 )
=> ( differentiable @ A @ B
@ ^ [X2: A] : ( plus_plus @ B @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ F5 ) ) ) ) ).
% differentiable_add
thf(fact_7488_differentiable__within__subset,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [F2: A > B,X: A,S: set @ A,T2: set @ A] :
( ( differentiable @ A @ B @ F2 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ord_less_eq @ ( set @ A ) @ T2 @ S )
=> ( differentiable @ A @ B @ F2 @ ( topolo174197925503356063within @ A @ X @ T2 ) ) ) ) ) ).
% differentiable_within_subset
thf(fact_7489_differentiable__divide,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V3459762299906320749_field @ B ) )
=> ! [F2: A > B,X: A,S: set @ A,G: A > B] :
( ( differentiable @ A @ B @ F2 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( differentiable @ A @ B @ G @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ( G @ X )
!= ( zero_zero @ B ) )
=> ( differentiable @ A @ B
@ ^ [X2: A] : ( divide_divide @ B @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ) ).
% differentiable_divide
thf(fact_7490_differentiable__inverse,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V3459762299906320749_field @ B ) )
=> ! [F2: A > B,X: A,S: set @ A] :
( ( differentiable @ A @ B @ F2 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ( F2 @ X )
!= ( zero_zero @ B ) )
=> ( differentiable @ A @ B
@ ^ [X2: A] : ( inverse_inverse @ B @ ( F2 @ X2 ) )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ).
% differentiable_inverse
thf(fact_7491_differentiable__power__int,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V3459762299906320749_field @ B ) )
=> ! [F2: A > B,X: A,S: set @ A,N2: int] :
( ( differentiable @ A @ B @ F2 @ ( topolo174197925503356063within @ A @ X @ S ) )
=> ( ( ( F2 @ X )
!= ( zero_zero @ B ) )
=> ( differentiable @ A @ B
@ ^ [X2: A] : ( power_int @ B @ ( F2 @ X2 ) @ N2 )
@ ( topolo174197925503356063within @ A @ X @ S ) ) ) ) ) ).
% differentiable_power_int
thf(fact_7492_map__eq__map__tailrec,axiom,
! [B: $tType,A: $tType] :
( ( map @ A @ B )
= ( map_tailrec @ A @ B ) ) ).
% map_eq_map_tailrec
thf(fact_7493_arg__min__inj__eq,axiom,
! [B: $tType,A: $tType] :
( ( order @ B )
=> ! [F2: A > B,P2: A > $o,A3: A] :
( ( inj_on @ A @ B @ F2 @ ( collect @ A @ P2 ) )
=> ( ( P2 @ A3 )
=> ( ! [Y4: A] :
( ( P2 @ Y4 )
=> ( ord_less_eq @ B @ ( F2 @ A3 ) @ ( F2 @ Y4 ) ) )
=> ( ( lattices_ord_arg_min @ A @ B @ F2 @ P2 )
= A3 ) ) ) ) ) ).
% arg_min_inj_eq
thf(fact_7494_concat__map__maps,axiom,
! [A: $tType,B: $tType,F2: B > ( list @ A ),Xs: list @ B] :
( ( concat @ A @ ( map @ B @ ( list @ A ) @ F2 @ Xs ) )
= ( maps @ B @ A @ F2 @ Xs ) ) ).
% concat_map_maps
thf(fact_7495_arg__min__nat__lemma,axiom,
! [A: $tType,P2: A > $o,K: A,M: A > nat] :
( ( P2 @ K )
=> ( ( P2 @ ( lattices_ord_arg_min @ A @ nat @ M @ P2 ) )
& ! [Y3: A] :
( ( P2 @ Y3 )
=> ( ord_less_eq @ nat @ ( M @ ( lattices_ord_arg_min @ A @ nat @ M @ P2 ) ) @ ( M @ Y3 ) ) ) ) ) ).
% arg_min_nat_lemma
thf(fact_7496_arg__min__nat__le,axiom,
! [A: $tType,P2: A > $o,X: A,M: A > nat] :
( ( P2 @ X )
=> ( ord_less_eq @ nat @ ( M @ ( lattices_ord_arg_min @ A @ nat @ M @ P2 ) ) @ ( M @ X ) ) ) ).
% arg_min_nat_le
thf(fact_7497_arg__min__equality,axiom,
! [A: $tType,C: $tType] :
( ( order @ A )
=> ! [P2: C > $o,K: C,F2: C > A] :
( ( P2 @ K )
=> ( ! [X5: C] :
( ( P2 @ X5 )
=> ( ord_less_eq @ A @ ( F2 @ K ) @ ( F2 @ X5 ) ) )
=> ( ( F2 @ ( lattices_ord_arg_min @ C @ A @ F2 @ P2 ) )
= ( F2 @ K ) ) ) ) ) ).
% arg_min_equality
thf(fact_7498_arg__minI,axiom,
! [B: $tType,A: $tType] :
( ( ord @ B )
=> ! [P2: A > $o,X: A,F2: A > B,Q: A > $o] :
( ( P2 @ X )
=> ( ! [Y4: A] :
( ( P2 @ Y4 )
=> ~ ( ord_less @ B @ ( F2 @ Y4 ) @ ( F2 @ X ) ) )
=> ( ! [X5: A] :
( ( P2 @ X5 )
=> ( ! [Y3: A] :
( ( P2 @ Y3 )
=> ~ ( ord_less @ B @ ( F2 @ Y3 ) @ ( F2 @ X5 ) ) )
=> ( Q @ X5 ) ) )
=> ( Q @ ( lattices_ord_arg_min @ A @ B @ F2 @ P2 ) ) ) ) ) ) ).
% arg_minI
thf(fact_7499_maps__simps_I2_J,axiom,
! [B: $tType,A: $tType,F2: B > ( list @ A )] :
( ( maps @ B @ A @ F2 @ ( nil @ B ) )
= ( nil @ A ) ) ).
% maps_simps(2)
thf(fact_7500_arg__min__on__def,axiom,
! [A: $tType,B: $tType] :
( ( ord @ A )
=> ( ( lattic7623131987881927897min_on @ B @ A )
= ( ^ [F3: B > A,S8: set @ B] :
( lattices_ord_arg_min @ B @ A @ F3
@ ^ [X2: B] : ( member2 @ B @ X2 @ S8 ) ) ) ) ) ).
% arg_min_on_def
thf(fact_7501_maps__simps_I1_J,axiom,
! [A: $tType,B: $tType,F2: B > ( list @ A ),X: B,Xs: list @ B] :
( ( maps @ B @ A @ F2 @ ( cons @ B @ X @ Xs ) )
= ( append @ A @ ( F2 @ X ) @ ( maps @ B @ A @ F2 @ Xs ) ) ) ).
% maps_simps(1)
thf(fact_7502_maps__def,axiom,
! [B: $tType,A: $tType] :
( ( maps @ A @ B )
= ( ^ [F3: A > ( list @ B ),Xs2: list @ A] : ( concat @ B @ ( map @ A @ ( list @ B ) @ F3 @ Xs2 ) ) ) ) ).
% maps_def
thf(fact_7503_in__measures_I2_J,axiom,
! [A: $tType,X: A,Y: A,F2: A > nat,Fs: list @ ( A > nat )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( measures @ A @ ( cons @ ( A > nat ) @ F2 @ Fs ) ) )
= ( ( ord_less @ nat @ ( F2 @ X ) @ ( F2 @ Y ) )
| ( ( ( F2 @ X )
= ( F2 @ Y ) )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( measures @ A @ Fs ) ) ) ) ) ).
% in_measures(2)
thf(fact_7504_Partial__order__eq__Image1__Image1__iff,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( order_7125193373082350890der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ B2 @ ( field2 @ A @ R2 ) )
=> ( ( ( image @ A @ A @ R2 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) )
= ( image @ A @ A @ R2 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( A3 = B2 ) ) ) ) ) ).
% Partial_order_eq_Image1_Image1_iff
thf(fact_7505_in__measures_I1_J,axiom,
! [A: $tType,X: A,Y: A] :
~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( measures @ A @ ( nil @ ( A > nat ) ) ) ) ).
% in_measures(1)
thf(fact_7506_arg__min__natI,axiom,
! [A: $tType,P2: A > $o,K: A,M: A > nat] :
( ( P2 @ K )
=> ( P2 @ ( lattices_ord_arg_min @ A @ nat @ M @ P2 ) ) ) ).
% arg_min_natI
thf(fact_7507_partial__order__on__empty,axiom,
! [A: $tType] : ( order_7125193373082350890der_on @ A @ ( bot_bot @ ( set @ A ) ) @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ).
% partial_order_on_empty
thf(fact_7508_wf__measures,axiom,
! [A: $tType,Fs: list @ ( A > nat )] : ( wf @ A @ ( measures @ A @ Fs ) ) ).
% wf_measures
thf(fact_7509_measures__less,axiom,
! [A: $tType,F2: A > nat,X: A,Y: A,Fs: list @ ( A > nat )] :
( ( ord_less @ nat @ ( F2 @ X ) @ ( F2 @ Y ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( measures @ A @ ( cons @ ( A > nat ) @ F2 @ Fs ) ) ) ) ).
% measures_less
thf(fact_7510_measures__lesseq,axiom,
! [A: $tType,F2: A > nat,X: A,Y: A,Fs: list @ ( A > nat )] :
( ( ord_less_eq @ nat @ ( F2 @ X ) @ ( F2 @ Y ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( measures @ A @ Fs ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( measures @ A @ ( cons @ ( A > nat ) @ F2 @ Fs ) ) ) ) ) ).
% measures_lesseq
thf(fact_7511_Zorns__po__lemma,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( order_7125193373082350890der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ! [C6: set @ A] :
( ( member2 @ ( set @ A ) @ C6 @ ( chains @ A @ R2 ) )
=> ? [X3: A] :
( ( member2 @ A @ X3 @ ( field2 @ A @ R2 ) )
& ! [Xa4: A] :
( ( member2 @ A @ Xa4 @ C6 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Xa4 @ X3 ) @ R2 ) ) ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ ( field2 @ A @ R2 ) )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Xa ) @ R2 )
=> ( Xa = X5 ) ) ) ) ) ) ).
% Zorns_po_lemma
thf(fact_7512_VEBT_Osimps_I7_J,axiom,
! [A: $tType,F1: ( option @ ( product_prod @ nat @ nat ) ) > nat > ( list @ ( product_prod @ vEBT_VEBT @ A ) ) > vEBT_VEBT > A > A,F22: $o > $o > A,X11: option @ ( product_prod @ nat @ nat ),X12: nat,X13: list @ vEBT_VEBT,X14: vEBT_VEBT] :
( ( vEBT_rec_VEBT @ A @ F1 @ F22 @ ( vEBT_Node @ X11 @ X12 @ X13 @ X14 ) )
= ( F1 @ X11 @ X12
@ ( map @ vEBT_VEBT @ ( product_prod @ vEBT_VEBT @ A )
@ ^ [VEBT: vEBT_VEBT] : ( product_Pair @ vEBT_VEBT @ A @ VEBT @ ( vEBT_rec_VEBT @ A @ F1 @ F22 @ VEBT ) )
@ X13 )
@ X14
@ ( vEBT_rec_VEBT @ A @ F1 @ F22 @ X14 ) ) ) ).
% VEBT.simps(7)
thf(fact_7513_Chains__def,axiom,
! [A: $tType] :
( ( chains @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
( collect @ ( set @ A )
@ ^ [C8: set @ A] :
! [X2: A] :
( ( member2 @ A @ X2 @ C8 )
=> ! [Y2: A] :
( ( member2 @ A @ Y2 @ C8 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R4 )
| ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y2 @ X2 ) @ R4 ) ) ) ) ) ) ) ).
% Chains_def
thf(fact_7514_Chains__relation__of,axiom,
! [A: $tType,C5: set @ A,P2: A > A > $o,A4: set @ A] :
( ( member2 @ ( set @ A ) @ C5 @ ( chains @ A @ ( order_relation_of @ A @ P2 @ A4 ) ) )
=> ( ord_less_eq @ ( set @ A ) @ C5 @ A4 ) ) ).
% Chains_relation_of
thf(fact_7515_Chains__subset_H,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( refl_on @ A @ ( top_top @ ( set @ A ) ) @ R2 )
=> ( ord_less_eq @ ( set @ ( set @ A ) )
@ ( collect @ ( set @ A )
@ ( pred_chain @ A @ ( top_top @ ( set @ A ) )
@ ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R2 ) ) )
@ ( chains @ A @ R2 ) ) ) ).
% Chains_subset'
thf(fact_7516_Chains__alt__def,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( refl_on @ A @ ( top_top @ ( set @ A ) ) @ R2 )
=> ( ( chains @ A @ R2 )
= ( collect @ ( set @ A )
@ ( pred_chain @ A @ ( top_top @ ( set @ A ) )
@ ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R2 ) ) ) ) ) ).
% Chains_alt_def
thf(fact_7517_pred__on_Ochain__empty,axiom,
! [A: $tType,A4: set @ A,P2: A > A > $o] : ( pred_chain @ A @ A4 @ P2 @ ( bot_bot @ ( set @ A ) ) ) ).
% pred_on.chain_empty
thf(fact_7518_subset_Ochain__empty,axiom,
! [A: $tType,A4: set @ ( set @ A )] : ( pred_chain @ ( set @ A ) @ A4 @ ( ord_less @ ( set @ A ) ) @ ( bot_bot @ ( set @ ( set @ A ) ) ) ) ).
% subset.chain_empty
thf(fact_7519_pred__on_Ochain__def,axiom,
! [A: $tType] :
( ( pred_chain @ A )
= ( ^ [A6: set @ A,P: A > A > $o,C8: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ C8 @ A6 )
& ! [X2: A] :
( ( member2 @ A @ X2 @ C8 )
=> ! [Y2: A] :
( ( member2 @ A @ Y2 @ C8 )
=> ( ( sup_sup @ ( A > A > $o ) @ P
@ ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ X2
@ Y2 )
| ( sup_sup @ ( A > A > $o ) @ P
@ ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ Y2
@ X2 ) ) ) ) ) ) ) ).
% pred_on.chain_def
thf(fact_7520_pred__on_OchainI,axiom,
! [A: $tType,C5: set @ A,A4: set @ A,P2: A > A > $o] :
( ( ord_less_eq @ ( set @ A ) @ C5 @ A4 )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ C5 )
=> ( ( member2 @ A @ Y4 @ C5 )
=> ( ( sup_sup @ ( A > A > $o ) @ P2
@ ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ X5
@ Y4 )
| ( sup_sup @ ( A > A > $o ) @ P2
@ ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ Y4
@ X5 ) ) ) )
=> ( pred_chain @ A @ A4 @ P2 @ C5 ) ) ) ).
% pred_on.chainI
thf(fact_7521_subset__Zorn,axiom,
! [A: $tType,A4: set @ ( set @ A )] :
( ! [C6: set @ ( set @ A )] :
( ( pred_chain @ ( set @ A ) @ A4 @ ( ord_less @ ( set @ A ) ) @ C6 )
=> ? [X3: set @ A] :
( ( member2 @ ( set @ A ) @ X3 @ A4 )
& ! [Xa4: set @ A] :
( ( member2 @ ( set @ A ) @ Xa4 @ C6 )
=> ( ord_less_eq @ ( set @ A ) @ Xa4 @ X3 ) ) ) )
=> ? [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ A4 )
& ! [Xa: set @ A] :
( ( member2 @ ( set @ A ) @ Xa @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ X5 @ Xa )
=> ( Xa = X5 ) ) ) ) ) ).
% subset_Zorn
thf(fact_7522_subset__Zorn_H,axiom,
! [A: $tType,A4: set @ ( set @ A )] :
( ! [C6: set @ ( set @ A )] :
( ( pred_chain @ ( set @ A ) @ A4 @ ( ord_less @ ( set @ A ) ) @ C6 )
=> ( member2 @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ C6 ) @ A4 ) )
=> ? [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ A4 )
& ! [Xa: set @ A] :
( ( member2 @ ( set @ A ) @ Xa @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ X5 @ Xa )
=> ( Xa = X5 ) ) ) ) ) ).
% subset_Zorn'
thf(fact_7523_subset__chain__def,axiom,
! [A: $tType,A27: set @ ( set @ A ),C10: set @ ( set @ A )] :
( ( pred_chain @ ( set @ A ) @ A27 @ ( ord_less @ ( set @ A ) ) @ C10 )
= ( ( ord_less_eq @ ( set @ ( set @ A ) ) @ C10 @ A27 )
& ! [X2: set @ A] :
( ( member2 @ ( set @ A ) @ X2 @ C10 )
=> ! [Y2: set @ A] :
( ( member2 @ ( set @ A ) @ Y2 @ C10 )
=> ( ( ord_less_eq @ ( set @ A ) @ X2 @ Y2 )
| ( ord_less_eq @ ( set @ A ) @ Y2 @ X2 ) ) ) ) ) ) ).
% subset_chain_def
thf(fact_7524_subset__chain__insert,axiom,
! [A: $tType,A27: set @ ( set @ A ),B3: set @ A,B10: set @ ( set @ A )] :
( ( pred_chain @ ( set @ A ) @ A27 @ ( ord_less @ ( set @ A ) ) @ ( insert2 @ ( set @ A ) @ B3 @ B10 ) )
= ( ( member2 @ ( set @ A ) @ B3 @ A27 )
& ! [X2: set @ A] :
( ( member2 @ ( set @ A ) @ X2 @ B10 )
=> ( ( ord_less_eq @ ( set @ A ) @ X2 @ B3 )
| ( ord_less_eq @ ( set @ A ) @ B3 @ X2 ) ) )
& ( pred_chain @ ( set @ A ) @ A27 @ ( ord_less @ ( set @ A ) ) @ B10 ) ) ) ).
% subset_chain_insert
thf(fact_7525_subset__Zorn__nonempty,axiom,
! [A: $tType,A27: set @ ( set @ A )] :
( ( A27
!= ( bot_bot @ ( set @ ( set @ A ) ) ) )
=> ( ! [C11: set @ ( set @ A )] :
( ( C11
!= ( bot_bot @ ( set @ ( set @ A ) ) ) )
=> ( ( pred_chain @ ( set @ A ) @ A27 @ ( ord_less @ ( set @ A ) ) @ C11 )
=> ( member2 @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ C11 ) @ A27 ) ) )
=> ? [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ A27 )
& ! [Xa: set @ A] :
( ( member2 @ ( set @ A ) @ Xa @ A27 )
=> ( ( ord_less_eq @ ( set @ A ) @ X5 @ Xa )
=> ( Xa = X5 ) ) ) ) ) ) ).
% subset_Zorn_nonempty
thf(fact_7526_Union__in__chain,axiom,
! [A: $tType,B10: set @ ( set @ A ),A27: set @ ( set @ A )] :
( ( finite_finite @ ( set @ A ) @ B10 )
=> ( ( B10
!= ( bot_bot @ ( set @ ( set @ A ) ) ) )
=> ( ( pred_chain @ ( set @ A ) @ A27 @ ( ord_less @ ( set @ A ) ) @ B10 )
=> ( member2 @ ( set @ A ) @ ( complete_Sup_Sup @ ( set @ A ) @ B10 ) @ B10 ) ) ) ) ).
% Union_in_chain
thf(fact_7527_Inter__in__chain,axiom,
! [A: $tType,B10: set @ ( set @ A ),A27: set @ ( set @ A )] :
( ( finite_finite @ ( set @ A ) @ B10 )
=> ( ( B10
!= ( bot_bot @ ( set @ ( set @ A ) ) ) )
=> ( ( pred_chain @ ( set @ A ) @ A27 @ ( ord_less @ ( set @ A ) ) @ B10 )
=> ( member2 @ ( set @ A ) @ ( complete_Inf_Inf @ ( set @ A ) @ B10 ) @ B10 ) ) ) ) ).
% Inter_in_chain
thf(fact_7528_subset_Ochain__extend,axiom,
! [A: $tType,A4: set @ ( set @ A ),C5: set @ ( set @ A ),Z: set @ A] :
( ( pred_chain @ ( set @ A ) @ A4 @ ( ord_less @ ( set @ A ) ) @ C5 )
=> ( ( member2 @ ( set @ A ) @ Z @ A4 )
=> ( ! [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ C5 )
=> ( sup_sup @ ( ( set @ A ) > ( set @ A ) > $o ) @ ( ord_less @ ( set @ A ) )
@ ^ [Y5: set @ A,Z3: set @ A] : ( Y5 = Z3 )
@ X5
@ Z ) )
=> ( pred_chain @ ( set @ A ) @ A4 @ ( ord_less @ ( set @ A ) ) @ ( sup_sup @ ( set @ ( set @ A ) ) @ ( insert2 @ ( set @ A ) @ Z @ ( bot_bot @ ( set @ ( set @ A ) ) ) ) @ C5 ) ) ) ) ) ).
% subset.chain_extend
thf(fact_7529_pred__on_Ochain__extend,axiom,
! [A: $tType,A4: set @ A,P2: A > A > $o,C5: set @ A,Z: A] :
( ( pred_chain @ A @ A4 @ P2 @ C5 )
=> ( ( member2 @ A @ Z @ A4 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ C5 )
=> ( sup_sup @ ( A > A > $o ) @ P2
@ ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ X5
@ Z ) )
=> ( pred_chain @ A @ A4 @ P2 @ ( sup_sup @ ( set @ A ) @ ( insert2 @ A @ Z @ ( bot_bot @ ( set @ A ) ) ) @ C5 ) ) ) ) ) ).
% pred_on.chain_extend
thf(fact_7530_finite__subset__Union__chain,axiom,
! [A: $tType,A4: set @ A,B10: set @ ( set @ A ),A27: set @ ( set @ A )] :
( ( finite_finite @ A @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( complete_Sup_Sup @ ( set @ A ) @ B10 ) )
=> ( ( B10
!= ( bot_bot @ ( set @ ( set @ A ) ) ) )
=> ( ( pred_chain @ ( set @ A ) @ A27 @ ( ord_less @ ( set @ A ) ) @ B10 )
=> ~ ! [B8: set @ A] :
( ( member2 @ ( set @ A ) @ B8 @ B10 )
=> ~ ( ord_less_eq @ ( set @ A ) @ A4 @ B8 ) ) ) ) ) ) ).
% finite_subset_Union_chain
thf(fact_7531_Chains__subset,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ord_less_eq @ ( set @ ( set @ A ) ) @ ( chains @ A @ R2 )
@ ( collect @ ( set @ A )
@ ( pred_chain @ A @ ( top_top @ ( set @ A ) )
@ ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R2 ) ) ) ) ).
% Chains_subset
thf(fact_7532_wo__rel_Ocases__Total3,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A,Phi: A > A > $o] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ A3 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) @ ( field2 @ A @ R2 ) )
=> ( ( ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ ( minus_minus @ ( set @ ( product_prod @ A @ A ) ) @ R2 @ ( id2 @ A ) ) )
| ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ A3 ) @ ( minus_minus @ ( set @ ( product_prod @ A @ A ) ) @ R2 @ ( id2 @ A ) ) ) )
=> ( Phi @ A3 @ B2 ) )
=> ( ( ( A3 = B2 )
=> ( Phi @ A3 @ B2 ) )
=> ( Phi @ A3 @ B2 ) ) ) ) ) ).
% wo_rel.cases_Total3
thf(fact_7533_admissible__chfin,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [P2: A > $o] :
( ! [S6: set @ A] :
( ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ S6 )
=> ( finite_finite @ A @ S6 ) )
=> ( comple1908693960933563346ssible @ A @ ( complete_Sup_Sup @ A ) @ ( ord_less_eq @ A ) @ P2 ) ) ) ).
% admissible_chfin
thf(fact_7534_ccpo_OadmissibleD,axiom,
! [A: $tType,Lub: ( set @ A ) > A,Ord: A > A > $o,P2: A > $o,A4: set @ A] :
( ( comple1908693960933563346ssible @ A @ Lub @ Ord @ P2 )
=> ( ( comple1602240252501008431_chain @ A @ Ord @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ A4 )
=> ( P2 @ X5 ) )
=> ( P2 @ ( Lub @ A4 ) ) ) ) ) ) ).
% ccpo.admissibleD
thf(fact_7535_ccpo_OadmissibleI,axiom,
! [A: $tType,Ord: A > A > $o,P2: A > $o,Lub: ( set @ A ) > A] :
( ! [A9: set @ A] :
( ( comple1602240252501008431_chain @ A @ Ord @ A9 )
=> ( ( A9
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X3: A] :
( ( member2 @ A @ X3 @ A9 )
=> ( P2 @ X3 ) )
=> ( P2 @ ( Lub @ A9 ) ) ) ) )
=> ( comple1908693960933563346ssible @ A @ Lub @ Ord @ P2 ) ) ).
% ccpo.admissibleI
thf(fact_7536_ccpo_Oadmissible__def,axiom,
! [A: $tType] :
( ( comple1908693960933563346ssible @ A )
= ( ^ [Lub2: ( set @ A ) > A,Ord2: A > A > $o,P: A > $o] :
! [A6: set @ A] :
( ( comple1602240252501008431_chain @ A @ Ord2 @ A6 )
=> ( ( A6
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( P @ X2 ) )
=> ( P @ ( Lub2 @ A6 ) ) ) ) ) ) ) ).
% ccpo.admissible_def
thf(fact_7537_wo__rel_Omax2__greater,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ B2 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ ( bNF_We1388413361240627857o_max2 @ A @ R2 @ A3 @ B2 ) ) @ R2 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ ( bNF_We1388413361240627857o_max2 @ A @ R2 @ A3 @ B2 ) ) @ R2 ) ) ) ) ) ).
% wo_rel.max2_greater
thf(fact_7538_wo__rel_Omax2__equals2,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ B2 @ ( field2 @ A @ R2 ) )
=> ( ( ( bNF_We1388413361240627857o_max2 @ A @ R2 @ A3 @ B2 )
= B2 )
= ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 ) ) ) ) ) ).
% wo_rel.max2_equals2
thf(fact_7539_wo__rel_Omax2__equals1,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ B2 @ ( field2 @ A @ R2 ) )
=> ( ( ( bNF_We1388413361240627857o_max2 @ A @ R2 @ A3 @ B2 )
= A3 )
= ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ A3 ) @ R2 ) ) ) ) ) ).
% wo_rel.max2_equals1
thf(fact_7540_wo__rel_Omax2__def,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ( bNF_We1388413361240627857o_max2 @ A @ R2 @ A3 @ B2 )
= B2 ) )
& ( ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ( bNF_We1388413361240627857o_max2 @ A @ R2 @ A3 @ B2 )
= A3 ) ) ) ) ).
% wo_rel.max2_def
thf(fact_7541_wo__rel_Owell__order__induct,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),P2: A > $o,A3: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ! [X5: A] :
( ! [Y3: A] :
( ( ( Y3 != X5 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y3 @ X5 ) @ R2 ) )
=> ( P2 @ Y3 ) )
=> ( P2 @ X5 ) )
=> ( P2 @ A3 ) ) ) ).
% wo_rel.well_order_induct
thf(fact_7542_well__order__induct__imp,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),P2: A > $o,A3: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ! [X5: A] :
( ! [Y3: A] :
( ( ( Y3 != X5 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y3 @ X5 ) @ R2 ) )
=> ( ( member2 @ A @ Y3 @ ( field2 @ A @ R2 ) )
=> ( P2 @ Y3 ) ) )
=> ( ( member2 @ A @ X5 @ ( field2 @ A @ R2 ) )
=> ( P2 @ X5 ) ) )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( P2 @ A3 ) ) ) ) ).
% well_order_induct_imp
thf(fact_7543_wo__rel_OTOTALS,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ! [X3: A] :
( ( member2 @ A @ X3 @ ( field2 @ A @ R2 ) )
=> ! [Xa: A] :
( ( member2 @ A @ Xa @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X3 @ Xa ) @ R2 )
| ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Xa @ X3 ) @ R2 ) ) ) ) ) ).
% wo_rel.TOTALS
thf(fact_7544_wo__rel_Omax2__among,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ B2 @ ( field2 @ A @ R2 ) )
=> ( member2 @ A @ ( bNF_We1388413361240627857o_max2 @ A @ R2 @ A3 @ B2 ) @ ( insert2 @ A @ A3 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% wo_rel.max2_among
thf(fact_7545_admissible__disj,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [P2: A > $o,Q: A > $o] :
( ( comple1908693960933563346ssible @ A @ ( complete_Sup_Sup @ A ) @ ( ord_less_eq @ A ) @ P2 )
=> ( ( comple1908693960933563346ssible @ A @ ( complete_Sup_Sup @ A ) @ ( ord_less_eq @ A ) @ Q )
=> ( comple1908693960933563346ssible @ A @ ( complete_Sup_Sup @ A ) @ ( ord_less_eq @ A )
@ ^ [X2: A] :
( ( P2 @ X2 )
| ( Q @ X2 ) ) ) ) ) ) ).
% admissible_disj
thf(fact_7546_wo__rel_Ocases__Total,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A,Phi: A > A > $o] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ A3 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) @ ( field2 @ A @ R2 ) )
=> ( ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( Phi @ A3 @ B2 ) )
=> ( ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ A3 ) @ R2 )
=> ( Phi @ A3 @ B2 ) )
=> ( Phi @ A3 @ B2 ) ) ) ) ) ).
% wo_rel.cases_Total
thf(fact_7547_natLeq__on__wo__rel,axiom,
! [N2: nat] :
( bNF_Wellorder_wo_rel @ nat
@ ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [X2: nat,Y2: nat] :
( ( ord_less @ nat @ X2 @ N2 )
& ( ord_less @ nat @ Y2 @ N2 )
& ( ord_less_eq @ nat @ X2 @ Y2 ) ) ) ) ) ).
% natLeq_on_wo_rel
thf(fact_7548_wo__rel_Omax2__greater__among,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ B2 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ ( bNF_We1388413361240627857o_max2 @ A @ R2 @ A3 @ B2 ) ) @ R2 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ ( bNF_We1388413361240627857o_max2 @ A @ R2 @ A3 @ B2 ) ) @ R2 )
& ( member2 @ A @ ( bNF_We1388413361240627857o_max2 @ A @ R2 @ A3 @ B2 ) @ ( insert2 @ A @ A3 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ).
% wo_rel.max2_greater_among
thf(fact_7549_wo__rel_OWell__order__isMinim__exists,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),B3: set @ A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( field2 @ A @ R2 ) )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ? [X_12: A] : ( bNF_We4791949203932849705sMinim @ A @ R2 @ B3 @ X_12 ) ) ) ) ).
% wo_rel.Well_order_isMinim_exists
thf(fact_7550_wo__rel_Ominim__in,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),B3: set @ A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( field2 @ A @ R2 ) )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ A @ ( bNF_We6954850376910717587_minim @ A @ R2 @ B3 ) @ B3 ) ) ) ) ).
% wo_rel.minim_in
thf(fact_7551_wo__rel_Ominim__isMinim,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),B3: set @ A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( field2 @ A @ R2 ) )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( bNF_We4791949203932849705sMinim @ A @ R2 @ B3 @ ( bNF_We6954850376910717587_minim @ A @ R2 @ B3 ) ) ) ) ) ).
% wo_rel.minim_isMinim
thf(fact_7552_wo__rel_OisMinim__def,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A,B2: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( bNF_We4791949203932849705sMinim @ A @ R2 @ A4 @ B2 )
= ( ( member2 @ A @ B2 @ A4 )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ X2 ) @ R2 ) ) ) ) ) ).
% wo_rel.isMinim_def
thf(fact_7553_wo__rel_Ominim__least,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),B3: set @ A,B2: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ B2 @ B3 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ ( bNF_We6954850376910717587_minim @ A @ R2 @ B3 ) @ B2 ) @ R2 ) ) ) ) ).
% wo_rel.minim_least
thf(fact_7554_wo__rel_Oequals__minim,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),B3: set @ A,A3: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ A3 @ B3 )
=> ( ! [B5: A] :
( ( member2 @ A @ B5 @ B3 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B5 ) @ R2 ) )
=> ( A3
= ( bNF_We6954850376910717587_minim @ A @ R2 @ B3 ) ) ) ) ) ) ).
% wo_rel.equals_minim
thf(fact_7555_wo__rel_Ominim__inField,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),B3: set @ A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( field2 @ A @ R2 ) )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ A @ ( bNF_We6954850376910717587_minim @ A @ R2 @ B3 ) @ ( field2 @ A @ R2 ) ) ) ) ) ).
% wo_rel.minim_inField
thf(fact_7556_distinct__adj__append__iff,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( distinct_adj @ A @ ( append @ A @ Xs @ Ys ) )
= ( ( distinct_adj @ A @ Xs )
& ( distinct_adj @ A @ Ys )
& ( ( Xs
= ( nil @ A ) )
| ( Ys
= ( nil @ A ) )
| ( ( last @ A @ Xs )
!= ( hd @ A @ Ys ) ) ) ) ) ).
% distinct_adj_append_iff
thf(fact_7557_bot_Oordering__top__axioms,axiom,
! [A: $tType] :
( ( order_bot @ A )
=> ( ordering_top @ A
@ ^ [X2: A,Y2: A] : ( ord_less_eq @ A @ Y2 @ X2 )
@ ^ [X2: A,Y2: A] : ( ord_less @ A @ Y2 @ X2 )
@ ( bot_bot @ A ) ) ) ).
% bot.ordering_top_axioms
thf(fact_7558_distinct__adj__Cons__Cons,axiom,
! [B: $tType,X: B,Y: B,Xs: list @ B] :
( ( distinct_adj @ B @ ( cons @ B @ X @ ( cons @ B @ Y @ Xs ) ) )
= ( ( X != Y )
& ( distinct_adj @ B @ ( cons @ B @ Y @ Xs ) ) ) ) ).
% distinct_adj_Cons_Cons
thf(fact_7559_distinct__adj__rev,axiom,
! [A: $tType,Xs: list @ A] :
( ( distinct_adj @ A @ ( rev @ A @ Xs ) )
= ( distinct_adj @ A @ Xs ) ) ).
% distinct_adj_rev
thf(fact_7560_distinct__adj__ConsD,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( distinct_adj @ A @ ( cons @ A @ X @ Xs ) )
=> ( distinct_adj @ A @ Xs ) ) ).
% distinct_adj_ConsD
thf(fact_7561_distinct__adj__remdups__adj,axiom,
! [A: $tType,Xs: list @ A] : ( distinct_adj @ A @ ( remdups_adj @ A @ Xs ) ) ).
% distinct_adj_remdups_adj
thf(fact_7562_distinct__adj__altdef,axiom,
! [A: $tType] :
( ( distinct_adj @ A )
= ( ^ [Xs2: list @ A] :
( ( remdups_adj @ A @ Xs2 )
= Xs2 ) ) ) ).
% distinct_adj_altdef
thf(fact_7563_distinct__adj__appendD2,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( distinct_adj @ A @ ( append @ A @ Xs @ Ys ) )
=> ( distinct_adj @ A @ Ys ) ) ).
% distinct_adj_appendD2
thf(fact_7564_distinct__adj__appendD1,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A] :
( ( distinct_adj @ A @ ( append @ A @ Xs @ Ys ) )
=> ( distinct_adj @ A @ Xs ) ) ).
% distinct_adj_appendD1
thf(fact_7565_distinct__adj__mapD,axiom,
! [A: $tType,B: $tType,F2: B > A,Xs: list @ B] :
( ( distinct_adj @ A @ ( map @ B @ A @ F2 @ Xs ) )
=> ( distinct_adj @ B @ Xs ) ) ).
% distinct_adj_mapD
thf(fact_7566_distinct__adj__Nil,axiom,
! [A: $tType] : ( distinct_adj @ A @ ( nil @ A ) ) ).
% distinct_adj_Nil
thf(fact_7567_distinct__adj__singleton,axiom,
! [B: $tType,X: B] : ( distinct_adj @ B @ ( cons @ B @ X @ ( nil @ B ) ) ) ).
% distinct_adj_singleton
thf(fact_7568_gcd__nat_Oordering__top__axioms,axiom,
( ordering_top @ nat @ ( dvd_dvd @ nat )
@ ^ [M2: nat,N: nat] :
( ( dvd_dvd @ nat @ M2 @ N )
& ( M2 != N ) )
@ ( zero_zero @ nat ) ) ).
% gcd_nat.ordering_top_axioms
thf(fact_7569_distinct__adj__mapI,axiom,
! [B: $tType,A: $tType,Xs: list @ A,F2: A > B] :
( ( distinct_adj @ A @ Xs )
=> ( ( inj_on @ A @ B @ F2 @ ( set2 @ A @ Xs ) )
=> ( distinct_adj @ B @ ( map @ A @ B @ F2 @ Xs ) ) ) ) ).
% distinct_adj_mapI
thf(fact_7570_distinct__adj__map__iff,axiom,
! [B: $tType,A: $tType,F2: A > B,Xs: list @ A] :
( ( inj_on @ A @ B @ F2 @ ( set2 @ A @ Xs ) )
=> ( ( distinct_adj @ B @ ( map @ A @ B @ F2 @ Xs ) )
= ( distinct_adj @ A @ Xs ) ) ) ).
% distinct_adj_map_iff
thf(fact_7571_distinct__adj__Cons,axiom,
! [A: $tType,X: A,Xs: list @ A] :
( ( distinct_adj @ A @ ( cons @ A @ X @ Xs ) )
= ( ( Xs
= ( nil @ A ) )
| ( ( X
!= ( hd @ A @ Xs ) )
& ( distinct_adj @ A @ Xs ) ) ) ) ).
% distinct_adj_Cons
thf(fact_7572_top_Oordering__top__axioms,axiom,
! [A: $tType] :
( ( order_top @ A )
=> ( ordering_top @ A @ ( ord_less_eq @ A ) @ ( ord_less @ A ) @ ( top_top @ A ) ) ) ).
% top.ordering_top_axioms
thf(fact_7573_bot__nat__0_Oordering__top__axioms,axiom,
( ordering_top @ nat
@ ^ [X2: nat,Y2: nat] : ( ord_less_eq @ nat @ Y2 @ X2 )
@ ^ [X2: nat,Y2: nat] : ( ord_less @ nat @ Y2 @ X2 )
@ ( zero_zero @ nat ) ) ).
% bot_nat_0.ordering_top_axioms
thf(fact_7574_span__singleton,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: A] :
( ( real_Vector_span @ A @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( image2 @ real @ A
@ ^ [K2: real] : ( real_V8093663219630862766scaleR @ A @ K2 @ X )
@ ( top_top @ ( set @ real ) ) ) ) ) ).
% span_singleton
thf(fact_7575_span__explicit,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ( ( real_Vector_span @ A )
= ( ^ [B4: set @ A] :
( collect @ A
@ ^ [Uu3: A] :
? [T3: set @ A,R4: A > real] :
( ( Uu3
= ( groups7311177749621191930dd_sum @ A @ A
@ ^ [A5: A] : ( real_V8093663219630862766scaleR @ A @ ( R4 @ A5 ) @ A5 )
@ T3 ) )
& ( finite_finite @ A @ T3 )
& ( ord_less_eq @ ( set @ A ) @ T3 @ B4 ) ) ) ) ) ) ).
% span_explicit
thf(fact_7576_span__insert__0,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A] :
( ( real_Vector_span @ A @ ( insert2 @ A @ ( zero_zero @ A ) @ S3 ) )
= ( real_Vector_span @ A @ S3 ) ) ) ).
% span_insert_0
thf(fact_7577_span__empty,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ( ( real_Vector_span @ A @ ( bot_bot @ ( set @ A ) ) )
= ( insert2 @ A @ ( zero_zero @ A ) @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% span_empty
thf(fact_7578_span__delete__0,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A] :
( ( real_Vector_span @ A @ ( minus_minus @ ( set @ A ) @ S3 @ ( insert2 @ A @ ( zero_zero @ A ) @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( real_Vector_span @ A @ S3 ) ) ) ).
% span_delete_0
thf(fact_7579_in__span__delete,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A3: A,S3: set @ A,B2: A] :
( ( member2 @ A @ A3 @ ( real_Vector_span @ A @ S3 ) )
=> ( ~ ( member2 @ A @ A3 @ ( real_Vector_span @ A @ ( minus_minus @ ( set @ A ) @ S3 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) ) )
=> ( member2 @ A @ B2 @ ( real_Vector_span @ A @ ( insert2 @ A @ A3 @ ( minus_minus @ ( set @ A ) @ S3 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ).
% in_span_delete
thf(fact_7580_span__induct__alt,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: A,S3: set @ A,H2: A > $o] :
( ( member2 @ A @ X @ ( real_Vector_span @ A @ S3 ) )
=> ( ( H2 @ ( zero_zero @ A ) )
=> ( ! [C4: real,X5: A,Y4: A] :
( ( member2 @ A @ X5 @ S3 )
=> ( ( H2 @ Y4 )
=> ( H2 @ ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ C4 @ X5 ) @ Y4 ) ) ) )
=> ( H2 @ X ) ) ) ) ) ).
% span_induct_alt
thf(fact_7581_span__add,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: A,S3: set @ A,Y: A] :
( ( member2 @ A @ X @ ( real_Vector_span @ A @ S3 ) )
=> ( ( member2 @ A @ Y @ ( real_Vector_span @ A @ S3 ) )
=> ( member2 @ A @ ( plus_plus @ A @ X @ Y ) @ ( real_Vector_span @ A @ S3 ) ) ) ) ) ).
% span_add
thf(fact_7582_span__add__eq,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [X: A,S3: set @ A,Y: A] :
( ( member2 @ A @ X @ ( real_Vector_span @ A @ S3 ) )
=> ( ( member2 @ A @ ( plus_plus @ A @ X @ Y ) @ ( real_Vector_span @ A @ S3 ) )
= ( member2 @ A @ Y @ ( real_Vector_span @ A @ S3 ) ) ) ) ) ).
% span_add_eq
thf(fact_7583_span__add__eq2,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [Y: A,S3: set @ A,X: A] :
( ( member2 @ A @ Y @ ( real_Vector_span @ A @ S3 ) )
=> ( ( member2 @ A @ ( plus_plus @ A @ X @ Y ) @ ( real_Vector_span @ A @ S3 ) )
= ( member2 @ A @ X @ ( real_Vector_span @ A @ S3 ) ) ) ) ) ).
% span_add_eq2
thf(fact_7584_span__0,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A] : ( member2 @ A @ ( zero_zero @ A ) @ ( real_Vector_span @ A @ S3 ) ) ) ).
% span_0
thf(fact_7585_maximal__independent__subset,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [V: set @ A] :
~ ! [B8: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B8 @ V )
=> ( ~ ( real_V358717886546972837endent @ A @ B8 )
=> ~ ( ord_less_eq @ ( set @ A ) @ V @ ( real_Vector_span @ A @ B8 ) ) ) ) ) ).
% maximal_independent_subset
thf(fact_7586_spanning__subset__independent,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ~ ( real_V358717886546972837endent @ A @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( real_Vector_span @ A @ B3 ) )
=> ( A4 = B3 ) ) ) ) ) ).
% spanning_subset_independent
thf(fact_7587_maximal__independent__subset__extend,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A,V: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ S3 @ V )
=> ( ~ ( real_V358717886546972837endent @ A @ S3 )
=> ~ ! [B8: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ S3 @ B8 )
=> ( ( ord_less_eq @ ( set @ A ) @ B8 @ V )
=> ( ~ ( real_V358717886546972837endent @ A @ B8 )
=> ~ ( ord_less_eq @ ( set @ A ) @ V @ ( real_Vector_span @ A @ B8 ) ) ) ) ) ) ) ) ).
% maximal_independent_subset_extend
thf(fact_7588_span__eq,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A,T4: set @ A] :
( ( ( real_Vector_span @ A @ S3 )
= ( real_Vector_span @ A @ T4 ) )
= ( ( ord_less_eq @ ( set @ A ) @ S3 @ ( real_Vector_span @ A @ T4 ) )
& ( ord_less_eq @ ( set @ A ) @ T4 @ ( real_Vector_span @ A @ S3 ) ) ) ) ) ).
% span_eq
thf(fact_7589_span__mono,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ord_less_eq @ ( set @ A ) @ ( real_Vector_span @ A @ A4 ) @ ( real_Vector_span @ A @ B3 ) ) ) ) ).
% span_mono
thf(fact_7590_span__superset,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A] : ( ord_less_eq @ ( set @ A ) @ S3 @ ( real_Vector_span @ A @ S3 ) ) ) ).
% span_superset
thf(fact_7591_span__Un,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A,T4: set @ A] :
( ( real_Vector_span @ A @ ( sup_sup @ ( set @ A ) @ S3 @ T4 ) )
= ( collect @ A
@ ^ [Uu3: A] :
? [X2: A,Y2: A] :
( ( Uu3
= ( plus_plus @ A @ X2 @ Y2 ) )
& ( member2 @ A @ X2 @ ( real_Vector_span @ A @ S3 ) )
& ( member2 @ A @ Y2 @ ( real_Vector_span @ A @ T4 ) ) ) ) ) ) ).
% span_Un
thf(fact_7592_dependent__def,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ( ( real_V358717886546972837endent @ A )
= ( ^ [P: set @ A] :
? [X2: A] :
( ( member2 @ A @ X2 @ P )
& ( member2 @ A @ X2 @ ( real_Vector_span @ A @ ( minus_minus @ ( set @ A ) @ P @ ( insert2 @ A @ X2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ).
% dependent_def
thf(fact_7593_span__breakdown,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [B2: A,S3: set @ A,A3: A] :
( ( member2 @ A @ B2 @ S3 )
=> ( ( member2 @ A @ A3 @ ( real_Vector_span @ A @ S3 ) )
=> ? [K3: real] : ( member2 @ A @ ( minus_minus @ A @ A3 @ ( real_V8093663219630862766scaleR @ A @ K3 @ B2 ) ) @ ( real_Vector_span @ A @ ( minus_minus @ ( set @ A ) @ S3 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ).
% span_breakdown
thf(fact_7594_independent__span__bound,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [T4: set @ A,S3: set @ A] :
( ( finite_finite @ A @ T4 )
=> ( ~ ( real_V358717886546972837endent @ A @ S3 )
=> ( ( ord_less_eq @ ( set @ A ) @ S3 @ ( real_Vector_span @ A @ T4 ) )
=> ( ( finite_finite @ A @ S3 )
& ( ord_less_eq @ nat @ ( finite_card @ A @ S3 ) @ ( finite_card @ A @ T4 ) ) ) ) ) ) ) ).
% independent_span_bound
thf(fact_7595_exchange__lemma,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [T4: set @ A,S3: set @ A] :
( ( finite_finite @ A @ T4 )
=> ( ~ ( real_V358717886546972837endent @ A @ S3 )
=> ( ( ord_less_eq @ ( set @ A ) @ S3 @ ( real_Vector_span @ A @ T4 ) )
=> ? [T13: set @ A] :
( ( ( finite_card @ A @ T13 )
= ( finite_card @ A @ T4 ) )
& ( finite_finite @ A @ T13 )
& ( ord_less_eq @ ( set @ A ) @ S3 @ T13 )
& ( ord_less_eq @ ( set @ A ) @ T13 @ ( sup_sup @ ( set @ A ) @ S3 @ T4 ) )
& ( ord_less_eq @ ( set @ A ) @ S3 @ ( real_Vector_span @ A @ T13 ) ) ) ) ) ) ) ).
% exchange_lemma
thf(fact_7596_span__alt,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ( ( real_Vector_span @ A )
= ( ^ [B6: set @ A] :
( collect @ A
@ ^ [Uu3: A] :
? [F3: A > real] :
( ( Uu3
= ( groups7311177749621191930dd_sum @ A @ A
@ ^ [X2: A] : ( real_V8093663219630862766scaleR @ A @ ( F3 @ X2 ) @ X2 )
@ ( collect @ A
@ ^ [X2: A] :
( ( F3 @ X2 )
!= ( zero_zero @ real ) ) ) ) )
& ( ord_less_eq @ ( set @ A )
@ ( collect @ A
@ ^ [X2: A] :
( ( F3 @ X2 )
!= ( zero_zero @ real ) ) )
@ B6 )
& ( finite_finite @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( F3 @ X2 )
!= ( zero_zero @ real ) ) ) ) ) ) ) ) ) ).
% span_alt
thf(fact_7597_sum__representation__eq,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [Basis: set @ A,V2: A,B3: set @ A] :
( ~ ( real_V358717886546972837endent @ A @ Basis )
=> ( ( member2 @ A @ V2 @ ( real_Vector_span @ A @ Basis ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ Basis @ B3 )
=> ( ( groups7311177749621191930dd_sum @ A @ A
@ ^ [B4: A] : ( real_V8093663219630862766scaleR @ A @ ( real_V7696804695334737415tation @ A @ Basis @ V2 @ B4 ) @ B4 )
@ B3 )
= V2 ) ) ) ) ) ) ).
% sum_representation_eq
thf(fact_7598_span__card__ge__dim,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [B3: set @ A,V: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ V )
=> ( ( ord_less_eq @ ( set @ A ) @ V @ ( real_Vector_span @ A @ B3 ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ord_less_eq @ nat @ ( real_Vector_dim @ A @ V ) @ ( finite_card @ A @ B3 ) ) ) ) ) ) ).
% span_card_ge_dim
thf(fact_7599_representation__zero,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [Basis: set @ A] :
( ( real_V7696804695334737415tation @ A @ Basis @ ( zero_zero @ A ) )
= ( ^ [B4: A] : ( zero_zero @ real ) ) ) ) ).
% representation_zero
thf(fact_7600_representation__extend,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [Basis: set @ A,V2: A,Basis2: set @ A] :
( ~ ( real_V358717886546972837endent @ A @ Basis )
=> ( ( member2 @ A @ V2 @ ( real_Vector_span @ A @ Basis2 ) )
=> ( ( ord_less_eq @ ( set @ A ) @ Basis2 @ Basis )
=> ( ( real_V7696804695334737415tation @ A @ Basis @ V2 )
= ( real_V7696804695334737415tation @ A @ Basis2 @ V2 ) ) ) ) ) ) ).
% representation_extend
thf(fact_7601_dim__le__card_H,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S: set @ A] :
( ( finite_finite @ A @ S )
=> ( ord_less_eq @ nat @ ( real_Vector_dim @ A @ S ) @ ( finite_card @ A @ S ) ) ) ) ).
% dim_le_card'
thf(fact_7602_representation__add,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [Basis: set @ A,V2: A,U: A] :
( ~ ( real_V358717886546972837endent @ A @ Basis )
=> ( ( member2 @ A @ V2 @ ( real_Vector_span @ A @ Basis ) )
=> ( ( member2 @ A @ U @ ( real_Vector_span @ A @ Basis ) )
=> ( ( real_V7696804695334737415tation @ A @ Basis @ ( plus_plus @ A @ U @ V2 ) )
= ( ^ [B4: A] : ( plus_plus @ real @ ( real_V7696804695334737415tation @ A @ Basis @ U @ B4 ) @ ( real_V7696804695334737415tation @ A @ Basis @ V2 @ B4 ) ) ) ) ) ) ) ) ).
% representation_add
thf(fact_7603_basis__card__eq__dim,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [B3: set @ A,V: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ V )
=> ( ( ord_less_eq @ ( set @ A ) @ V @ ( real_Vector_span @ A @ B3 ) )
=> ( ~ ( real_V358717886546972837endent @ A @ B3 )
=> ( ( finite_card @ A @ B3 )
= ( real_Vector_dim @ A @ V ) ) ) ) ) ) ).
% basis_card_eq_dim
thf(fact_7604_basis__exists,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [V: set @ A] :
~ ! [B8: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B8 @ V )
=> ( ~ ( real_V358717886546972837endent @ A @ B8 )
=> ( ( ord_less_eq @ ( set @ A ) @ V @ ( real_Vector_span @ A @ B8 ) )
=> ( ( finite_card @ A @ B8 )
!= ( real_Vector_dim @ A @ V ) ) ) ) ) ) ).
% basis_exists
thf(fact_7605_dim__unique,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [B3: set @ A,V: set @ A,N2: nat] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ V )
=> ( ( ord_less_eq @ ( set @ A ) @ V @ ( real_Vector_span @ A @ B3 ) )
=> ( ~ ( real_V358717886546972837endent @ A @ B3 )
=> ( ( ( finite_card @ A @ B3 )
= N2 )
=> ( ( real_Vector_dim @ A @ V )
= N2 ) ) ) ) ) ) ).
% dim_unique
thf(fact_7606_dim__le__card,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [V: set @ A,W4: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ V @ ( real_Vector_span @ A @ W4 ) )
=> ( ( finite_finite @ A @ W4 )
=> ( ord_less_eq @ nat @ ( real_Vector_dim @ A @ V ) @ ( finite_card @ A @ W4 ) ) ) ) ) ).
% dim_le_card
thf(fact_7607_dim__def,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ( ( real_Vector_dim @ A )
= ( ^ [V6: set @ A] :
( if @ nat
@ ? [B4: set @ A] :
( ~ ( real_V358717886546972837endent @ A @ B4 )
& ( ( real_Vector_span @ A @ B4 )
= ( real_Vector_span @ A @ V6 ) ) )
@ ( finite_card @ A
@ ( fChoice @ ( set @ A )
@ ^ [B4: set @ A] :
( ~ ( real_V358717886546972837endent @ A @ B4 )
& ( ( real_Vector_span @ A @ B4 )
= ( real_Vector_span @ A @ V6 ) ) ) ) )
@ ( zero_zero @ nat ) ) ) ) ) ).
% dim_def
thf(fact_7608_linear__indep__image__lemma,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [F2: A > B,B3: set @ A,X: A] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( finite_finite @ A @ B3 )
=> ( ~ ( real_V358717886546972837endent @ B @ ( image2 @ A @ B @ F2 @ B3 ) )
=> ( ( inj_on @ A @ B @ F2 @ B3 )
=> ( ( member2 @ A @ X @ ( real_Vector_span @ A @ B3 ) )
=> ( ( ( F2 @ X )
= ( zero_zero @ B ) )
=> ( X
= ( zero_zero @ A ) ) ) ) ) ) ) ) ) ).
% linear_indep_image_lemma
thf(fact_7609_some__in__eq,axiom,
! [A: $tType,A4: set @ A] :
( ( member2 @ A
@ ( fChoice @ A
@ ^ [X2: A] : ( member2 @ A @ X2 @ A4 ) )
@ A4 )
= ( A4
!= ( bot_bot @ ( set @ A ) ) ) ) ).
% some_in_eq
thf(fact_7610_linear__injective__0,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [F2: A > B] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( inj_on @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
= ( ! [X2: A] :
( ( ( F2 @ X2 )
= ( zero_zero @ B ) )
=> ( X2
= ( zero_zero @ A ) ) ) ) ) ) ) ).
% linear_injective_0
thf(fact_7611_linear__0,axiom,
! [A: $tType,B: $tType] :
( ( ( real_V4867850818363320053vector @ B )
& ( real_V4867850818363320053vector @ A ) )
=> ! [F2: A > B] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( F2 @ ( zero_zero @ A ) )
= ( zero_zero @ B ) ) ) ) ).
% linear_0
thf(fact_7612_linear__add,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [F2: A > B,B15: A,B24: A] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( F2 @ ( plus_plus @ A @ B15 @ B24 ) )
= ( plus_plus @ B @ ( F2 @ B15 ) @ ( F2 @ B24 ) ) ) ) ) ).
% linear_add
thf(fact_7613_linear__compose__add,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [F2: A > B,G: A > B] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( real_Vector_linear @ A @ B @ G )
=> ( real_Vector_linear @ A @ B
@ ^ [X2: A] : ( plus_plus @ B @ ( F2 @ X2 ) @ ( G @ X2 ) ) ) ) ) ) ).
% linear_compose_add
thf(fact_7614_module__hom__zero,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ( real_Vector_linear @ A @ B
@ ^ [X2: A] : ( zero_zero @ B ) ) ) ).
% module_hom_zero
thf(fact_7615_Real__Vector__Spaces_Olinear__iff,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ( ( real_Vector_linear @ A @ B )
= ( ^ [F3: A > B] :
( ! [X2: A,Y2: A] :
( ( F3 @ ( plus_plus @ A @ X2 @ Y2 ) )
= ( plus_plus @ B @ ( F3 @ X2 ) @ ( F3 @ Y2 ) ) )
& ! [C3: real,X2: A] :
( ( F3 @ ( real_V8093663219630862766scaleR @ A @ C3 @ X2 ) )
= ( real_V8093663219630862766scaleR @ B @ C3 @ ( F3 @ X2 ) ) ) ) ) ) ) ).
% Real_Vector_Spaces.linear_iff
thf(fact_7616_linearI,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [F2: A > B] :
( ! [B16: A,B25: A] :
( ( F2 @ ( plus_plus @ A @ B16 @ B25 ) )
= ( plus_plus @ B @ ( F2 @ B16 ) @ ( F2 @ B25 ) ) )
=> ( ! [R3: real,B5: A] :
( ( F2 @ ( real_V8093663219630862766scaleR @ A @ R3 @ B5 ) )
= ( real_V8093663219630862766scaleR @ B @ R3 @ ( F2 @ B5 ) ) )
=> ( real_Vector_linear @ A @ B @ F2 ) ) ) ) ).
% linearI
thf(fact_7617_linear__spans__image,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [F2: A > B,V: set @ A,B3: set @ A] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ V @ ( real_Vector_span @ A @ B3 ) )
=> ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ V ) @ ( real_Vector_span @ B @ ( image2 @ A @ B @ F2 @ B3 ) ) ) ) ) ) ).
% linear_spans_image
thf(fact_7618_linear__eq__0__on__span,axiom,
! [A: $tType,B: $tType] :
( ( ( real_V4867850818363320053vector @ B )
& ( real_V4867850818363320053vector @ A ) )
=> ! [F2: A > B,B2: set @ A,X: A] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ B2 )
=> ( ( F2 @ X5 )
= ( zero_zero @ B ) ) )
=> ( ( member2 @ A @ X @ ( real_Vector_span @ A @ B2 ) )
=> ( ( F2 @ X )
= ( zero_zero @ B ) ) ) ) ) ) ).
% linear_eq_0_on_span
thf(fact_7619_linear__spanning__surjective__image,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [F2: A > B,S3: set @ A] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( ord_less_eq @ ( set @ A ) @ ( top_top @ ( set @ A ) ) @ ( real_Vector_span @ A @ S3 ) )
=> ( ( ( image2 @ A @ B @ F2 @ ( top_top @ ( set @ A ) ) )
= ( top_top @ ( set @ B ) ) )
=> ( ord_less_eq @ ( set @ B ) @ ( top_top @ ( set @ B ) ) @ ( real_Vector_span @ B @ ( image2 @ A @ B @ F2 @ S3 ) ) ) ) ) ) ) ).
% linear_spanning_surjective_image
thf(fact_7620_linear__surj__right__inverse,axiom,
! [A: $tType,B: $tType] :
( ( ( real_V4867850818363320053vector @ B )
& ( real_V4867850818363320053vector @ A ) )
=> ! [F2: A > B,T4: set @ B,S3: set @ A] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( real_Vector_span @ B @ T4 ) @ ( image2 @ A @ B @ F2 @ ( real_Vector_span @ A @ S3 ) ) )
=> ? [G4: B > A] :
( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ G4 @ ( top_top @ ( set @ B ) ) ) @ ( real_Vector_span @ A @ S3 ) )
& ( real_Vector_linear @ B @ A @ G4 )
& ! [X3: B] :
( ( member2 @ B @ X3 @ ( real_Vector_span @ B @ T4 ) )
=> ( ( F2 @ ( G4 @ X3 ) )
= X3 ) ) ) ) ) ) ).
% linear_surj_right_inverse
thf(fact_7621_linear__inj__on__left__inverse,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [F2: A > B,S3: set @ A] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( inj_on @ A @ B @ F2 @ ( real_Vector_span @ A @ S3 ) )
=> ? [G4: B > A] :
( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ G4 @ ( top_top @ ( set @ B ) ) ) @ ( real_Vector_span @ A @ S3 ) )
& ( real_Vector_linear @ B @ A @ G4 )
& ! [X3: A] :
( ( member2 @ A @ X3 @ ( real_Vector_span @ A @ S3 ) )
=> ( ( G4 @ ( F2 @ X3 ) )
= X3 ) ) ) ) ) ) ).
% linear_inj_on_left_inverse
thf(fact_7622_arg__min__SOME__Min,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ! [S3: set @ A,F2: A > B] :
( ( finite_finite @ A @ S3 )
=> ( ( lattic7623131987881927897min_on @ A @ B @ F2 @ S3 )
= ( fChoice @ A
@ ^ [Y2: A] :
( ( member2 @ A @ Y2 @ S3 )
& ( ( F2 @ Y2 )
= ( lattic643756798350308766er_Min @ B @ ( image2 @ A @ B @ F2 @ S3 ) ) ) ) ) ) ) ) ).
% arg_min_SOME_Min
thf(fact_7623_extend__basis__def,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ( ( real_V4986007116245087402_basis @ A )
= ( ^ [B6: set @ A] :
( fChoice @ ( set @ A )
@ ^ [B17: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B6 @ B17 )
& ~ ( real_V358717886546972837endent @ A @ B17 )
& ( ( real_Vector_span @ A @ B17 )
= ( top_top @ ( set @ A ) ) ) ) ) ) ) ) ).
% extend_basis_def
thf(fact_7624_finite__basis__to__basis__subspace__isomorphism,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [S3: set @ A,T4: set @ B,B3: set @ A,C5: set @ B] :
( ( real_Vector_subspace @ A @ S3 )
=> ( ( real_Vector_subspace @ B @ T4 )
=> ( ( ( real_Vector_dim @ A @ S3 )
= ( real_Vector_dim @ B @ T4 ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ S3 )
=> ( ~ ( real_V358717886546972837endent @ A @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ S3 @ ( real_Vector_span @ A @ B3 ) )
=> ( ( ( finite_card @ A @ B3 )
= ( real_Vector_dim @ A @ S3 ) )
=> ( ( finite_finite @ B @ C5 )
=> ( ( ord_less_eq @ ( set @ B ) @ C5 @ T4 )
=> ( ~ ( real_V358717886546972837endent @ B @ C5 )
=> ( ( ord_less_eq @ ( set @ B ) @ T4 @ ( real_Vector_span @ B @ C5 ) )
=> ( ( ( finite_card @ B @ C5 )
= ( real_Vector_dim @ B @ T4 ) )
=> ? [F4: A > B] :
( ( real_Vector_linear @ A @ B @ F4 )
& ( ( image2 @ A @ B @ F4 @ B3 )
= C5 )
& ( ( image2 @ A @ B @ F4 @ S3 )
= T4 )
& ( inj_on @ A @ B @ F4 @ S3 ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ).
% finite_basis_to_basis_subspace_isomorphism
thf(fact_7625_Eps__case__prod__eq,axiom,
! [A: $tType,B: $tType,X: A,Y: B] :
( ( fChoice @ ( product_prod @ A @ B )
@ ( product_case_prod @ A @ B @ $o
@ ^ [X10: A,Y7: B] :
( ( X = X10 )
& ( Y = Y7 ) ) ) )
= ( product_Pair @ A @ B @ X @ Y ) ) ).
% Eps_case_prod_eq
thf(fact_7626_split__paired__Eps,axiom,
! [B: $tType,A: $tType] :
( ( fChoice @ ( product_prod @ A @ B ) )
= ( ^ [P: ( product_prod @ A @ B ) > $o] :
( fChoice @ ( product_prod @ A @ B )
@ ( product_case_prod @ A @ B @ $o
@ ^ [A5: A,B4: B] : ( P @ ( product_Pair @ A @ B @ A5 @ B4 ) ) ) ) ) ) ).
% split_paired_Eps
thf(fact_7627_linear__subspace__kernel,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [F2: A > B] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( real_Vector_subspace @ A
@ ( collect @ A
@ ^ [X2: A] :
( ( F2 @ X2 )
= ( zero_zero @ B ) ) ) ) ) ) ).
% linear_subspace_kernel
thf(fact_7628_subspace__sums,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A,T4: set @ A] :
( ( real_Vector_subspace @ A @ S3 )
=> ( ( real_Vector_subspace @ A @ T4 )
=> ( real_Vector_subspace @ A
@ ( collect @ A
@ ^ [Uu3: A] :
? [X2: A,Y2: A] :
( ( Uu3
= ( plus_plus @ A @ X2 @ Y2 ) )
& ( member2 @ A @ X2 @ S3 )
& ( member2 @ A @ Y2 @ T4 ) ) ) ) ) ) ) ).
% subspace_sums
thf(fact_7629_span__subspace,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( real_Vector_span @ A @ A4 ) )
=> ( ( real_Vector_subspace @ A @ B3 )
=> ( ( real_Vector_span @ A @ A4 )
= B3 ) ) ) ) ) ).
% span_subspace
thf(fact_7630_span__minimal,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A,T4: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ S3 @ T4 )
=> ( ( real_Vector_subspace @ A @ T4 )
=> ( ord_less_eq @ ( set @ A ) @ ( real_Vector_span @ A @ S3 ) @ T4 ) ) ) ) ).
% span_minimal
thf(fact_7631_span__unique,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A,T4: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ S3 @ T4 )
=> ( ( real_Vector_subspace @ A @ T4 )
=> ( ! [T14: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ S3 @ T14 )
=> ( ( real_Vector_subspace @ A @ T14 )
=> ( ord_less_eq @ ( set @ A ) @ T4 @ T14 ) ) )
=> ( ( real_Vector_span @ A @ S3 )
= T4 ) ) ) ) ) ).
% span_unique
thf(fact_7632_subspace__add,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A,X: A,Y: A] :
( ( real_Vector_subspace @ A @ S3 )
=> ( ( member2 @ A @ X @ S3 )
=> ( ( member2 @ A @ Y @ S3 )
=> ( member2 @ A @ ( plus_plus @ A @ X @ Y ) @ S3 ) ) ) ) ) ).
% subspace_add
thf(fact_7633_subspace__0,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A] :
( ( real_Vector_subspace @ A @ S3 )
=> ( member2 @ A @ ( zero_zero @ A ) @ S3 ) ) ) ).
% subspace_0
thf(fact_7634_subspace__single__0,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ( real_Vector_subspace @ A @ ( insert2 @ A @ ( zero_zero @ A ) @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% subspace_single_0
thf(fact_7635_subspace__def,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ( ( real_Vector_subspace @ A )
= ( ^ [S8: set @ A] :
( ( member2 @ A @ ( zero_zero @ A ) @ S8 )
& ! [X2: A] :
( ( member2 @ A @ X2 @ S8 )
=> ! [Y2: A] :
( ( member2 @ A @ Y2 @ S8 )
=> ( member2 @ A @ ( plus_plus @ A @ X2 @ Y2 ) @ S8 ) ) )
& ! [C3: real,X2: A] :
( ( member2 @ A @ X2 @ S8 )
=> ( member2 @ A @ ( real_V8093663219630862766scaleR @ A @ C3 @ X2 ) @ S8 ) ) ) ) ) ) ).
% subspace_def
thf(fact_7636_subspaceI,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [S3: set @ A] :
( ( member2 @ A @ ( zero_zero @ A ) @ S3 )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ S3 )
=> ( ( member2 @ A @ Y4 @ S3 )
=> ( member2 @ A @ ( plus_plus @ A @ X5 @ Y4 ) @ S3 ) ) )
=> ( ! [C4: real,X5: A] :
( ( member2 @ A @ X5 @ S3 )
=> ( member2 @ A @ ( real_V8093663219630862766scaleR @ A @ C4 @ X5 ) @ S3 ) )
=> ( real_Vector_subspace @ A @ S3 ) ) ) ) ) ).
% subspaceI
thf(fact_7637_linear__injective__on__subspace__0,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [F2: A > B,S: set @ A] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( real_Vector_subspace @ A @ S )
=> ( ( inj_on @ A @ B @ F2 @ S )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ S )
=> ( ( ( F2 @ X2 )
= ( zero_zero @ B ) )
=> ( X2
= ( zero_zero @ A ) ) ) ) ) ) ) ) ) ).
% linear_injective_on_subspace_0
thf(fact_7638_extend__basis__superset,axiom,
! [A: $tType] :
( ( real_V4867850818363320053vector @ A )
=> ! [B3: set @ A] :
( ~ ( real_V358717886546972837endent @ A @ B3 )
=> ( ord_less_eq @ ( set @ A ) @ B3 @ ( real_V4986007116245087402_basis @ A @ B3 ) ) ) ) ).
% extend_basis_superset
thf(fact_7639_linear__exists__right__inverse__on,axiom,
! [A: $tType,B: $tType] :
( ( ( real_V4867850818363320053vector @ B )
& ( real_V4867850818363320053vector @ A ) )
=> ! [F2: A > B,V: set @ A] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( real_Vector_subspace @ A @ V )
=> ? [G4: B > A] :
( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ G4 @ ( top_top @ ( set @ B ) ) ) @ V )
& ( real_Vector_linear @ B @ A @ G4 )
& ! [X3: B] :
( ( member2 @ B @ X3 @ ( image2 @ A @ B @ F2 @ V ) )
=> ( ( F2 @ ( G4 @ X3 ) )
= X3 ) ) ) ) ) ) ).
% linear_exists_right_inverse_on
thf(fact_7640_linear__exists__left__inverse__on,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [F2: A > B,V: set @ A] :
( ( real_Vector_linear @ A @ B @ F2 )
=> ( ( real_Vector_subspace @ A @ V )
=> ( ( inj_on @ A @ B @ F2 @ V )
=> ? [G4: B > A] :
( ( ord_less_eq @ ( set @ A ) @ ( image2 @ B @ A @ G4 @ ( top_top @ ( set @ B ) ) ) @ V )
& ( real_Vector_linear @ B @ A @ G4 )
& ! [X3: A] :
( ( member2 @ A @ X3 @ V )
=> ( ( G4 @ ( F2 @ X3 ) )
= X3 ) ) ) ) ) ) ) ).
% linear_exists_left_inverse_on
thf(fact_7641_construct__def,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ( ( real_V4425403222259421789struct @ A @ B )
= ( ^ [B6: set @ A,G2: A > B,V5: A] :
( groups7311177749621191930dd_sum @ A @ B
@ ^ [B4: A] : ( real_V8093663219630862766scaleR @ B @ ( real_V7696804695334737415tation @ A @ ( real_V4986007116245087402_basis @ A @ B6 ) @ V5 @ B4 ) @ ( if @ B @ ( member2 @ A @ B4 @ B6 ) @ ( G2 @ B4 ) @ ( zero_zero @ B ) ) )
@ ( collect @ A
@ ^ [B4: A] :
( ( real_V7696804695334737415tation @ A @ ( real_V4986007116245087402_basis @ A @ B6 ) @ V5 @ B4 )
!= ( zero_zero @ real ) ) ) ) ) ) ) ).
% construct_def
thf(fact_7642_construct__outside,axiom,
! [A: $tType,B: $tType] :
( ( ( real_V4867850818363320053vector @ B )
& ( real_V4867850818363320053vector @ A ) )
=> ! [B3: set @ A,V2: A,F2: A > B] :
( ~ ( real_V358717886546972837endent @ A @ B3 )
=> ( ( member2 @ A @ V2 @ ( real_Vector_span @ A @ ( minus_minus @ ( set @ A ) @ ( real_V4986007116245087402_basis @ A @ B3 ) @ B3 ) ) )
=> ( ( real_V4425403222259421789struct @ A @ B @ B3 @ F2 @ V2 )
= ( zero_zero @ B ) ) ) ) ) ).
% construct_outside
thf(fact_7643_construct__add,axiom,
! [B: $tType,A: $tType] :
( ( ( real_V4867850818363320053vector @ A )
& ( real_V4867850818363320053vector @ B ) )
=> ! [B3: set @ A,F2: A > B,G: A > B,V2: A] :
( ~ ( real_V358717886546972837endent @ A @ B3 )
=> ( ( real_V4425403222259421789struct @ A @ B @ B3
@ ^ [X2: A] : ( plus_plus @ B @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ V2 )
= ( plus_plus @ B @ ( real_V4425403222259421789struct @ A @ B @ B3 @ F2 @ V2 ) @ ( real_V4425403222259421789struct @ A @ B @ B3 @ G @ V2 ) ) ) ) ) ).
% construct_add
thf(fact_7644_arg__min__def,axiom,
! [A: $tType,B: $tType] :
( ( ord @ A )
=> ( ( lattices_ord_arg_min @ B @ A )
= ( ^ [F3: B > A,P: B > $o] : ( fChoice @ B @ ( lattic501386751177426532rg_min @ B @ A @ F3 @ P ) ) ) ) ) ).
% arg_min_def
thf(fact_7645_euclidean__size__times__nonunit,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ~ ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( ord_less @ nat @ ( euclid6346220572633701492n_size @ A @ B2 ) @ ( euclid6346220572633701492n_size @ A @ ( times_times @ A @ A3 @ B2 ) ) ) ) ) ) ) ).
% euclidean_size_times_nonunit
thf(fact_7646_size__0,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ( ( euclid6346220572633701492n_size @ A @ ( zero_zero @ A ) )
= ( zero_zero @ nat ) ) ) ).
% size_0
thf(fact_7647_euclidean__size__eq__0__iff,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [B2: A] :
( ( ( euclid6346220572633701492n_size @ A @ B2 )
= ( zero_zero @ nat ) )
= ( B2
= ( zero_zero @ A ) ) ) ) ).
% euclidean_size_eq_0_iff
thf(fact_7648_euclidean__size__greater__0__iff,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [B2: A] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( euclid6346220572633701492n_size @ A @ B2 ) )
= ( B2
!= ( zero_zero @ A ) ) ) ) ).
% euclidean_size_greater_0_iff
thf(fact_7649_is__arg__min__linorder,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ( ( lattic501386751177426532rg_min @ A @ B )
= ( ^ [F3: A > B,P: A > $o,X2: A] :
( ( P @ X2 )
& ! [Y2: A] :
( ( P @ Y2 )
=> ( ord_less_eq @ B @ ( F3 @ X2 ) @ ( F3 @ Y2 ) ) ) ) ) ) ) ).
% is_arg_min_linorder
thf(fact_7650_is__arg__min__antimono,axiom,
! [B: $tType,A: $tType] :
( ( order @ B )
=> ! [F2: A > B,P2: A > $o,X: A,Y: A] :
( ( lattic501386751177426532rg_min @ A @ B @ F2 @ P2 @ X )
=> ( ( ord_less_eq @ B @ ( F2 @ Y ) @ ( F2 @ X ) )
=> ( ( P2 @ Y )
=> ( lattic501386751177426532rg_min @ A @ B @ F2 @ P2 @ Y ) ) ) ) ) ).
% is_arg_min_antimono
thf(fact_7651_is__arg__min__def,axiom,
! [A: $tType,B: $tType] :
( ( ord @ A )
=> ( ( lattic501386751177426532rg_min @ B @ A )
= ( ^ [F3: B > A,P: B > $o,X2: B] :
( ( P @ X2 )
& ~ ? [Y2: B] :
( ( P @ Y2 )
& ( ord_less @ A @ ( F3 @ Y2 ) @ ( F3 @ X2 ) ) ) ) ) ) ) ).
% is_arg_min_def
thf(fact_7652_dvd__euclidean__size__eq__imp__dvd,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( ( euclid6346220572633701492n_size @ A @ A3 )
= ( euclid6346220572633701492n_size @ A @ B2 ) )
=> ( ( dvd_dvd @ A @ B2 @ A3 )
=> ( dvd_dvd @ A @ A3 @ B2 ) ) ) ) ) ).
% dvd_euclidean_size_eq_imp_dvd
thf(fact_7653_unit__iff__euclidean__size,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [A3: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
= ( ( ( euclid6346220572633701492n_size @ A @ A3 )
= ( euclid6346220572633701492n_size @ A @ ( one_one @ A ) ) )
& ( A3
!= ( zero_zero @ A ) ) ) ) ) ).
% unit_iff_euclidean_size
thf(fact_7654_size__mult__mono_H,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ord_less_eq @ nat @ ( euclid6346220572633701492n_size @ A @ A3 ) @ ( euclid6346220572633701492n_size @ A @ ( times_times @ A @ B2 @ A3 ) ) ) ) ) ).
% size_mult_mono'
thf(fact_7655_size__mult__mono,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ord_less_eq @ nat @ ( euclid6346220572633701492n_size @ A @ A3 ) @ ( euclid6346220572633701492n_size @ A @ ( times_times @ A @ A3 @ B2 ) ) ) ) ) ).
% size_mult_mono
thf(fact_7656_dvd__proper__imp__size__less,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ~ ( dvd_dvd @ A @ B2 @ A3 )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ord_less @ nat @ ( euclid6346220572633701492n_size @ A @ A3 ) @ ( euclid6346220572633701492n_size @ A @ B2 ) ) ) ) ) ) ).
% dvd_proper_imp_size_less
thf(fact_7657_dvd__imp__size__le,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ B2 )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ord_less_eq @ nat @ ( euclid6346220572633701492n_size @ A @ A3 ) @ ( euclid6346220572633701492n_size @ A @ B2 ) ) ) ) ) ).
% dvd_imp_size_le
thf(fact_7658_mod__size__less,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ord_less @ nat @ ( euclid6346220572633701492n_size @ A @ ( modulo_modulo @ A @ A3 @ B2 ) ) @ ( euclid6346220572633701492n_size @ A @ B2 ) ) ) ) ).
% mod_size_less
thf(fact_7659_is__arg__min__arg__min__nat,axiom,
! [A: $tType,P2: A > $o,X: A,M: A > nat] :
( ( P2 @ X )
=> ( lattic501386751177426532rg_min @ A @ nat @ M @ P2 @ ( lattices_ord_arg_min @ A @ nat @ M @ P2 ) ) ) ).
% is_arg_min_arg_min_nat
thf(fact_7660_ex__is__arg__min__if__finite,axiom,
! [B: $tType,A: $tType] :
( ( order @ B )
=> ! [S3: set @ A,F2: A > B] :
( ( finite_finite @ A @ S3 )
=> ( ( S3
!= ( bot_bot @ ( set @ A ) ) )
=> ? [X_12: A] :
( lattic501386751177426532rg_min @ A @ B @ F2
@ ^ [X2: A] : ( member2 @ A @ X2 @ S3 )
@ X_12 ) ) ) ) ).
% ex_is_arg_min_if_finite
thf(fact_7661_divmod__cases,axiom,
! [A: $tType] :
( ( euclid3128863361964157862miring @ A )
=> ! [B2: A,A3: A] :
( ( ( B2
!= ( zero_zero @ A ) )
=> ( ( ( modulo_modulo @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
=> ( A3
!= ( times_times @ A @ ( divide_divide @ A @ A3 @ B2 ) @ B2 ) ) ) )
=> ( ( ( B2
!= ( zero_zero @ A ) )
=> ! [Q3: A,R3: A] :
( ( ( euclid7384307370059645450egment @ A @ R3 )
= ( euclid7384307370059645450egment @ A @ B2 ) )
=> ( ( ord_less @ nat @ ( euclid6346220572633701492n_size @ A @ R3 ) @ ( euclid6346220572633701492n_size @ A @ B2 ) )
=> ( ( R3
!= ( zero_zero @ A ) )
=> ( ( ( divide_divide @ A @ A3 @ B2 )
= Q3 )
=> ( ( ( modulo_modulo @ A @ A3 @ B2 )
= R3 )
=> ( A3
!= ( plus_plus @ A @ ( times_times @ A @ Q3 @ B2 ) @ R3 ) ) ) ) ) ) ) )
=> ( B2
= ( zero_zero @ A ) ) ) ) ) ).
% divmod_cases
thf(fact_7662_mod__eqI,axiom,
! [A: $tType] :
( ( euclid3128863361964157862miring @ A )
=> ! [B2: A,R2: A,Q2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( ( euclid7384307370059645450egment @ A @ R2 )
= ( euclid7384307370059645450egment @ A @ B2 ) )
=> ( ( ord_less @ nat @ ( euclid6346220572633701492n_size @ A @ R2 ) @ ( euclid6346220572633701492n_size @ A @ B2 ) )
=> ( ( ( plus_plus @ A @ ( times_times @ A @ Q2 @ B2 ) @ R2 )
= A3 )
=> ( ( modulo_modulo @ A @ A3 @ B2 )
= R2 ) ) ) ) ) ) ).
% mod_eqI
thf(fact_7663_division__segment__mult,axiom,
! [A: $tType] :
( ( euclid3128863361964157862miring @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( B2
!= ( zero_zero @ A ) )
=> ( ( euclid7384307370059645450egment @ A @ ( times_times @ A @ A3 @ B2 ) )
= ( times_times @ A @ ( euclid7384307370059645450egment @ A @ A3 ) @ ( euclid7384307370059645450egment @ A @ B2 ) ) ) ) ) ) ).
% division_segment_mult
thf(fact_7664_division__segment__not__0,axiom,
! [A: $tType] :
( ( euclid3128863361964157862miring @ A )
=> ! [A3: A] :
( ( euclid7384307370059645450egment @ A @ A3 )
!= ( zero_zero @ A ) ) ) ).
% division_segment_not_0
thf(fact_7665_division__segment__mod,axiom,
! [A: $tType] :
( ( euclid3128863361964157862miring @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ~ ( dvd_dvd @ A @ B2 @ A3 )
=> ( ( euclid7384307370059645450egment @ A @ ( modulo_modulo @ A @ A3 @ B2 ) )
= ( euclid7384307370059645450egment @ A @ B2 ) ) ) ) ) ).
% division_segment_mod
thf(fact_7666_unique__euclidean__semiring__class_Odiv__eq__0__iff,axiom,
! [A: $tType] :
( ( euclid3128863361964157862miring @ A )
=> ! [A3: A,B2: A] :
( ( ( euclid7384307370059645450egment @ A @ A3 )
= ( euclid7384307370059645450egment @ A @ B2 ) )
=> ( ( ( divide_divide @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
= ( ( ord_less @ nat @ ( euclid6346220572633701492n_size @ A @ A3 ) @ ( euclid6346220572633701492n_size @ A @ B2 ) )
| ( B2
= ( zero_zero @ A ) ) ) ) ) ) ).
% unique_euclidean_semiring_class.div_eq_0_iff
thf(fact_7667_div__eqI,axiom,
! [A: $tType] :
( ( euclid3128863361964157862miring @ A )
=> ! [B2: A,R2: A,Q2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( ( euclid7384307370059645450egment @ A @ R2 )
= ( euclid7384307370059645450egment @ A @ B2 ) )
=> ( ( ord_less @ nat @ ( euclid6346220572633701492n_size @ A @ R2 ) @ ( euclid6346220572633701492n_size @ A @ B2 ) )
=> ( ( ( plus_plus @ A @ ( times_times @ A @ Q2 @ B2 ) @ R2 )
= A3 )
=> ( ( divide_divide @ A @ A3 @ B2 )
= Q2 ) ) ) ) ) ) ).
% div_eqI
thf(fact_7668_div__bounded,axiom,
! [A: $tType] :
( ( euclid3128863361964157862miring @ A )
=> ! [B2: A,R2: A,Q2: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( ( euclid7384307370059645450egment @ A @ R2 )
= ( euclid7384307370059645450egment @ A @ B2 ) )
=> ( ( ord_less @ nat @ ( euclid6346220572633701492n_size @ A @ R2 ) @ ( euclid6346220572633701492n_size @ A @ B2 ) )
=> ( ( divide_divide @ A @ ( plus_plus @ A @ ( times_times @ A @ Q2 @ B2 ) @ R2 ) @ B2 )
= Q2 ) ) ) ) ) ).
% div_bounded
thf(fact_7669_AboveS__def,axiom,
! [A: $tType] :
( ( order_AboveS @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A ),A6: set @ A] :
( collect @ A
@ ^ [B4: A] :
( ( member2 @ A @ B4 @ ( field2 @ A @ R4 ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( ( B4 != X2 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ B4 ) @ R4 ) ) ) ) ) ) ) ).
% AboveS_def
thf(fact_7670_less__eq__enat__def,axiom,
( ( ord_less_eq @ extended_enat )
= ( ^ [M2: extended_enat] :
( extended_case_enat @ $o
@ ^ [N1: nat] :
( extended_case_enat @ $o
@ ^ [M12: nat] : ( ord_less_eq @ nat @ M12 @ N1 )
@ $false
@ M2 )
@ $true ) ) ) ).
% less_eq_enat_def
thf(fact_7671_AboveS__Field,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A] : ( ord_less_eq @ ( set @ A ) @ ( order_AboveS @ A @ R2 @ A4 ) @ ( field2 @ A @ R2 ) ) ).
% AboveS_Field
thf(fact_7672_AboveS__disjoint,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A )] :
( ( inf_inf @ ( set @ A ) @ A4 @ ( order_AboveS @ A @ R2 @ A4 ) )
= ( bot_bot @ ( set @ A ) ) ) ).
% AboveS_disjoint
thf(fact_7673_less__enat__def,axiom,
( ( ord_less @ extended_enat )
= ( ^ [M2: extended_enat,N: extended_enat] :
( extended_case_enat @ $o
@ ^ [M12: nat] : ( extended_case_enat @ $o @ ( ord_less @ nat @ M12 ) @ $true @ N )
@ $false
@ M2 ) ) ) ).
% less_enat_def
thf(fact_7674_wo__rel_Osuc__greater,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),B3: set @ A,B2: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( field2 @ A @ R2 ) )
=> ( ( ( order_AboveS @ A @ R2 @ B3 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( member2 @ A @ B2 @ B3 )
=> ( ( ( bNF_Wellorder_wo_suc @ A @ R2 @ B3 )
!= B2 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ ( bNF_Wellorder_wo_suc @ A @ R2 @ B3 ) ) @ R2 ) ) ) ) ) ) ).
% wo_rel.suc_greater
thf(fact_7675_wo__rel_Osuc__AboveS,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),B3: set @ A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( field2 @ A @ R2 ) )
=> ( ( ( order_AboveS @ A @ R2 @ B3 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ A @ ( bNF_Wellorder_wo_suc @ A @ R2 @ B3 ) @ ( order_AboveS @ A @ R2 @ B3 ) ) ) ) ) ).
% wo_rel.suc_AboveS
thf(fact_7676_wo__rel_Osuc__least__AboveS,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B3: set @ A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( member2 @ A @ A3 @ ( order_AboveS @ A @ R2 @ B3 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ ( bNF_Wellorder_wo_suc @ A @ R2 @ B3 ) @ A3 ) @ R2 ) ) ) ).
% wo_rel.suc_least_AboveS
thf(fact_7677_wo__rel_Oequals__suc__AboveS,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),B3: set @ A,A3: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ A3 @ ( order_AboveS @ A @ R2 @ B3 ) )
=> ( ! [A28: A] :
( ( member2 @ A @ A28 @ ( order_AboveS @ A @ R2 @ B3 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ A28 ) @ R2 ) )
=> ( A3
= ( bNF_Wellorder_wo_suc @ A @ R2 @ B3 ) ) ) ) ) ) ).
% wo_rel.equals_suc_AboveS
thf(fact_7678_wo__rel_Osuc__inField,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),B3: set @ A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ ( field2 @ A @ R2 ) )
=> ( ( ( order_AboveS @ A @ R2 @ B3 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ A @ ( bNF_Wellorder_wo_suc @ A @ R2 @ B3 ) @ ( field2 @ A @ R2 ) ) ) ) ) ).
% wo_rel.suc_inField
thf(fact_7679_wo__rel_Osuc__ofilter__in,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A,B2: A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( order_ofilter @ A @ R2 @ A4 )
=> ( ( ( order_AboveS @ A @ R2 @ A4 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ B2 @ ( bNF_Wellorder_wo_suc @ A @ R2 @ A4 ) ) @ R2 )
=> ( ( B2
!= ( bNF_Wellorder_wo_suc @ A @ R2 @ A4 ) )
=> ( member2 @ A @ B2 @ A4 ) ) ) ) ) ) ).
% wo_rel.suc_ofilter_in
thf(fact_7680_sorted__wrt__iff__nth__Suc__transp,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A] :
( ( transp @ A @ P2 )
=> ( ( sorted_wrt @ A @ P2 @ Xs )
= ( ! [I5: nat] :
( ( ord_less @ nat @ ( suc @ I5 ) @ ( size_size @ ( list @ A ) @ Xs ) )
=> ( P2 @ ( nth @ A @ Xs @ I5 ) @ ( nth @ A @ Xs @ ( suc @ I5 ) ) ) ) ) ) ) ).
% sorted_wrt_iff_nth_Suc_transp
thf(fact_7681_wo__rel_Oofilter__linord,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A,B3: set @ A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( order_ofilter @ A @ R2 @ A4 )
=> ( ( order_ofilter @ A @ R2 @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
| ( ord_less_eq @ ( set @ A ) @ B3 @ A4 ) ) ) ) ) ).
% wo_rel.ofilter_linord
thf(fact_7682_sorted__wrt2,axiom,
! [A: $tType,P2: A > A > $o,X: A,Y: A,Zs: list @ A] :
( ( transp @ A @ P2 )
=> ( ( sorted_wrt @ A @ P2 @ ( cons @ A @ X @ ( cons @ A @ Y @ Zs ) ) )
= ( ( P2 @ X @ Y )
& ( sorted_wrt @ A @ P2 @ ( cons @ A @ Y @ Zs ) ) ) ) ) ).
% sorted_wrt2
thf(fact_7683_transp__le,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( transp @ A @ ( ord_less_eq @ A ) ) ) ).
% transp_le
thf(fact_7684_transp__ge,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( transp @ A
@ ^ [X2: A,Y2: A] : ( ord_less_eq @ A @ Y2 @ X2 ) ) ) ).
% transp_ge
thf(fact_7685_list_Orel__transp,axiom,
! [A: $tType,R: A > A > $o] :
( ( transp @ A @ R )
=> ( transp @ ( list @ A ) @ ( list_all2 @ A @ A @ R ) ) ) ).
% list.rel_transp
thf(fact_7686_transp__gr,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( transp @ A
@ ^ [X2: A,Y2: A] : ( ord_less @ A @ Y2 @ X2 ) ) ) ).
% transp_gr
thf(fact_7687_transp__less,axiom,
! [A: $tType] :
( ( preorder @ A )
=> ( transp @ A @ ( ord_less @ A ) ) ) ).
% transp_less
thf(fact_7688_ofilter__def,axiom,
! [A: $tType] :
( ( order_ofilter @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A ),A6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A6 @ ( field2 @ A @ R4 ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A6 )
=> ( ord_less_eq @ ( set @ A ) @ ( order_under @ A @ R4 @ X2 ) @ A6 ) ) ) ) ) ).
% ofilter_def
thf(fact_7689_wo__rel_Oofilter__def,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A] :
( ( bNF_Wellorder_wo_rel @ A @ R2 )
=> ( ( order_ofilter @ A @ R2 @ A4 )
= ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( field2 @ A @ R2 ) )
& ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( ord_less_eq @ ( set @ A ) @ ( order_under @ A @ R2 @ X2 ) @ A4 ) ) ) ) ) ).
% wo_rel.ofilter_def
thf(fact_7690_bsqr__max2,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A12: A,A23: A,B15: A,B24: A] :
( ( order_well_order_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( member2 @ ( product_prod @ ( product_prod @ A @ A ) @ ( product_prod @ A @ A ) ) @ ( product_Pair @ ( product_prod @ A @ A ) @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A12 @ A23 ) @ ( product_Pair @ A @ A @ B15 @ B24 ) ) @ ( bNF_Wellorder_bsqr @ A @ R2 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ ( bNF_We1388413361240627857o_max2 @ A @ R2 @ A12 @ A23 ) @ ( bNF_We1388413361240627857o_max2 @ A @ R2 @ B15 @ B24 ) ) @ R2 ) ) ) ).
% bsqr_max2
thf(fact_7691_bounded__bilinear_Ointro,axiom,
! [C: $tType,B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B )
& ( real_V822414075346904944vector @ C ) )
=> ! [Prod: A > B > C] :
( ! [A7: A,A28: A,B5: B] :
( ( Prod @ ( plus_plus @ A @ A7 @ A28 ) @ B5 )
= ( plus_plus @ C @ ( Prod @ A7 @ B5 ) @ ( Prod @ A28 @ B5 ) ) )
=> ( ! [A7: A,B5: B,B18: B] :
( ( Prod @ A7 @ ( plus_plus @ B @ B5 @ B18 ) )
= ( plus_plus @ C @ ( Prod @ A7 @ B5 ) @ ( Prod @ A7 @ B18 ) ) )
=> ( ! [R3: real,A7: A,B5: B] :
( ( Prod @ ( real_V8093663219630862766scaleR @ A @ R3 @ A7 ) @ B5 )
= ( real_V8093663219630862766scaleR @ C @ R3 @ ( Prod @ A7 @ B5 ) ) )
=> ( ! [A7: A,R3: real,B5: B] :
( ( Prod @ A7 @ ( real_V8093663219630862766scaleR @ B @ R3 @ B5 ) )
= ( real_V8093663219630862766scaleR @ C @ R3 @ ( Prod @ A7 @ B5 ) ) )
=> ( ? [K8: real] :
! [A7: A,B5: B] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ C @ ( Prod @ A7 @ B5 ) ) @ ( times_times @ real @ ( times_times @ real @ ( real_V7770717601297561774m_norm @ A @ A7 ) @ ( real_V7770717601297561774m_norm @ B @ B5 ) ) @ K8 ) )
=> ( real_V2442710119149674383linear @ A @ B @ C @ Prod ) ) ) ) ) ) ) ).
% bounded_bilinear.intro
thf(fact_7692_well__order__on__domain,axiom,
! [A: $tType,A4: set @ A,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( order_well_order_on @ A @ A4 @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ( member2 @ A @ A3 @ A4 )
& ( member2 @ A @ B2 @ A4 ) ) ) ) ).
% well_order_on_domain
thf(fact_7693_well__order__on__empty,axiom,
! [A: $tType] : ( order_well_order_on @ A @ ( bot_bot @ ( set @ A ) ) @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ).
% well_order_on_empty
thf(fact_7694_bounded__bilinear_Oprod__diff__prod,axiom,
! [A: $tType,C: $tType,B: $tType] :
( ( ( real_V822414075346904944vector @ B )
& ( real_V822414075346904944vector @ C )
& ( real_V822414075346904944vector @ A ) )
=> ! [Prod: A > B > C,X: A,Y: B,A3: A,B2: B] :
( ( real_V2442710119149674383linear @ A @ B @ C @ Prod )
=> ( ( minus_minus @ C @ ( Prod @ X @ Y ) @ ( Prod @ A3 @ B2 ) )
= ( plus_plus @ C @ ( plus_plus @ C @ ( Prod @ ( minus_minus @ A @ X @ A3 ) @ ( minus_minus @ B @ Y @ B2 ) ) @ ( Prod @ ( minus_minus @ A @ X @ A3 ) @ B2 ) ) @ ( Prod @ A3 @ ( minus_minus @ B @ Y @ B2 ) ) ) ) ) ) ).
% bounded_bilinear.prod_diff_prod
thf(fact_7695_bounded__bilinear_Ozero__left,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( ( real_V822414075346904944vector @ C )
& ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [Prod: A > B > C,B2: B] :
( ( real_V2442710119149674383linear @ A @ B @ C @ Prod )
=> ( ( Prod @ ( zero_zero @ A ) @ B2 )
= ( zero_zero @ C ) ) ) ) ).
% bounded_bilinear.zero_left
thf(fact_7696_bounded__bilinear_Ozero__right,axiom,
! [B: $tType,A: $tType,C: $tType] :
( ( ( real_V822414075346904944vector @ C )
& ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B ) )
=> ! [Prod: A > B > C,A3: A] :
( ( real_V2442710119149674383linear @ A @ B @ C @ Prod )
=> ( ( Prod @ A3 @ ( zero_zero @ B ) )
= ( zero_zero @ C ) ) ) ) ).
% bounded_bilinear.zero_right
thf(fact_7697_bounded__bilinear_Oadd__left,axiom,
! [A: $tType,C: $tType,B: $tType] :
( ( ( real_V822414075346904944vector @ B )
& ( real_V822414075346904944vector @ C )
& ( real_V822414075346904944vector @ A ) )
=> ! [Prod: A > B > C,A3: A,A8: A,B2: B] :
( ( real_V2442710119149674383linear @ A @ B @ C @ Prod )
=> ( ( Prod @ ( plus_plus @ A @ A3 @ A8 ) @ B2 )
= ( plus_plus @ C @ ( Prod @ A3 @ B2 ) @ ( Prod @ A8 @ B2 ) ) ) ) ) ).
% bounded_bilinear.add_left
thf(fact_7698_bounded__bilinear_Oadd__right,axiom,
! [A: $tType,C: $tType,B: $tType] :
( ( ( real_V822414075346904944vector @ B )
& ( real_V822414075346904944vector @ C )
& ( real_V822414075346904944vector @ A ) )
=> ! [Prod: A > B > C,A3: A,B2: B,B7: B] :
( ( real_V2442710119149674383linear @ A @ B @ C @ Prod )
=> ( ( Prod @ A3 @ ( plus_plus @ B @ B2 @ B7 ) )
= ( plus_plus @ C @ ( Prod @ A3 @ B2 ) @ ( Prod @ A3 @ B7 ) ) ) ) ) ).
% bounded_bilinear.add_right
thf(fact_7699_natLeq__on__well__order__on,axiom,
! [N2: nat] :
( order_well_order_on @ nat
@ ( collect @ nat
@ ^ [X2: nat] : ( ord_less @ nat @ X2 @ N2 ) )
@ ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [X2: nat,Y2: nat] :
( ( ord_less @ nat @ X2 @ N2 )
& ( ord_less @ nat @ Y2 @ N2 )
& ( ord_less_eq @ nat @ X2 @ Y2 ) ) ) ) ) ).
% natLeq_on_well_order_on
thf(fact_7700_bounded__bilinear_Otendsto__right__zero,axiom,
! [C: $tType,B: $tType,A: $tType,D: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B )
& ( real_V822414075346904944vector @ C ) )
=> ! [Prod: A > B > C,F2: D > B,F5: filter @ D,C2: A] :
( ( real_V2442710119149674383linear @ A @ B @ C @ Prod )
=> ( ( filterlim @ D @ B @ F2 @ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) ) @ F5 )
=> ( filterlim @ D @ C
@ ^ [X2: D] : ( Prod @ C2 @ ( F2 @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ C @ ( zero_zero @ C ) )
@ F5 ) ) ) ) ).
% bounded_bilinear.tendsto_right_zero
thf(fact_7701_bounded__bilinear_Otendsto__left__zero,axiom,
! [C: $tType,B: $tType,A: $tType,D: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B )
& ( real_V822414075346904944vector @ C ) )
=> ! [Prod: A > B > C,F2: D > A,F5: filter @ D,C2: B] :
( ( real_V2442710119149674383linear @ A @ B @ C @ Prod )
=> ( ( filterlim @ D @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ F5 )
=> ( filterlim @ D @ C
@ ^ [X2: D] : ( Prod @ ( F2 @ X2 ) @ C2 )
@ ( topolo7230453075368039082e_nhds @ C @ ( zero_zero @ C ) )
@ F5 ) ) ) ) ).
% bounded_bilinear.tendsto_left_zero
thf(fact_7702_bounded__bilinear_Otendsto__zero,axiom,
! [C: $tType,B: $tType,A: $tType,D: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B )
& ( real_V822414075346904944vector @ C ) )
=> ! [Prod: A > B > C,F2: D > A,F5: filter @ D,G: D > B] :
( ( real_V2442710119149674383linear @ A @ B @ C @ Prod )
=> ( ( filterlim @ D @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ ( zero_zero @ A ) ) @ F5 )
=> ( ( filterlim @ D @ B @ G @ ( topolo7230453075368039082e_nhds @ B @ ( zero_zero @ B ) ) @ F5 )
=> ( filterlim @ D @ C
@ ^ [X2: D] : ( Prod @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( topolo7230453075368039082e_nhds @ C @ ( zero_zero @ C ) )
@ F5 ) ) ) ) ) ).
% bounded_bilinear.tendsto_zero
thf(fact_7703_bounded__bilinear_OFDERIV,axiom,
! [A: $tType,C: $tType,B: $tType,D: $tType] :
( ( ( real_V822414075346904944vector @ D )
& ( real_V822414075346904944vector @ B )
& ( real_V822414075346904944vector @ C )
& ( real_V822414075346904944vector @ A ) )
=> ! [Prod: A > B > C,F2: D > A,F8: D > A,X: D,S: set @ D,G: D > B,G6: D > B] :
( ( real_V2442710119149674383linear @ A @ B @ C @ Prod )
=> ( ( has_derivative @ D @ A @ F2 @ F8 @ ( topolo174197925503356063within @ D @ X @ S ) )
=> ( ( has_derivative @ D @ B @ G @ G6 @ ( topolo174197925503356063within @ D @ X @ S ) )
=> ( has_derivative @ D @ C
@ ^ [X2: D] : ( Prod @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ^ [H: D] : ( plus_plus @ C @ ( Prod @ ( F2 @ X ) @ ( G6 @ H ) ) @ ( Prod @ ( F8 @ H ) @ ( G @ X ) ) )
@ ( topolo174197925503356063within @ D @ X @ S ) ) ) ) ) ) ).
% bounded_bilinear.FDERIV
thf(fact_7704_well__order__on__Restr,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A] :
( ( order_well_order_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( field2 @ A @ R2 ) )
=> ( order_well_order_on @ A @ A4
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : A4 ) ) ) ) ) ).
% well_order_on_Restr
thf(fact_7705_natLeq__on__Well__order,axiom,
! [N2: nat] :
( order_well_order_on @ nat
@ ( field2 @ nat
@ ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [X2: nat,Y2: nat] :
( ( ord_less @ nat @ X2 @ N2 )
& ( ord_less @ nat @ Y2 @ N2 )
& ( ord_less_eq @ nat @ X2 @ Y2 ) ) ) ) )
@ ( collect @ ( product_prod @ nat @ nat )
@ ( product_case_prod @ nat @ nat @ $o
@ ^ [X2: nat,Y2: nat] :
( ( ord_less @ nat @ X2 @ N2 )
& ( ord_less @ nat @ Y2 @ N2 )
& ( ord_less_eq @ nat @ X2 @ Y2 ) ) ) ) ) ).
% natLeq_on_Well_order
thf(fact_7706_Linear__order__Well__order__iff,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( order_679001287576687338der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( order_well_order_on @ A @ ( field2 @ A @ R2 ) @ R2 )
= ( ! [A6: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A6 @ ( field2 @ A @ R2 ) )
=> ( ( A6
!= ( bot_bot @ ( set @ A ) ) )
=> ? [X2: A] :
( ( member2 @ A @ X2 @ A6 )
& ! [Y2: A] :
( ( member2 @ A @ Y2 @ A6 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R2 ) ) ) ) ) ) ) ) ).
% Linear_order_Well_order_iff
thf(fact_7707_ofilter__Restr__subset,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A,B3: set @ A] :
( ( order_well_order_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( order_ofilter @ A @ R2 @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( order_ofilter @ A
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ B3
@ ^ [Uu3: A] : B3 ) )
@ A4 ) ) ) ) ).
% ofilter_Restr_subset
thf(fact_7708_bounded__bilinear__def,axiom,
! [C: $tType,B: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ B )
& ( real_V822414075346904944vector @ C ) )
=> ( ( real_V2442710119149674383linear @ A @ B @ C )
= ( ^ [Prod2: A > B > C] :
( ! [A5: A,A11: A,B4: B] :
( ( Prod2 @ ( plus_plus @ A @ A5 @ A11 ) @ B4 )
= ( plus_plus @ C @ ( Prod2 @ A5 @ B4 ) @ ( Prod2 @ A11 @ B4 ) ) )
& ! [A5: A,B4: B,B11: B] :
( ( Prod2 @ A5 @ ( plus_plus @ B @ B4 @ B11 ) )
= ( plus_plus @ C @ ( Prod2 @ A5 @ B4 ) @ ( Prod2 @ A5 @ B11 ) ) )
& ! [R4: real,A5: A,B4: B] :
( ( Prod2 @ ( real_V8093663219630862766scaleR @ A @ R4 @ A5 ) @ B4 )
= ( real_V8093663219630862766scaleR @ C @ R4 @ ( Prod2 @ A5 @ B4 ) ) )
& ! [A5: A,R4: real,B4: B] :
( ( Prod2 @ A5 @ ( real_V8093663219630862766scaleR @ B @ R4 @ B4 ) )
= ( real_V8093663219630862766scaleR @ C @ R4 @ ( Prod2 @ A5 @ B4 ) ) )
& ? [K6: real] :
! [A5: A,B4: B] : ( ord_less_eq @ real @ ( real_V7770717601297561774m_norm @ C @ ( Prod2 @ A5 @ B4 ) ) @ ( times_times @ real @ ( times_times @ real @ ( real_V7770717601297561774m_norm @ A @ A5 ) @ ( real_V7770717601297561774m_norm @ B @ B4 ) ) @ K6 ) ) ) ) ) ) ).
% bounded_bilinear_def
thf(fact_7709_ofilter__subset__embed,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A,B3: set @ A] :
( ( order_well_order_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( order_ofilter @ A @ R2 @ A4 )
=> ( ( order_ofilter @ A @ R2 @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
= ( bNF_Wellorder_embed @ A @ A
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : A4 ) )
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ B3
@ ^ [Uu3: A] : B3 ) )
@ ( id @ A ) ) ) ) ) ) ).
% ofilter_subset_embed
thf(fact_7710_ofilter__embed,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A] :
( ( order_well_order_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( order_ofilter @ A @ R2 @ A4 )
= ( ( ord_less_eq @ ( set @ A ) @ A4 @ ( field2 @ A @ R2 ) )
& ( bNF_Wellorder_embed @ A @ A
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : A4 ) )
@ R2
@ ( id @ A ) ) ) ) ) ).
% ofilter_embed
thf(fact_7711_embed__Field,axiom,
! [A: $tType,B: $tType,R2: set @ ( product_prod @ A @ A ),R6: set @ ( product_prod @ B @ B ),F2: A > B] :
( ( bNF_Wellorder_embed @ A @ B @ R2 @ R6 @ F2 )
=> ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F2 @ ( field2 @ A @ R2 ) ) @ ( field2 @ B @ R6 ) ) ) ).
% embed_Field
thf(fact_7712_underS__Restr__ordLess,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A] :
( ( order_well_order_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( ( field2 @ A @ R2 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) )
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ ( order_underS @ A @ R2 @ A3 )
@ ^ [Uu3: A] : ( order_underS @ A @ R2 @ A3 ) ) )
@ R2 )
@ ( bNF_We4044943003108391690rdLess @ A @ A ) ) ) ) ).
% underS_Restr_ordLess
thf(fact_7713_ofilter__subset__ordLeq,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ A,B3: set @ A] :
( ( order_well_order_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( order_ofilter @ A @ R2 @ A4 )
=> ( ( order_ofilter @ A @ R2 @ B3 )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
= ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) )
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ A4
@ ^ [Uu3: A] : A4 ) )
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ B3
@ ^ [Uu3: A] : B3 ) ) )
@ ( bNF_Wellorder_ordLeq @ A @ A ) ) ) ) ) ) ).
% ofilter_subset_ordLeq
thf(fact_7714_coinduct3,axiom,
! [A: $tType,F2: ( set @ A ) > ( set @ A ),A3: A,X7: set @ A] :
( ( order_mono @ ( set @ A ) @ ( set @ A ) @ F2 )
=> ( ( member2 @ A @ A3 @ X7 )
=> ( ( ord_less_eq @ ( set @ A ) @ X7
@ ( F2
@ ( complete_lattice_lfp @ ( set @ A )
@ ^ [X2: set @ A] : ( sup_sup @ ( set @ A ) @ ( sup_sup @ ( set @ A ) @ ( F2 @ X2 ) @ X7 ) @ ( complete_lattice_gfp @ ( set @ A ) @ F2 ) ) ) ) )
=> ( member2 @ A @ A3 @ ( complete_lattice_gfp @ ( set @ A ) @ F2 ) ) ) ) ) ).
% coinduct3
thf(fact_7715_exists__minim__Well__order,axiom,
! [A: $tType,R: set @ ( set @ ( product_prod @ A @ A ) )] :
( ( R
!= ( bot_bot @ ( set @ ( set @ ( product_prod @ A @ A ) ) ) ) )
=> ( ! [X5: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( set @ ( product_prod @ A @ A ) ) @ X5 @ R )
=> ( order_well_order_on @ A @ ( field2 @ A @ X5 ) @ X5 ) )
=> ? [X5: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( set @ ( product_prod @ A @ A ) ) @ X5 @ R )
& ! [Xa: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( set @ ( product_prod @ A @ A ) ) @ Xa @ R )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) @ X5 @ Xa ) @ ( bNF_Wellorder_ordLeq @ A @ A ) ) ) ) ) ) ).
% exists_minim_Well_order
thf(fact_7716_weak__coinduct__image,axiom,
! [A: $tType,B: $tType,A3: A,X7: set @ A,G: A > B,F2: ( set @ B ) > ( set @ B )] :
( ( member2 @ A @ A3 @ X7 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ G @ X7 ) @ ( F2 @ ( image2 @ A @ B @ G @ X7 ) ) )
=> ( member2 @ B @ ( G @ A3 ) @ ( complete_lattice_gfp @ ( set @ B ) @ F2 ) ) ) ) ).
% weak_coinduct_image
thf(fact_7717_gfp__gfp,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A > A] :
( ! [X5: A,Y4: A,W: A,Z2: A] :
( ( ord_less_eq @ A @ X5 @ Y4 )
=> ( ( ord_less_eq @ A @ W @ Z2 )
=> ( ord_less_eq @ A @ ( F2 @ X5 @ W ) @ ( F2 @ Y4 @ Z2 ) ) ) )
=> ( ( complete_lattice_gfp @ A
@ ^ [X2: A] : ( complete_lattice_gfp @ A @ ( F2 @ X2 ) ) )
= ( complete_lattice_gfp @ A
@ ^ [X2: A] : ( F2 @ X2 @ X2 ) ) ) ) ) ).
% gfp_gfp
thf(fact_7718_gfp__least,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,X7: A] :
( ! [U4: A] :
( ( ord_less_eq @ A @ U4 @ ( F2 @ U4 ) )
=> ( ord_less_eq @ A @ U4 @ X7 ) )
=> ( ord_less_eq @ A @ ( complete_lattice_gfp @ A @ F2 ) @ X7 ) ) ) ).
% gfp_least
thf(fact_7719_gfp__upperbound,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [X7: A,F2: A > A] :
( ( ord_less_eq @ A @ X7 @ ( F2 @ X7 ) )
=> ( ord_less_eq @ A @ X7 @ ( complete_lattice_gfp @ A @ F2 ) ) ) ) ).
% gfp_upperbound
thf(fact_7720_gfp__mono,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,G: A > A] :
( ! [Z10: A] : ( ord_less_eq @ A @ ( F2 @ Z10 ) @ ( G @ Z10 ) )
=> ( ord_less_eq @ A @ ( complete_lattice_gfp @ A @ F2 ) @ ( complete_lattice_gfp @ A @ G ) ) ) ) ).
% gfp_mono
thf(fact_7721_weak__coinduct,axiom,
! [A: $tType,A3: A,X7: set @ A,F2: ( set @ A ) > ( set @ A )] :
( ( member2 @ A @ A3 @ X7 )
=> ( ( ord_less_eq @ ( set @ A ) @ X7 @ ( F2 @ X7 ) )
=> ( member2 @ A @ A3 @ ( complete_lattice_gfp @ ( set @ A ) @ F2 ) ) ) ) ).
% weak_coinduct
thf(fact_7722_gfp__eqI,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F5: A > A,X: A] :
( ( order_mono @ A @ A @ F5 )
=> ( ( ( F5 @ X )
= X )
=> ( ! [Z2: A] :
( ( ( F5 @ Z2 )
= Z2 )
=> ( ord_less_eq @ A @ Z2 @ X ) )
=> ( ( complete_lattice_gfp @ A @ F5 )
= X ) ) ) ) ) ).
% gfp_eqI
thf(fact_7723_gfp__def,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ( ( complete_lattice_gfp @ A )
= ( ^ [F3: A > A] :
( complete_Sup_Sup @ A
@ ( collect @ A
@ ^ [U2: A] : ( ord_less_eq @ A @ U2 @ ( F3 @ U2 ) ) ) ) ) ) ) ).
% gfp_def
thf(fact_7724_coinduct,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,X7: A] :
( ( order_mono @ A @ A @ F2 )
=> ( ( ord_less_eq @ A @ X7 @ ( F2 @ ( sup_sup @ A @ X7 @ ( complete_lattice_gfp @ A @ F2 ) ) ) )
=> ( ord_less_eq @ A @ X7 @ ( complete_lattice_gfp @ A @ F2 ) ) ) ) ) ).
% coinduct
thf(fact_7725_def__coinduct,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [A4: A,F2: A > A,X7: A] :
( ( A4
= ( complete_lattice_gfp @ A @ F2 ) )
=> ( ( order_mono @ A @ A @ F2 )
=> ( ( ord_less_eq @ A @ X7 @ ( F2 @ ( sup_sup @ A @ X7 @ A4 ) ) )
=> ( ord_less_eq @ A @ X7 @ A4 ) ) ) ) ) ).
% def_coinduct
thf(fact_7726_coinduct__lemma,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [X7: A,F2: A > A] :
( ( ord_less_eq @ A @ X7 @ ( F2 @ ( sup_sup @ A @ X7 @ ( complete_lattice_gfp @ A @ F2 ) ) ) )
=> ( ( order_mono @ A @ A @ F2 )
=> ( ord_less_eq @ A @ ( sup_sup @ A @ X7 @ ( complete_lattice_gfp @ A @ F2 ) ) @ ( F2 @ ( sup_sup @ A @ X7 @ ( complete_lattice_gfp @ A @ F2 ) ) ) ) ) ) ) ).
% coinduct_lemma
thf(fact_7727_coinduct__set,axiom,
! [A: $tType,F2: ( set @ A ) > ( set @ A ),A3: A,X7: set @ A] :
( ( order_mono @ ( set @ A ) @ ( set @ A ) @ F2 )
=> ( ( member2 @ A @ A3 @ X7 )
=> ( ( ord_less_eq @ ( set @ A ) @ X7 @ ( F2 @ ( sup_sup @ ( set @ A ) @ X7 @ ( complete_lattice_gfp @ ( set @ A ) @ F2 ) ) ) )
=> ( member2 @ A @ A3 @ ( complete_lattice_gfp @ ( set @ A ) @ F2 ) ) ) ) ) ).
% coinduct_set
thf(fact_7728_def__coinduct__set,axiom,
! [A: $tType,A4: set @ A,F2: ( set @ A ) > ( set @ A ),A3: A,X7: set @ A] :
( ( A4
= ( complete_lattice_gfp @ ( set @ A ) @ F2 ) )
=> ( ( order_mono @ ( set @ A ) @ ( set @ A ) @ F2 )
=> ( ( member2 @ A @ A3 @ X7 )
=> ( ( ord_less_eq @ ( set @ A ) @ X7 @ ( F2 @ ( sup_sup @ ( set @ A ) @ X7 @ A4 ) ) )
=> ( member2 @ A @ A3 @ A4 ) ) ) ) ) ).
% def_coinduct_set
thf(fact_7729_gfp__ordinal__induct,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,P2: A > $o] :
( ( order_mono @ A @ A @ F2 )
=> ( ! [S6: A] :
( ( P2 @ S6 )
=> ( ( ord_less_eq @ A @ ( complete_lattice_gfp @ A @ F2 ) @ S6 )
=> ( P2 @ ( F2 @ S6 ) ) ) )
=> ( ! [M8: set @ A] :
( ! [X3: A] :
( ( member2 @ A @ X3 @ M8 )
=> ( P2 @ X3 ) )
=> ( P2 @ ( complete_Inf_Inf @ A @ M8 ) ) )
=> ( P2 @ ( complete_lattice_gfp @ A @ F2 ) ) ) ) ) ) ).
% gfp_ordinal_induct
thf(fact_7730_gfp__funpow,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,N2: nat] :
( ( order_mono @ A @ A @ F2 )
=> ( ( complete_lattice_gfp @ A @ ( compow @ ( A > A ) @ ( suc @ N2 ) @ F2 ) )
= ( complete_lattice_gfp @ A @ F2 ) ) ) ) ).
% gfp_funpow
thf(fact_7731_lfp__le__gfp,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A] :
( ( order_mono @ A @ A @ F2 )
=> ( ord_less_eq @ A @ ( complete_lattice_lfp @ A @ F2 ) @ ( complete_lattice_gfp @ A @ F2 ) ) ) ) ).
% lfp_le_gfp
thf(fact_7732_gfp__Kleene__iter,axiom,
! [A: $tType] :
( ( comple6319245703460814977attice @ A )
=> ! [F2: A > A,K: nat] :
( ( order_mono @ A @ A @ F2 )
=> ( ( ( compow @ ( A > A ) @ ( suc @ K ) @ F2 @ ( top_top @ A ) )
= ( compow @ ( A > A ) @ K @ F2 @ ( top_top @ A ) ) )
=> ( ( complete_lattice_gfp @ A @ F2 )
= ( compow @ ( A > A ) @ K @ F2 @ ( top_top @ A ) ) ) ) ) ) ).
% gfp_Kleene_iter
thf(fact_7733_coinduct3__lemma,axiom,
! [A: $tType,X7: set @ A,F2: ( set @ A ) > ( set @ A )] :
( ( ord_less_eq @ ( set @ A ) @ X7
@ ( F2
@ ( complete_lattice_lfp @ ( set @ A )
@ ^ [X2: set @ A] : ( sup_sup @ ( set @ A ) @ ( sup_sup @ ( set @ A ) @ ( F2 @ X2 ) @ X7 ) @ ( complete_lattice_gfp @ ( set @ A ) @ F2 ) ) ) ) )
=> ( ( order_mono @ ( set @ A ) @ ( set @ A ) @ F2 )
=> ( ord_less_eq @ ( set @ A )
@ ( complete_lattice_lfp @ ( set @ A )
@ ^ [X2: set @ A] : ( sup_sup @ ( set @ A ) @ ( sup_sup @ ( set @ A ) @ ( F2 @ X2 ) @ X7 ) @ ( complete_lattice_gfp @ ( set @ A ) @ F2 ) ) )
@ ( F2
@ ( complete_lattice_lfp @ ( set @ A )
@ ^ [X2: set @ A] : ( sup_sup @ ( set @ A ) @ ( sup_sup @ ( set @ A ) @ ( F2 @ X2 ) @ X7 ) @ ( complete_lattice_gfp @ ( set @ A ) @ F2 ) ) ) ) ) ) ) ).
% coinduct3_lemma
thf(fact_7734_def__coinduct3,axiom,
! [A: $tType,A4: set @ A,F2: ( set @ A ) > ( set @ A ),A3: A,X7: set @ A] :
( ( A4
= ( complete_lattice_gfp @ ( set @ A ) @ F2 ) )
=> ( ( order_mono @ ( set @ A ) @ ( set @ A ) @ F2 )
=> ( ( member2 @ A @ A3 @ X7 )
=> ( ( ord_less_eq @ ( set @ A ) @ X7
@ ( F2
@ ( complete_lattice_lfp @ ( set @ A )
@ ^ [X2: set @ A] : ( sup_sup @ ( set @ A ) @ ( sup_sup @ ( set @ A ) @ ( F2 @ X2 ) @ X7 ) @ A4 ) ) ) )
=> ( member2 @ A @ A3 @ A4 ) ) ) ) ) ).
% def_coinduct3
thf(fact_7735_gfp__transfer__bounded,axiom,
! [A: $tType,B: $tType] :
( ( ( comple6319245703460814977attice @ B )
& ( comple6319245703460814977attice @ A ) )
=> ! [P2: A > $o,F2: A > A,Alpha: A > B,G: B > B] :
( ( P2 @ ( F2 @ ( top_top @ A ) ) )
=> ( ! [X5: A] :
( ( P2 @ X5 )
=> ( P2 @ ( F2 @ X5 ) ) )
=> ( ! [M8: nat > A] :
( ( order_antimono @ nat @ A @ M8 )
=> ( ! [I4: nat] : ( P2 @ ( M8 @ I4 ) )
=> ( P2 @ ( complete_Inf_Inf @ A @ ( image2 @ nat @ A @ M8 @ ( top_top @ ( set @ nat ) ) ) ) ) ) )
=> ( ! [M8: nat > A] :
( ( order_antimono @ nat @ A @ M8 )
=> ( ! [I4: nat] : ( P2 @ ( M8 @ I4 ) )
=> ( ( Alpha @ ( complete_Inf_Inf @ A @ ( image2 @ nat @ A @ M8 @ ( top_top @ ( set @ nat ) ) ) ) )
= ( complete_Inf_Inf @ B
@ ( image2 @ nat @ B
@ ^ [I5: nat] : ( Alpha @ ( M8 @ I5 ) )
@ ( top_top @ ( set @ nat ) ) ) ) ) ) )
=> ( ( order_inf_continuous @ A @ A @ F2 )
=> ( ( order_inf_continuous @ B @ B @ G )
=> ( ! [X5: A] :
( ( P2 @ X5 )
=> ( ( Alpha @ ( F2 @ X5 ) )
= ( G @ ( Alpha @ X5 ) ) ) )
=> ( ! [X5: B] : ( ord_less_eq @ B @ ( G @ X5 ) @ ( Alpha @ ( F2 @ ( top_top @ A ) ) ) )
=> ( ( Alpha @ ( complete_lattice_gfp @ A @ F2 ) )
= ( complete_lattice_gfp @ B @ G ) ) ) ) ) ) ) ) ) ) ) ).
% gfp_transfer_bounded
thf(fact_7736_prod__decode__triangle__add,axiom,
! [K: nat,M: nat] :
( ( nat_prod_decode @ ( plus_plus @ nat @ ( nat_triangle @ K ) @ M ) )
= ( nat_prod_decode_aux @ K @ M ) ) ).
% prod_decode_triangle_add
thf(fact_7737_prod__decode__def,axiom,
( nat_prod_decode
= ( nat_prod_decode_aux @ ( zero_zero @ nat ) ) ) ).
% prod_decode_def
thf(fact_7738_list__decode_Opinduct,axiom,
! [A0: nat,P2: nat > $o] :
( ( accp @ nat @ nat_list_decode_rel @ A0 )
=> ( ( ( accp @ nat @ nat_list_decode_rel @ ( zero_zero @ nat ) )
=> ( P2 @ ( zero_zero @ nat ) ) )
=> ( ! [N3: nat] :
( ( accp @ nat @ nat_list_decode_rel @ ( suc @ N3 ) )
=> ( ! [X3: nat,Y3: nat] :
( ( ( product_Pair @ nat @ nat @ X3 @ Y3 )
= ( nat_prod_decode @ N3 ) )
=> ( P2 @ Y3 ) )
=> ( P2 @ ( suc @ N3 ) ) ) )
=> ( P2 @ A0 ) ) ) ) ).
% list_decode.pinduct
thf(fact_7739_list__decode_Oelims,axiom,
! [X: nat,Y: list @ nat] :
( ( ( nat_list_decode @ X )
= Y )
=> ( ( ( X
= ( zero_zero @ nat ) )
=> ( Y
!= ( nil @ nat ) ) )
=> ~ ! [N3: nat] :
( ( X
= ( suc @ N3 ) )
=> ( Y
!= ( product_case_prod @ nat @ nat @ ( list @ nat )
@ ^ [X2: nat,Y2: nat] : ( cons @ nat @ X2 @ ( nat_list_decode @ Y2 ) )
@ ( nat_prod_decode @ N3 ) ) ) ) ) ) ).
% list_decode.elims
thf(fact_7740_list__decode_Opsimps_I1_J,axiom,
( ( accp @ nat @ nat_list_decode_rel @ ( zero_zero @ nat ) )
=> ( ( nat_list_decode @ ( zero_zero @ nat ) )
= ( nil @ nat ) ) ) ).
% list_decode.psimps(1)
thf(fact_7741_list__decode_Osimps_I1_J,axiom,
( ( nat_list_decode @ ( zero_zero @ nat ) )
= ( nil @ nat ) ) ).
% list_decode.simps(1)
thf(fact_7742_list__decode_Opsimps_I2_J,axiom,
! [N2: nat] :
( ( accp @ nat @ nat_list_decode_rel @ ( suc @ N2 ) )
=> ( ( nat_list_decode @ ( suc @ N2 ) )
= ( product_case_prod @ nat @ nat @ ( list @ nat )
@ ^ [X2: nat,Y2: nat] : ( cons @ nat @ X2 @ ( nat_list_decode @ Y2 ) )
@ ( nat_prod_decode @ N2 ) ) ) ) ).
% list_decode.psimps(2)
thf(fact_7743_list__decode_Osimps_I2_J,axiom,
! [N2: nat] :
( ( nat_list_decode @ ( suc @ N2 ) )
= ( product_case_prod @ nat @ nat @ ( list @ nat )
@ ^ [X2: nat,Y2: nat] : ( cons @ nat @ X2 @ ( nat_list_decode @ Y2 ) )
@ ( nat_prod_decode @ N2 ) ) ) ).
% list_decode.simps(2)
thf(fact_7744_list__decode_Opelims,axiom,
! [X: nat,Y: list @ nat] :
( ( ( nat_list_decode @ X )
= Y )
=> ( ( accp @ nat @ nat_list_decode_rel @ X )
=> ( ( ( X
= ( zero_zero @ nat ) )
=> ( ( Y
= ( nil @ nat ) )
=> ~ ( accp @ nat @ nat_list_decode_rel @ ( zero_zero @ nat ) ) ) )
=> ~ ! [N3: nat] :
( ( X
= ( suc @ N3 ) )
=> ( ( Y
= ( product_case_prod @ nat @ nat @ ( list @ nat )
@ ^ [X2: nat,Y2: nat] : ( cons @ nat @ X2 @ ( nat_list_decode @ Y2 ) )
@ ( nat_prod_decode @ N3 ) ) )
=> ~ ( accp @ nat @ nat_list_decode_rel @ ( suc @ N3 ) ) ) ) ) ) ) ).
% list_decode.pelims
thf(fact_7745_Max_Osemilattice__order__set__axioms,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( lattic4895041142388067077er_set @ A @ ( ord_max @ A )
@ ^ [X2: A,Y2: A] : ( ord_less_eq @ A @ Y2 @ X2 )
@ ^ [X2: A,Y2: A] : ( ord_less @ A @ Y2 @ X2 ) ) ) ).
% Max.semilattice_order_set_axioms
thf(fact_7746_arg__min__list_Opelims,axiom,
! [B: $tType,A: $tType] :
( ( linorder @ B )
=> ! [X: A > B,Xa2: list @ A,Y: A] :
( ( ( arg_min_list @ A @ B @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ ( A > B ) @ ( list @ A ) ) @ ( arg_min_list_rel @ A @ B ) @ ( product_Pair @ ( A > B ) @ ( list @ A ) @ X @ Xa2 ) )
=> ( ! [X5: A] :
( ( Xa2
= ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ( ( Y = X5 )
=> ~ ( accp @ ( product_prod @ ( A > B ) @ ( list @ A ) ) @ ( arg_min_list_rel @ A @ B ) @ ( product_Pair @ ( A > B ) @ ( list @ A ) @ X @ ( cons @ A @ X5 @ ( nil @ A ) ) ) ) ) )
=> ( ! [X5: A,Y4: A,Zs2: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Zs2 ) ) )
=> ( ( Y
= ( if @ A @ ( ord_less_eq @ B @ ( X @ X5 ) @ ( X @ ( arg_min_list @ A @ B @ X @ ( cons @ A @ Y4 @ Zs2 ) ) ) ) @ X5 @ ( arg_min_list @ A @ B @ X @ ( cons @ A @ Y4 @ Zs2 ) ) ) )
=> ~ ( accp @ ( product_prod @ ( A > B ) @ ( list @ A ) ) @ ( arg_min_list_rel @ A @ B ) @ ( product_Pair @ ( A > B ) @ ( list @ A ) @ X @ ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Zs2 ) ) ) ) ) )
=> ~ ( ( Xa2
= ( nil @ A ) )
=> ( ( Y
= ( undefined @ A ) )
=> ~ ( accp @ ( product_prod @ ( A > B ) @ ( list @ A ) ) @ ( arg_min_list_rel @ A @ B ) @ ( product_Pair @ ( A > B ) @ ( list @ A ) @ X @ ( nil @ A ) ) ) ) ) ) ) ) ) ) ).
% arg_min_list.pelims
thf(fact_7747_Inf__fin_Osemilattice__order__set__axioms,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ( lattic4895041142388067077er_set @ A @ ( inf_inf @ A ) @ ( ord_less_eq @ A ) @ ( ord_less @ A ) ) ) ).
% Inf_fin.semilattice_order_set_axioms
thf(fact_7748_Min_Osemilattice__order__set__axioms,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( lattic4895041142388067077er_set @ A @ ( ord_min @ A ) @ ( ord_less_eq @ A ) @ ( ord_less @ A ) ) ) ).
% Min.semilattice_order_set_axioms
thf(fact_7749_Sup__fin_Osemilattice__order__set__axioms,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ( lattic4895041142388067077er_set @ A @ ( sup_sup @ A )
@ ^ [X2: A,Y2: A] : ( ord_less_eq @ A @ Y2 @ X2 )
@ ^ [X2: A,Y2: A] : ( ord_less @ A @ Y2 @ X2 ) ) ) ).
% Sup_fin.semilattice_order_set_axioms
thf(fact_7750_sorted__wrt_Opelims_I1_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A,Y: $o] :
( ( ( sorted_wrt @ A @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( sorted_wrt_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ Xa2 ) )
=> ( ( ( Xa2
= ( nil @ A ) )
=> ( Y
=> ~ ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( sorted_wrt_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( nil @ A ) ) ) ) )
=> ~ ! [X5: A,Ys4: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ Ys4 ) )
=> ( ( Y
= ( ! [Y2: A] :
( ( member2 @ A @ Y2 @ ( set2 @ A @ Ys4 ) )
=> ( X @ X5 @ Y2 ) )
& ( sorted_wrt @ A @ X @ Ys4 ) ) )
=> ~ ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( sorted_wrt_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( cons @ A @ X5 @ Ys4 ) ) ) ) ) ) ) ) ).
% sorted_wrt.pelims(1)
thf(fact_7751_sorted__wrt_Opelims_I2_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A] :
( ( sorted_wrt @ A @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( sorted_wrt_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ Xa2 ) )
=> ( ( ( Xa2
= ( nil @ A ) )
=> ~ ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( sorted_wrt_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( nil @ A ) ) ) )
=> ~ ! [X5: A,Ys4: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ Ys4 ) )
=> ( ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( sorted_wrt_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( cons @ A @ X5 @ Ys4 ) ) )
=> ~ ( ! [Xa: A] :
( ( member2 @ A @ Xa @ ( set2 @ A @ Ys4 ) )
=> ( X @ X5 @ Xa ) )
& ( sorted_wrt @ A @ X @ Ys4 ) ) ) ) ) ) ) ).
% sorted_wrt.pelims(2)
thf(fact_7752_sorted__wrt_Opelims_I3_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A] :
( ~ ( sorted_wrt @ A @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( sorted_wrt_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ Xa2 ) )
=> ~ ! [X5: A,Ys4: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ Ys4 ) )
=> ( ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( sorted_wrt_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( cons @ A @ X5 @ Ys4 ) ) )
=> ( ! [Xa4: A] :
( ( member2 @ A @ Xa4 @ ( set2 @ A @ Ys4 ) )
=> ( X @ X5 @ Xa4 ) )
& ( sorted_wrt @ A @ X @ Ys4 ) ) ) ) ) ) ).
% sorted_wrt.pelims(3)
thf(fact_7753_char__of__take__bit__eq,axiom,
! [A: $tType] :
( ( bit_un5681908812861735899ations @ A )
=> ! [N2: nat,M: A] :
( ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ ( bit0 @ ( bit0 @ ( bit0 @ one2 ) ) ) ) @ N2 )
=> ( ( unique5772411509450598832har_of @ A @ ( bit_se2584673776208193580ke_bit @ A @ N2 @ M ) )
= ( unique5772411509450598832har_of @ A @ M ) ) ) ) ).
% char_of_take_bit_eq
thf(fact_7754_flip__pred,axiom,
! [A: $tType,B: $tType,A4: set @ ( product_prod @ A @ B ),R: B > A > $o] :
( ( ord_less_eq @ ( set @ ( product_prod @ A @ B ) ) @ A4 @ ( collect @ ( product_prod @ A @ B ) @ ( product_case_prod @ A @ B @ $o @ ( conversep @ B @ A @ R ) ) ) )
=> ( ord_less_eq @ ( set @ ( product_prod @ B @ A ) )
@ ( image2 @ ( product_prod @ A @ B ) @ ( product_prod @ B @ A )
@ ( product_case_prod @ A @ B @ ( product_prod @ B @ A )
@ ^ [X2: A,Y2: B] : ( product_Pair @ B @ A @ Y2 @ X2 ) )
@ A4 )
@ ( collect @ ( product_prod @ B @ A ) @ ( product_case_prod @ B @ A @ $o @ R ) ) ) ) ).
% flip_pred
thf(fact_7755_list_Orel__conversep,axiom,
! [B: $tType,A: $tType,R: A > B > $o] :
( ( list_all2 @ B @ A @ ( conversep @ A @ B @ R ) )
= ( conversep @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ R ) ) ) ).
% list.rel_conversep
thf(fact_7756_list_Orel__flip,axiom,
! [A: $tType,B: $tType,R: A > B > $o,A3: list @ B,B2: list @ A] :
( ( list_all2 @ B @ A @ ( conversep @ A @ B @ R ) @ A3 @ B2 )
= ( list_all2 @ A @ B @ R @ B2 @ A3 ) ) ).
% list.rel_flip
thf(fact_7757_inj__on__char__of__nat,axiom,
inj_on @ nat @ char @ ( unique5772411509450598832har_of @ nat ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( numeral_numeral @ nat @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ).
% inj_on_char_of_nat
thf(fact_7758_UNIV__char__of__nat,axiom,
( ( top_top @ ( set @ char ) )
= ( image2 @ nat @ char @ ( unique5772411509450598832har_of @ nat ) @ ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( numeral_numeral @ nat @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ) ) ).
% UNIV_char_of_nat
thf(fact_7759_range__nat__of__char,axiom,
( ( image2 @ char @ nat @ ( comm_s6883823935334413003f_char @ nat ) @ ( top_top @ ( set @ char ) ) )
= ( set_or7035219750837199246ssThan @ nat @ ( zero_zero @ nat ) @ ( numeral_numeral @ nat @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ) ).
% range_nat_of_char
thf(fact_7760_gen__length__def,axiom,
! [A: $tType] :
( ( gen_length @ A )
= ( ^ [N: nat,Xs2: list @ A] : ( plus_plus @ nat @ N @ ( size_size @ ( list @ A ) @ Xs2 ) ) ) ) ).
% gen_length_def
thf(fact_7761_gen__length__code_I1_J,axiom,
! [A: $tType,N2: nat] :
( ( gen_length @ A @ N2 @ ( nil @ A ) )
= N2 ) ).
% gen_length_code(1)
thf(fact_7762_nat__of__char__less__256,axiom,
! [C2: char] : ( ord_less @ nat @ ( comm_s6883823935334413003f_char @ nat @ C2 ) @ ( numeral_numeral @ nat @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ).
% nat_of_char_less_256
thf(fact_7763_gen__length__code_I2_J,axiom,
! [B: $tType,N2: nat,X: B,Xs: list @ B] :
( ( gen_length @ B @ N2 @ ( cons @ B @ X @ Xs ) )
= ( gen_length @ B @ ( suc @ N2 ) @ Xs ) ) ).
% gen_length_code(2)
thf(fact_7764_length__code,axiom,
! [A: $tType] :
( ( size_size @ ( list @ A ) )
= ( gen_length @ A @ ( zero_zero @ nat ) ) ) ).
% length_code
thf(fact_7765_relImage__def,axiom,
! [A: $tType,B: $tType] :
( ( bNF_Gr4221423524335903396lImage @ B @ A )
= ( ^ [R5: set @ ( product_prod @ B @ B ),F3: B > A] :
( collect @ ( product_prod @ A @ A )
@ ^ [Uu3: product_prod @ A @ A] :
? [A1: B,A22: B] :
( ( Uu3
= ( product_Pair @ A @ A @ ( F3 @ A1 ) @ ( F3 @ A22 ) ) )
& ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ A1 @ A22 ) @ R5 ) ) ) ) ) ).
% relImage_def
thf(fact_7766_one__int_Otransfer,axiom,
pcr_int @ ( product_Pair @ nat @ nat @ ( one_one @ nat ) @ ( zero_zero @ nat ) ) @ ( one_one @ int ) ).
% one_int.transfer
thf(fact_7767_zero__int_Otransfer,axiom,
pcr_int @ ( product_Pair @ nat @ nat @ ( zero_zero @ nat ) @ ( zero_zero @ nat ) ) @ ( zero_zero @ int ) ).
% zero_int.transfer
thf(fact_7768_Rats__abs__nat__div__natE,axiom,
! [X: real] :
( ( member2 @ real @ X @ ( field_char_0_Rats @ real ) )
=> ~ ! [M3: nat,N3: nat] :
( ( N3
!= ( zero_zero @ nat ) )
=> ( ( ( abs_abs @ real @ X )
= ( divide_divide @ real @ ( semiring_1_of_nat @ real @ M3 ) @ ( semiring_1_of_nat @ real @ N3 ) ) )
=> ~ ( algebr8660921524188924756oprime @ nat @ M3 @ N3 ) ) ) ) ).
% Rats_abs_nat_div_natE
thf(fact_7769_of__int_Otransfer,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ A @ A @ pcr_int
@ ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ ( product_case_prod @ nat @ nat @ A
@ ^ [I5: nat,J3: nat] : ( minus_minus @ A @ ( semiring_1_of_nat @ A @ I5 ) @ ( semiring_1_of_nat @ A @ J3 ) ) )
@ ( ring_1_of_int @ A ) ) ) ).
% of_int.transfer
thf(fact_7770_coprime__self,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A] :
( ( algebr8660921524188924756oprime @ A @ A3 @ A3 )
= ( dvd_dvd @ A @ A3 @ ( one_one @ A ) ) ) ) ).
% coprime_self
thf(fact_7771_coprime__mod__left__iff,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [B2: A,A3: A] :
( ( B2
!= ( zero_zero @ A ) )
=> ( ( algebr8660921524188924756oprime @ A @ ( modulo_modulo @ A @ A3 @ B2 ) @ B2 )
= ( algebr8660921524188924756oprime @ A @ A3 @ B2 ) ) ) ) ).
% coprime_mod_left_iff
thf(fact_7772_coprime__mod__right__iff,axiom,
! [A: $tType] :
( ( euclid3725896446679973847miring @ A )
=> ! [A3: A,B2: A] :
( ( A3
!= ( zero_zero @ A ) )
=> ( ( algebr8660921524188924756oprime @ A @ A3 @ ( modulo_modulo @ A @ B2 @ A3 ) )
= ( algebr8660921524188924756oprime @ A @ A3 @ B2 ) ) ) ) ).
% coprime_mod_right_iff
thf(fact_7773_coprime__power__left__iff,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [A3: A,N2: nat,B2: A] :
( ( algebr8660921524188924756oprime @ A @ ( power_power @ A @ A3 @ N2 ) @ B2 )
= ( ( algebr8660921524188924756oprime @ A @ A3 @ B2 )
| ( N2
= ( zero_zero @ nat ) ) ) ) ) ).
% coprime_power_left_iff
thf(fact_7774_coprime__power__right__iff,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [A3: A,B2: A,N2: nat] :
( ( algebr8660921524188924756oprime @ A @ A3 @ ( power_power @ A @ B2 @ N2 ) )
= ( ( algebr8660921524188924756oprime @ A @ A3 @ B2 )
| ( N2
= ( zero_zero @ nat ) ) ) ) ) ).
% coprime_power_right_iff
thf(fact_7775_coprime__0__left__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A] :
( ( algebr8660921524188924756oprime @ A @ ( zero_zero @ A ) @ A3 )
= ( dvd_dvd @ A @ A3 @ ( one_one @ A ) ) ) ) ).
% coprime_0_left_iff
thf(fact_7776_coprime__0__right__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A] :
( ( algebr8660921524188924756oprime @ A @ A3 @ ( zero_zero @ A ) )
= ( dvd_dvd @ A @ A3 @ ( one_one @ A ) ) ) ) ).
% coprime_0_right_iff
thf(fact_7777_coprime__mult__self__right__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,C2: A,B2: A] :
( ( algebr8660921524188924756oprime @ A @ ( times_times @ A @ A3 @ C2 ) @ ( times_times @ A @ B2 @ C2 ) )
= ( ( dvd_dvd @ A @ C2 @ ( one_one @ A ) )
& ( algebr8660921524188924756oprime @ A @ A3 @ B2 ) ) ) ) ).
% coprime_mult_self_right_iff
thf(fact_7778_coprime__mult__self__left__iff,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( algebr8660921524188924756oprime @ A @ ( times_times @ A @ C2 @ A3 ) @ ( times_times @ A @ C2 @ B2 ) )
= ( ( dvd_dvd @ A @ C2 @ ( one_one @ A ) )
& ( algebr8660921524188924756oprime @ A @ A3 @ B2 ) ) ) ) ).
% coprime_mult_self_left_iff
thf(fact_7779_minus__int_Otransfer,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ ( int > int ) @ pcr_int @ ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ ( product_prod @ nat @ nat ) @ int @ pcr_int @ pcr_int )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ Y2 @ U2 ) ) ) )
@ ( minus_minus @ int ) ) ).
% minus_int.transfer
thf(fact_7780_plus__int_Otransfer,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ ( int > int ) @ pcr_int @ ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ ( product_prod @ nat @ nat ) @ int @ pcr_int @ pcr_int )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ X2 @ U2 ) @ ( plus_plus @ nat @ Y2 @ V5 ) ) ) )
@ ( plus_plus @ int ) ) ).
% plus_int.transfer
thf(fact_7781_less__int_Otransfer,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ ( ( product_prod @ nat @ nat ) > $o ) @ ( int > $o ) @ pcr_int
@ ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ $o @ $o @ pcr_int
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Y2 ) ) ) )
@ ( ord_less @ int ) ) ).
% less_int.transfer
thf(fact_7782_less__eq__int_Otransfer,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ ( ( product_prod @ nat @ nat ) > $o ) @ ( int > $o ) @ pcr_int
@ ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ $o @ $o @ pcr_int
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less_eq @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Y2 ) ) ) )
@ ( ord_less_eq @ int ) ) ).
% less_eq_int.transfer
thf(fact_7783_foldr__transfer,axiom,
! [A: $tType,B: $tType,D: $tType,C: $tType,A4: A > C > $o,B3: B > D > $o] : ( bNF_rel_fun @ ( A > B > B ) @ ( C > D > D ) @ ( ( list @ A ) > B > B ) @ ( ( list @ C ) > D > D ) @ ( bNF_rel_fun @ A @ C @ ( B > B ) @ ( D > D ) @ A4 @ ( bNF_rel_fun @ B @ D @ B @ D @ B3 @ B3 ) ) @ ( bNF_rel_fun @ ( list @ A ) @ ( list @ C ) @ ( B > B ) @ ( D > D ) @ ( list_all2 @ A @ C @ A4 ) @ ( bNF_rel_fun @ B @ D @ B @ D @ B3 @ B3 ) ) @ ( foldr @ A @ B ) @ ( foldr @ C @ D ) ) ).
% foldr_transfer
thf(fact_7784_List_Ofold__transfer,axiom,
! [A: $tType,B: $tType,D: $tType,C: $tType,A4: A > C > $o,B3: B > D > $o] : ( bNF_rel_fun @ ( A > B > B ) @ ( C > D > D ) @ ( ( list @ A ) > B > B ) @ ( ( list @ C ) > D > D ) @ ( bNF_rel_fun @ A @ C @ ( B > B ) @ ( D > D ) @ A4 @ ( bNF_rel_fun @ B @ D @ B @ D @ B3 @ B3 ) ) @ ( bNF_rel_fun @ ( list @ A ) @ ( list @ C ) @ ( B > B ) @ ( D > D ) @ ( list_all2 @ A @ C @ A4 ) @ ( bNF_rel_fun @ B @ D @ B @ D @ B3 @ B3 ) ) @ ( fold @ A @ B ) @ ( fold @ C @ D ) ) ).
% List.fold_transfer
thf(fact_7785_sum__list__transfer,axiom,
! [A: $tType,B: $tType] :
( ( ( monoid_add @ B )
& ( monoid_add @ A ) )
=> ! [A4: A > B > $o] :
( ( A4 @ ( zero_zero @ A ) @ ( zero_zero @ B ) )
=> ( ( bNF_rel_fun @ A @ B @ ( A > A ) @ ( B > B ) @ A4 @ ( bNF_rel_fun @ A @ B @ A @ B @ A4 @ A4 ) @ ( plus_plus @ A ) @ ( plus_plus @ B ) )
=> ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ A @ B @ ( list_all2 @ A @ B @ A4 ) @ A4 @ ( groups8242544230860333062m_list @ A ) @ ( groups8242544230860333062m_list @ B ) ) ) ) ) ).
% sum_list_transfer
thf(fact_7786_foldl__transfer,axiom,
! [A: $tType,B: $tType,D: $tType,C: $tType,B3: A > C > $o,A4: B > D > $o] : ( bNF_rel_fun @ ( A > B > A ) @ ( C > D > C ) @ ( A > ( list @ B ) > A ) @ ( C > ( list @ D ) > C ) @ ( bNF_rel_fun @ A @ C @ ( B > A ) @ ( D > C ) @ B3 @ ( bNF_rel_fun @ B @ D @ A @ C @ A4 @ B3 ) ) @ ( bNF_rel_fun @ A @ C @ ( ( list @ B ) > A ) @ ( ( list @ D ) > C ) @ B3 @ ( bNF_rel_fun @ ( list @ B ) @ ( list @ D ) @ A @ C @ ( list_all2 @ B @ D @ A4 ) @ B3 ) ) @ ( foldl @ A @ B ) @ ( foldl @ C @ D ) ) ).
% foldl_transfer
thf(fact_7787_horner__sum__transfer,axiom,
! [C: $tType,A: $tType,B: $tType,D: $tType] :
( ( ( comm_semiring_0 @ B )
& ( comm_semiring_0 @ A ) )
=> ! [A4: A > B > $o,B3: C > D > $o] :
( ( A4 @ ( zero_zero @ A ) @ ( zero_zero @ B ) )
=> ( ( bNF_rel_fun @ A @ B @ ( A > A ) @ ( B > B ) @ A4 @ ( bNF_rel_fun @ A @ B @ A @ B @ A4 @ A4 ) @ ( plus_plus @ A ) @ ( plus_plus @ B ) )
=> ( ( bNF_rel_fun @ A @ B @ ( A > A ) @ ( B > B ) @ A4 @ ( bNF_rel_fun @ A @ B @ A @ B @ A4 @ A4 ) @ ( times_times @ A ) @ ( times_times @ B ) )
=> ( bNF_rel_fun @ ( C > A ) @ ( D > B ) @ ( A > ( list @ C ) > A ) @ ( B > ( list @ D ) > B ) @ ( bNF_rel_fun @ C @ D @ A @ B @ B3 @ A4 ) @ ( bNF_rel_fun @ A @ B @ ( ( list @ C ) > A ) @ ( ( list @ D ) > B ) @ A4 @ ( bNF_rel_fun @ ( list @ C ) @ ( list @ D ) @ A @ B @ ( list_all2 @ C @ D @ B3 ) @ A4 ) ) @ ( groups4207007520872428315er_sum @ C @ A ) @ ( groups4207007520872428315er_sum @ D @ B ) ) ) ) ) ) ).
% horner_sum_transfer
thf(fact_7788_prod__list__coprime__left,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [Xs: list @ A,A3: A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( algebr8660921524188924756oprime @ A @ X5 @ A3 ) )
=> ( algebr8660921524188924756oprime @ A @ ( groups5270119922927024881d_list @ A @ Xs ) @ A3 ) ) ) ).
% prod_list_coprime_left
thf(fact_7789_prod__list__coprime__right,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [Xs: list @ A,A3: A] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( algebr8660921524188924756oprime @ A @ A3 @ X5 ) )
=> ( algebr8660921524188924756oprime @ A @ A3 @ ( groups5270119922927024881d_list @ A @ Xs ) ) ) ) ).
% prod_list_coprime_right
thf(fact_7790_coprime__Suc__0__left,axiom,
! [N2: nat] : ( algebr8660921524188924756oprime @ nat @ ( suc @ ( zero_zero @ nat ) ) @ N2 ) ).
% coprime_Suc_0_left
thf(fact_7791_coprime__Suc__0__right,axiom,
! [N2: nat] : ( algebr8660921524188924756oprime @ nat @ N2 @ ( suc @ ( zero_zero @ nat ) ) ) ).
% coprime_Suc_0_right
thf(fact_7792_coprime__add__one__left,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [A3: A] : ( algebr8660921524188924756oprime @ A @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) @ A3 ) ) ).
% coprime_add_one_left
thf(fact_7793_coprime__add__one__right,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [A3: A] : ( algebr8660921524188924756oprime @ A @ A3 @ ( plus_plus @ A @ A3 @ ( one_one @ A ) ) ) ) ).
% coprime_add_one_right
thf(fact_7794_is__unit__right__imp__coprime,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [B2: A,A3: A] :
( ( dvd_dvd @ A @ B2 @ ( one_one @ A ) )
=> ( algebr8660921524188924756oprime @ A @ A3 @ B2 ) ) ) ).
% is_unit_right_imp_coprime
thf(fact_7795_is__unit__left__imp__coprime,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ( dvd_dvd @ A @ A3 @ ( one_one @ A ) )
=> ( algebr8660921524188924756oprime @ A @ A3 @ B2 ) ) ) ).
% is_unit_left_imp_coprime
thf(fact_7796_coprime__common__divisor,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A,C2: A] :
( ( algebr8660921524188924756oprime @ A @ A3 @ B2 )
=> ( ( dvd_dvd @ A @ C2 @ A3 )
=> ( ( dvd_dvd @ A @ C2 @ B2 )
=> ( dvd_dvd @ A @ C2 @ ( one_one @ A ) ) ) ) ) ) ).
% coprime_common_divisor
thf(fact_7797_coprime__absorb__right,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [Y: A,X: A] :
( ( dvd_dvd @ A @ Y @ X )
=> ( ( algebr8660921524188924756oprime @ A @ X @ Y )
= ( dvd_dvd @ A @ Y @ ( one_one @ A ) ) ) ) ) ).
% coprime_absorb_right
thf(fact_7798_coprime__imp__coprime,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [C2: A,D2: A,A3: A,B2: A] :
( ( algebr8660921524188924756oprime @ A @ C2 @ D2 )
=> ( ! [E: A] :
( ~ ( dvd_dvd @ A @ E @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ E @ A3 )
=> ( ( dvd_dvd @ A @ E @ B2 )
=> ( dvd_dvd @ A @ E @ C2 ) ) ) )
=> ( ! [E: A] :
( ~ ( dvd_dvd @ A @ E @ ( one_one @ A ) )
=> ( ( dvd_dvd @ A @ E @ A3 )
=> ( ( dvd_dvd @ A @ E @ B2 )
=> ( dvd_dvd @ A @ E @ D2 ) ) ) )
=> ( algebr8660921524188924756oprime @ A @ A3 @ B2 ) ) ) ) ) ).
% coprime_imp_coprime
thf(fact_7799_coprime__absorb__left,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [X: A,Y: A] :
( ( dvd_dvd @ A @ X @ Y )
=> ( ( algebr8660921524188924756oprime @ A @ X @ Y )
= ( dvd_dvd @ A @ X @ ( one_one @ A ) ) ) ) ) ).
% coprime_absorb_left
thf(fact_7800_not__coprimeI,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [C2: A,A3: A,B2: A] :
( ( dvd_dvd @ A @ C2 @ A3 )
=> ( ( dvd_dvd @ A @ C2 @ B2 )
=> ( ~ ( dvd_dvd @ A @ C2 @ ( one_one @ A ) )
=> ~ ( algebr8660921524188924756oprime @ A @ A3 @ B2 ) ) ) ) ) ).
% not_coprimeI
thf(fact_7801_not__coprimeE,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ~ ( algebr8660921524188924756oprime @ A @ A3 @ B2 )
=> ~ ! [C4: A] :
( ( dvd_dvd @ A @ C4 @ A3 )
=> ( ( dvd_dvd @ A @ C4 @ B2 )
=> ( dvd_dvd @ A @ C4 @ ( one_one @ A ) ) ) ) ) ) ).
% not_coprimeE
thf(fact_7802_coprime__def,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ( ( algebr8660921524188924756oprime @ A )
= ( ^ [A5: A,B4: A] :
! [C3: A] :
( ( dvd_dvd @ A @ C3 @ A5 )
=> ( ( dvd_dvd @ A @ C3 @ B4 )
=> ( dvd_dvd @ A @ C3 @ ( one_one @ A ) ) ) ) ) ) ) ).
% coprime_def
thf(fact_7803_coprimeI,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,B2: A] :
( ! [C4: A] :
( ( dvd_dvd @ A @ C4 @ A3 )
=> ( ( dvd_dvd @ A @ C4 @ B2 )
=> ( dvd_dvd @ A @ C4 @ ( one_one @ A ) ) ) )
=> ( algebr8660921524188924756oprime @ A @ A3 @ B2 ) ) ) ).
% coprimeI
thf(fact_7804_coprime__divisors,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A,C2: A,B2: A,D2: A] :
( ( dvd_dvd @ A @ A3 @ C2 )
=> ( ( dvd_dvd @ A @ B2 @ D2 )
=> ( ( algebr8660921524188924756oprime @ A @ C2 @ D2 )
=> ( algebr8660921524188924756oprime @ A @ A3 @ B2 ) ) ) ) ) ).
% coprime_divisors
thf(fact_7805_transfer__rule__numeral,axiom,
! [A: $tType,B: $tType] :
( ( ( monoid_add @ B )
& ( semiring_numeral @ B )
& ( monoid_add @ A )
& ( semiring_numeral @ A ) )
=> ! [R: A > B > $o] :
( ( R @ ( zero_zero @ A ) @ ( zero_zero @ B ) )
=> ( ( R @ ( one_one @ A ) @ ( one_one @ B ) )
=> ( ( bNF_rel_fun @ A @ B @ ( A > A ) @ ( B > B ) @ R @ ( bNF_rel_fun @ A @ B @ A @ B @ R @ R ) @ ( plus_plus @ A ) @ ( plus_plus @ B ) )
=> ( bNF_rel_fun @ num @ num @ A @ B
@ ^ [Y5: num,Z3: num] : ( Y5 = Z3 )
@ R
@ ( numeral_numeral @ A )
@ ( numeral_numeral @ B ) ) ) ) ) ) ).
% transfer_rule_numeral
thf(fact_7806_coprime__Suc__left__nat,axiom,
! [N2: nat] : ( algebr8660921524188924756oprime @ nat @ ( suc @ N2 ) @ N2 ) ).
% coprime_Suc_left_nat
thf(fact_7807_coprime__Suc__right__nat,axiom,
! [N2: nat] : ( algebr8660921524188924756oprime @ nat @ N2 @ ( suc @ N2 ) ) ).
% coprime_Suc_right_nat
thf(fact_7808_coprime__commute,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ( ( algebr8660921524188924756oprime @ A )
= ( ^ [B4: A,A5: A] : ( algebr8660921524188924756oprime @ A @ A5 @ B4 ) ) ) ) ).
% coprime_commute
thf(fact_7809_coprime__1__right,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A] : ( algebr8660921524188924756oprime @ A @ A3 @ ( one_one @ A ) ) ) ).
% coprime_1_right
thf(fact_7810_coprime__1__left,axiom,
! [A: $tType] :
( ( algebraic_semidom @ A )
=> ! [A3: A] : ( algebr8660921524188924756oprime @ A @ ( one_one @ A ) @ A3 ) ) ).
% coprime_1_left
thf(fact_7811_transfer__rule__of__int,axiom,
! [A: $tType,B: $tType] :
( ( ( ring_1 @ B )
& ( ring_1 @ A ) )
=> ! [R: A > B > $o] :
( ( R @ ( zero_zero @ A ) @ ( zero_zero @ B ) )
=> ( ( R @ ( one_one @ A ) @ ( one_one @ B ) )
=> ( ( bNF_rel_fun @ A @ B @ ( A > A ) @ ( B > B ) @ R @ ( bNF_rel_fun @ A @ B @ A @ B @ R @ R ) @ ( plus_plus @ A ) @ ( plus_plus @ B ) )
=> ( ( bNF_rel_fun @ A @ B @ A @ B @ R @ R @ ( uminus_uminus @ A ) @ ( uminus_uminus @ B ) )
=> ( bNF_rel_fun @ int @ int @ A @ B
@ ^ [Y5: int,Z3: int] : ( Y5 = Z3 )
@ R
@ ( ring_1_of_int @ A )
@ ( ring_1_of_int @ B ) ) ) ) ) ) ) ).
% transfer_rule_of_int
thf(fact_7812_list_Orec__transfer,axiom,
! [C: $tType,A: $tType,B: $tType,D: $tType,S3: C > D > $o,R: A > B > $o] : ( bNF_rel_fun @ C @ D @ ( ( A > ( list @ A ) > C > C ) > ( list @ A ) > C ) @ ( ( B > ( list @ B ) > D > D ) > ( list @ B ) > D ) @ S3 @ ( bNF_rel_fun @ ( A > ( list @ A ) > C > C ) @ ( B > ( list @ B ) > D > D ) @ ( ( list @ A ) > C ) @ ( ( list @ B ) > D ) @ ( bNF_rel_fun @ A @ B @ ( ( list @ A ) > C > C ) @ ( ( list @ B ) > D > D ) @ R @ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( C > C ) @ ( D > D ) @ ( list_all2 @ A @ B @ R ) @ ( bNF_rel_fun @ C @ D @ C @ D @ S3 @ S3 ) ) ) @ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ C @ D @ ( list_all2 @ A @ B @ R ) @ S3 ) ) @ ( rec_list @ C @ A ) @ ( rec_list @ D @ B ) ) ).
% list.rec_transfer
thf(fact_7813_list_Omap__transfer,axiom,
! [A: $tType,B: $tType,F: $tType,E2: $tType,Rb2: A > E2 > $o,Sd: B > F > $o] : ( bNF_rel_fun @ ( A > B ) @ ( E2 > F ) @ ( ( list @ A ) > ( list @ B ) ) @ ( ( list @ E2 ) > ( list @ F ) ) @ ( bNF_rel_fun @ A @ E2 @ B @ F @ Rb2 @ Sd ) @ ( bNF_rel_fun @ ( list @ A ) @ ( list @ E2 ) @ ( list @ B ) @ ( list @ F ) @ ( list_all2 @ A @ E2 @ Rb2 ) @ ( list_all2 @ B @ F @ Sd ) ) @ ( map @ A @ B ) @ ( map @ E2 @ F ) ) ).
% list.map_transfer
thf(fact_7814_times__int_Otransfer,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ ( int > int ) @ pcr_int @ ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ ( product_prod @ nat @ nat ) @ int @ pcr_int @ pcr_int )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ X2 @ U2 ) @ ( times_times @ nat @ Y2 @ V5 ) ) @ ( plus_plus @ nat @ ( times_times @ nat @ X2 @ V5 ) @ ( times_times @ nat @ Y2 @ U2 ) ) ) ) )
@ ( times_times @ int ) ) ).
% times_int.transfer
thf(fact_7815_coprime__diff__one__right__nat,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( algebr8660921524188924756oprime @ nat @ N2 @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) ) ) ).
% coprime_diff_one_right_nat
thf(fact_7816_coprime__diff__one__left__nat,axiom,
! [N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( algebr8660921524188924756oprime @ nat @ ( minus_minus @ nat @ N2 @ ( one_one @ nat ) ) @ N2 ) ) ).
% coprime_diff_one_left_nat
thf(fact_7817_uminus__int_Otransfer,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ ( product_prod @ nat @ nat ) @ int @ pcr_int @ pcr_int
@ ( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [X2: nat,Y2: nat] : ( product_Pair @ nat @ nat @ Y2 @ X2 ) )
@ ( uminus_uminus @ int ) ) ).
% uminus_int.transfer
thf(fact_7818_nat_Otransfer,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ nat @ nat @ pcr_int
@ ^ [Y5: nat,Z3: nat] : ( Y5 = Z3 )
@ ( product_case_prod @ nat @ nat @ nat @ ( minus_minus @ nat ) )
@ nat2 ) ).
% nat.transfer
thf(fact_7819_transfer__rule__of__nat,axiom,
! [A: $tType,B: $tType] :
( ( ( semiring_1 @ B )
& ( semiring_1 @ A ) )
=> ! [R: A > B > $o] :
( ( R @ ( zero_zero @ A ) @ ( zero_zero @ B ) )
=> ( ( R @ ( one_one @ A ) @ ( one_one @ B ) )
=> ( ( bNF_rel_fun @ A @ B @ ( A > A ) @ ( B > B ) @ R @ ( bNF_rel_fun @ A @ B @ A @ B @ R @ R ) @ ( plus_plus @ A ) @ ( plus_plus @ B ) )
=> ( bNF_rel_fun @ nat @ nat @ A @ B
@ ^ [Y5: nat,Z3: nat] : ( Y5 = Z3 )
@ R
@ ( semiring_1_of_nat @ A )
@ ( semiring_1_of_nat @ B ) ) ) ) ) ) ).
% transfer_rule_of_nat
thf(fact_7820_prod__set__simps_I1_J,axiom,
! [B: $tType,A: $tType,X: A,Y: B] :
( ( basic_fsts @ A @ B @ ( product_Pair @ A @ B @ X @ Y ) )
= ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ).
% prod_set_simps(1)
thf(fact_7821_list_Octr__transfer_I2_J,axiom,
! [A: $tType,B: $tType,R: A > B > $o] : ( bNF_rel_fun @ A @ B @ ( ( list @ A ) > ( list @ A ) ) @ ( ( list @ B ) > ( list @ B ) ) @ R @ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ R ) @ ( list_all2 @ A @ B @ R ) ) @ ( cons @ A ) @ ( cons @ B ) ) ).
% list.ctr_transfer(2)
thf(fact_7822_butlast__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] : ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) @ ( butlast @ A ) @ ( butlast @ B ) ) ).
% butlast_transfer
thf(fact_7823_list_Ocase__transfer,axiom,
! [C: $tType,A: $tType,B: $tType,D: $tType,S3: C > D > $o,R: A > B > $o] : ( bNF_rel_fun @ C @ D @ ( ( A > ( list @ A ) > C ) > ( list @ A ) > C ) @ ( ( B > ( list @ B ) > D ) > ( list @ B ) > D ) @ S3 @ ( bNF_rel_fun @ ( A > ( list @ A ) > C ) @ ( B > ( list @ B ) > D ) @ ( ( list @ A ) > C ) @ ( ( list @ B ) > D ) @ ( bNF_rel_fun @ A @ B @ ( ( list @ A ) > C ) @ ( ( list @ B ) > D ) @ R @ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ C @ D @ ( list_all2 @ A @ B @ R ) @ S3 ) ) @ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ C @ D @ ( list_all2 @ A @ B @ R ) @ S3 ) ) @ ( case_list @ C @ A ) @ ( case_list @ D @ B ) ) ).
% list.case_transfer
thf(fact_7824_rev__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] : ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) @ ( rev @ A ) @ ( rev @ B ) ) ).
% rev_transfer
thf(fact_7825_length__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ nat @ nat @ ( list_all2 @ A @ B @ A4 )
@ ^ [Y5: nat,Z3: nat] : ( Y5 = Z3 )
@ ( size_size @ ( list @ A ) )
@ ( size_size @ ( list @ B ) ) ) ).
% length_transfer
thf(fact_7826_drop__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ nat @ nat @ ( ( list @ A ) > ( list @ A ) ) @ ( ( list @ B ) > ( list @ B ) )
@ ^ [Y5: nat,Z3: nat] : ( Y5 = Z3 )
@ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) )
@ ( drop @ A )
@ ( drop @ B ) ) ).
% drop_transfer
thf(fact_7827_take__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ nat @ nat @ ( ( list @ A ) > ( list @ A ) ) @ ( ( list @ B ) > ( list @ B ) )
@ ^ [Y5: nat,Z3: nat] : ( Y5 = Z3 )
@ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) )
@ ( take @ A )
@ ( take @ B ) ) ).
% take_transfer
thf(fact_7828_replicate__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ nat @ nat @ ( A > ( list @ A ) ) @ ( B > ( list @ B ) )
@ ^ [Y5: nat,Z3: nat] : ( Y5 = Z3 )
@ ( bNF_rel_fun @ A @ B @ ( list @ A ) @ ( list @ B ) @ A4 @ ( list_all2 @ A @ B @ A4 ) )
@ ( replicate @ A )
@ ( replicate @ B ) ) ).
% replicate_transfer
thf(fact_7829_subseqs__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] : ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ ( list @ A ) ) @ ( list @ ( list @ B ) ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) ) @ ( subseqs @ A ) @ ( subseqs @ B ) ) ).
% subseqs_transfer
thf(fact_7830_list__update__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( nat > A > ( list @ A ) ) @ ( nat > B > ( list @ B ) ) @ ( list_all2 @ A @ B @ A4 )
@ ( bNF_rel_fun @ nat @ nat @ ( A > ( list @ A ) ) @ ( B > ( list @ B ) )
@ ^ [Y5: nat,Z3: nat] : ( Y5 = Z3 )
@ ( bNF_rel_fun @ A @ B @ ( list @ A ) @ ( list @ B ) @ A4 @ ( list_all2 @ A @ B @ A4 ) ) )
@ ( list_update @ A )
@ ( list_update @ B ) ) ).
% list_update_transfer
thf(fact_7831_list_Orel__transfer,axiom,
! [A: $tType,B: $tType,D: $tType,C: $tType,Sa: A > C > $o,Sc: B > D > $o] :
( bNF_rel_fun @ ( A > B > $o ) @ ( C > D > $o ) @ ( ( list @ A ) > ( list @ B ) > $o ) @ ( ( list @ C ) > ( list @ D ) > $o )
@ ( bNF_rel_fun @ A @ C @ ( B > $o ) @ ( D > $o ) @ Sa
@ ( bNF_rel_fun @ B @ D @ $o @ $o @ Sc
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) ) )
@ ( bNF_rel_fun @ ( list @ A ) @ ( list @ C ) @ ( ( list @ B ) > $o ) @ ( ( list @ D ) > $o ) @ ( list_all2 @ A @ C @ Sa )
@ ( bNF_rel_fun @ ( list @ B ) @ ( list @ D ) @ $o @ $o @ ( list_all2 @ B @ D @ Sc )
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) ) )
@ ( list_all2 @ A @ B )
@ ( list_all2 @ C @ D ) ) ).
% list.rel_transfer
thf(fact_7832_splice__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] : ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( ( list @ A ) > ( list @ A ) ) @ ( ( list @ B ) > ( list @ B ) ) @ ( list_all2 @ A @ B @ A4 ) @ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) ) @ ( splice @ A ) @ ( splice @ B ) ) ).
% splice_transfer
thf(fact_7833_rotate1__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] : ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) @ ( rotate1 @ A ) @ ( rotate1 @ B ) ) ).
% rotate1_transfer
thf(fact_7834_product__lists__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] : ( bNF_rel_fun @ ( list @ ( list @ A ) ) @ ( list @ ( list @ B ) ) @ ( list @ ( list @ A ) ) @ ( list @ ( list @ B ) ) @ ( list_all2 @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) ) @ ( list_all2 @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) ) @ ( product_lists @ A ) @ ( product_lists @ B ) ) ).
% product_lists_transfer
thf(fact_7835_concat__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] : ( bNF_rel_fun @ ( list @ ( list @ A ) ) @ ( list @ ( list @ B ) ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) ) @ ( list_all2 @ A @ B @ A4 ) @ ( concat @ A ) @ ( concat @ B ) ) ).
% concat_transfer
thf(fact_7836_append__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] : ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( ( list @ A ) > ( list @ A ) ) @ ( ( list @ B ) > ( list @ B ) ) @ ( list_all2 @ A @ B @ A4 ) @ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) ) @ ( append @ A ) @ ( append @ B ) ) ).
% append_transfer
thf(fact_7837_tl__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] : ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) @ ( tl @ A ) @ ( tl @ B ) ) ).
% tl_transfer
thf(fact_7838_List_Ofilter__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ ( A > $o ) @ ( B > $o ) @ ( ( list @ A ) > ( list @ A ) ) @ ( ( list @ B ) > ( list @ B ) )
@ ( bNF_rel_fun @ A @ B @ $o @ $o @ A4
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) )
@ ( filter2 @ A )
@ ( filter2 @ B ) ) ).
% List.filter_transfer
thf(fact_7839_takeWhile__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ ( A > $o ) @ ( B > $o ) @ ( ( list @ A ) > ( list @ A ) ) @ ( ( list @ B ) > ( list @ B ) )
@ ( bNF_rel_fun @ A @ B @ $o @ $o @ A4
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) )
@ ( takeWhile @ A )
@ ( takeWhile @ B ) ) ).
% takeWhile_transfer
thf(fact_7840_dropWhile__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ ( A > $o ) @ ( B > $o ) @ ( ( list @ A ) > ( list @ A ) ) @ ( ( list @ B ) > ( list @ B ) )
@ ( bNF_rel_fun @ A @ B @ $o @ $o @ A4
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) )
@ ( dropWhile @ A )
@ ( dropWhile @ B ) ) ).
% dropWhile_transfer
thf(fact_7841_rotate__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ nat @ nat @ ( ( list @ A ) > ( list @ A ) ) @ ( ( list @ B ) > ( list @ B ) )
@ ^ [Y5: nat,Z3: nat] : ( Y5 = Z3 )
@ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ A4 ) @ ( list_all2 @ A @ B @ A4 ) )
@ ( rotate @ A )
@ ( rotate @ B ) ) ).
% rotate_transfer
thf(fact_7842_transfer__rule__of__bool,axiom,
! [A: $tType,B: $tType] :
( ( ( zero_neq_one @ B )
& ( zero_neq_one @ A ) )
=> ! [R: A > B > $o] :
( ( R @ ( zero_zero @ A ) @ ( zero_zero @ B ) )
=> ( ( R @ ( one_one @ A ) @ ( one_one @ B ) )
=> ( bNF_rel_fun @ $o @ $o @ A @ B
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 )
@ R
@ ( zero_neq_one_of_bool @ A )
@ ( zero_neq_one_of_bool @ B ) ) ) ) ) ).
% transfer_rule_of_bool
thf(fact_7843_list_Odisc__transfer_I2_J,axiom,
! [A: $tType,B: $tType,R: A > B > $o] :
( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ $o @ $o @ ( list_all2 @ A @ B @ R )
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 )
@ ^ [List2: list @ A] :
( List2
!= ( nil @ A ) )
@ ^ [List2: list @ B] :
( List2
!= ( nil @ B ) ) ) ).
% list.disc_transfer(2)
thf(fact_7844_list_Odisc__transfer_I1_J,axiom,
! [A: $tType,B: $tType,R: A > B > $o] :
( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ $o @ $o @ ( list_all2 @ A @ B @ R )
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 )
@ ^ [List2: list @ A] :
( List2
= ( nil @ A ) )
@ ^ [List2: list @ B] :
( List2
= ( nil @ B ) ) ) ).
% list.disc_transfer(1)
thf(fact_7845_int__transfer,axiom,
( bNF_rel_fun @ nat @ nat @ ( product_prod @ nat @ nat ) @ int
@ ^ [Y5: nat,Z3: nat] : ( Y5 = Z3 )
@ pcr_int
@ ^ [N: nat] : ( product_Pair @ nat @ nat @ N @ ( zero_zero @ nat ) )
@ ( semiring_1_of_nat @ int ) ) ).
% int_transfer
thf(fact_7846_prod__set__defs_I1_J,axiom,
! [B: $tType,A: $tType] :
( ( basic_fsts @ A @ B )
= ( ^ [P6: product_prod @ A @ B] : ( insert2 @ A @ ( product_fst @ A @ B @ P6 ) @ ( bot_bot @ ( set @ A ) ) ) ) ) ).
% prod_set_defs(1)
thf(fact_7847_times__int_Orsp,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ intrel @ ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ intrel @ intrel )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ X2 @ U2 ) @ ( times_times @ nat @ Y2 @ V5 ) ) @ ( plus_plus @ nat @ ( times_times @ nat @ X2 @ V5 ) @ ( times_times @ nat @ Y2 @ U2 ) ) ) ) )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ ( times_times @ nat @ X2 @ U2 ) @ ( times_times @ nat @ Y2 @ V5 ) ) @ ( plus_plus @ nat @ ( times_times @ nat @ X2 @ V5 ) @ ( times_times @ nat @ Y2 @ U2 ) ) ) ) ) ) ).
% times_int.rsp
thf(fact_7848_intrel__iff,axiom,
! [X: nat,Y: nat,U: nat,V2: nat] :
( ( intrel @ ( product_Pair @ nat @ nat @ X @ Y ) @ ( product_Pair @ nat @ nat @ U @ V2 ) )
= ( ( plus_plus @ nat @ X @ V2 )
= ( plus_plus @ nat @ U @ Y ) ) ) ).
% intrel_iff
thf(fact_7849_nat_Orsp,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ nat @ nat @ intrel
@ ^ [Y5: nat,Z3: nat] : ( Y5 = Z3 )
@ ( product_case_prod @ nat @ nat @ nat @ ( minus_minus @ nat ) )
@ ( product_case_prod @ nat @ nat @ nat @ ( minus_minus @ nat ) ) ) ).
% nat.rsp
thf(fact_7850_uminus__int_Orsp,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ intrel @ intrel
@ ( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [X2: nat,Y2: nat] : ( product_Pair @ nat @ nat @ Y2 @ X2 ) )
@ ( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [X2: nat,Y2: nat] : ( product_Pair @ nat @ nat @ Y2 @ X2 ) ) ) ).
% uminus_int.rsp
thf(fact_7851_zero__int_Orsp,axiom,
intrel @ ( product_Pair @ nat @ nat @ ( zero_zero @ nat ) @ ( zero_zero @ nat ) ) @ ( product_Pair @ nat @ nat @ ( zero_zero @ nat ) @ ( zero_zero @ nat ) ) ).
% zero_int.rsp
thf(fact_7852_int_Oabs__eq__iff,axiom,
! [X: product_prod @ nat @ nat,Y: product_prod @ nat @ nat] :
( ( ( abs_Integ @ X )
= ( abs_Integ @ Y ) )
= ( intrel @ X @ Y ) ) ).
% int.abs_eq_iff
thf(fact_7853_one__int_Orsp,axiom,
intrel @ ( product_Pair @ nat @ nat @ ( one_one @ nat ) @ ( zero_zero @ nat ) ) @ ( product_Pair @ nat @ nat @ ( one_one @ nat ) @ ( zero_zero @ nat ) ) ).
% one_int.rsp
thf(fact_7854_of__int_Orsp,axiom,
! [A: $tType] :
( ( ring_1 @ A )
=> ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ A @ A @ intrel
@ ^ [Y5: A,Z3: A] : ( Y5 = Z3 )
@ ( product_case_prod @ nat @ nat @ A
@ ^ [I5: nat,J3: nat] : ( minus_minus @ A @ ( semiring_1_of_nat @ A @ I5 ) @ ( semiring_1_of_nat @ A @ J3 ) ) )
@ ( product_case_prod @ nat @ nat @ A
@ ^ [I5: nat,J3: nat] : ( minus_minus @ A @ ( semiring_1_of_nat @ A @ I5 ) @ ( semiring_1_of_nat @ A @ J3 ) ) ) ) ) ).
% of_int.rsp
thf(fact_7855_intrel__def,axiom,
( intrel
= ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] :
( ( plus_plus @ nat @ X2 @ V5 )
= ( plus_plus @ nat @ U2 @ Y2 ) ) ) ) ) ).
% intrel_def
thf(fact_7856_less__int_Orsp,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( ( product_prod @ nat @ nat ) > $o ) @ ( ( product_prod @ nat @ nat ) > $o ) @ intrel
@ ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ $o @ $o @ intrel
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Y2 ) ) ) )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Y2 ) ) ) ) ) ).
% less_int.rsp
thf(fact_7857_less__eq__int_Orsp,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( ( product_prod @ nat @ nat ) > $o ) @ ( ( product_prod @ nat @ nat ) > $o ) @ intrel
@ ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ $o @ $o @ intrel
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less_eq @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Y2 ) ) ) )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > $o )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ $o
@ ^ [U2: nat,V5: nat] : ( ord_less_eq @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ U2 @ Y2 ) ) ) ) ) ).
% less_eq_int.rsp
thf(fact_7858_int_Orel__eq__transfer,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ ( ( product_prod @ nat @ nat ) > $o ) @ ( int > $o ) @ pcr_int
@ ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ int @ $o @ $o @ pcr_int
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ intrel
@ ^ [Y5: int,Z3: int] : ( Y5 = Z3 ) ) ).
% int.rel_eq_transfer
thf(fact_7859_plus__int_Orsp,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ intrel @ ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ intrel @ intrel )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ X2 @ U2 ) @ ( plus_plus @ nat @ Y2 @ V5 ) ) ) )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ X2 @ U2 ) @ ( plus_plus @ nat @ Y2 @ V5 ) ) ) ) ) ).
% plus_int.rsp
thf(fact_7860_minus__int_Orsp,axiom,
( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) ) @ intrel @ ( bNF_rel_fun @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ ( product_prod @ nat @ nat ) @ intrel @ intrel )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ Y2 @ U2 ) ) ) )
@ ( product_case_prod @ nat @ nat @ ( ( product_prod @ nat @ nat ) > ( product_prod @ nat @ nat ) )
@ ^ [X2: nat,Y2: nat] :
( product_case_prod @ nat @ nat @ ( product_prod @ nat @ nat )
@ ^ [U2: nat,V5: nat] : ( product_Pair @ nat @ nat @ ( plus_plus @ nat @ X2 @ V5 ) @ ( plus_plus @ nat @ Y2 @ U2 ) ) ) ) ) ).
% minus_int.rsp
thf(fact_7861_null__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ $o @ $o @ ( list_all2 @ A @ B @ A4 )
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 )
@ ( null @ A )
@ ( null @ B ) ) ).
% null_transfer
thf(fact_7862_list__ex__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ ( A > $o ) @ ( B > $o ) @ ( ( list @ A ) > $o ) @ ( ( list @ B ) > $o )
@ ( bNF_rel_fun @ A @ B @ $o @ $o @ A4
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ $o @ $o @ ( list_all2 @ A @ B @ A4 )
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( list_ex @ A )
@ ( list_ex @ B ) ) ).
% list_ex_transfer
thf(fact_7863_list__ex__simps_I1_J,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A] :
( ( list_ex @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( ( P2 @ X )
| ( list_ex @ A @ P2 @ Xs ) ) ) ).
% list_ex_simps(1)
thf(fact_7864_list__ex__simps_I2_J,axiom,
! [A: $tType,P2: A > $o] :
~ ( list_ex @ A @ P2 @ ( nil @ A ) ) ).
% list_ex_simps(2)
thf(fact_7865_list__ex__append,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A,Ys: list @ A] :
( ( list_ex @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( ( list_ex @ A @ P2 @ Xs )
| ( list_ex @ A @ P2 @ Ys ) ) ) ).
% list_ex_append
thf(fact_7866_list__ex__rev,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( list_ex @ A @ P2 @ ( rev @ A @ Xs ) )
= ( list_ex @ A @ P2 @ Xs ) ) ).
% list_ex_rev
thf(fact_7867_eq__Nil__null,axiom,
! [A: $tType,Xs: list @ A] :
( ( Xs
= ( nil @ A ) )
= ( null @ A @ Xs ) ) ).
% eq_Nil_null
thf(fact_7868_null__rec_I2_J,axiom,
! [B: $tType] : ( null @ B @ ( nil @ B ) ) ).
% null_rec(2)
thf(fact_7869_list__ex__cong,axiom,
! [A: $tType,Xs: list @ A,Ys: list @ A,F2: A > $o,G: A > $o] :
( ( Xs = Ys )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Ys ) )
=> ( ( F2 @ X5 )
= ( G @ X5 ) ) )
=> ( ( list_ex @ A @ F2 @ Xs )
= ( list_ex @ A @ G @ Ys ) ) ) ) ).
% list_ex_cong
thf(fact_7870_null__rec_I1_J,axiom,
! [A: $tType,X: A,Xs: list @ A] :
~ ( null @ A @ ( cons @ A @ X @ Xs ) ) ).
% null_rec(1)
thf(fact_7871_Bex__set__list__ex,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ( ? [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
& ( P2 @ X2 ) ) )
= ( list_ex @ A @ P2 @ Xs ) ) ).
% Bex_set_list_ex
thf(fact_7872_list__ex__length,axiom,
! [A: $tType] :
( ( list_ex @ A )
= ( ^ [P: A > $o,Xs2: list @ A] :
? [N: nat] :
( ( ord_less @ nat @ N @ ( size_size @ ( list @ A ) @ Xs2 ) )
& ( P @ ( nth @ A @ Xs2 @ N ) ) ) ) ) ).
% list_ex_length
thf(fact_7873_is__empty__set,axiom,
! [A: $tType,Xs: list @ A] :
( ( is_empty @ A @ ( set2 @ A @ Xs ) )
= ( null @ A @ Xs ) ) ).
% is_empty_set
thf(fact_7874_list__all__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ ( A > $o ) @ ( B > $o ) @ ( ( list @ A ) > $o ) @ ( ( list @ B ) > $o )
@ ( bNF_rel_fun @ A @ B @ $o @ $o @ A4
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ $o @ $o @ ( list_all2 @ A @ B @ A4 )
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( list_all @ A )
@ ( list_all @ B ) ) ).
% list_all_transfer
thf(fact_7875_list_Opred__inject_I2_J,axiom,
! [A: $tType,P2: A > $o,A3: A,Aa3: list @ A] :
( ( list_all @ A @ P2 @ ( cons @ A @ A3 @ Aa3 ) )
= ( ( P2 @ A3 )
& ( list_all @ A @ P2 @ Aa3 ) ) ) ).
% list.pred_inject(2)
thf(fact_7876_list__all__simps_I1_J,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A] :
( ( list_all @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( ( P2 @ X )
& ( list_all @ A @ P2 @ Xs ) ) ) ).
% list_all_simps(1)
thf(fact_7877_list__all__simps_I2_J,axiom,
! [A: $tType,P2: A > $o] : ( list_all @ A @ P2 @ ( nil @ A ) ) ).
% list_all_simps(2)
thf(fact_7878_list__all__append,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A,Ys: list @ A] :
( ( list_all @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( ( list_all @ A @ P2 @ Xs )
& ( list_all @ A @ P2 @ Ys ) ) ) ).
% list_all_append
thf(fact_7879_list__all__rev,axiom,
! [A: $tType,P2: A > $o,Xs: list @ A] :
( ( list_all @ A @ P2 @ ( rev @ A @ Xs ) )
= ( list_all @ A @ P2 @ Xs ) ) ).
% list_all_rev
thf(fact_7880_list__ex1__simps_I2_J,axiom,
! [A: $tType,P2: A > $o,X: A,Xs: list @ A] :
( ( list_ex1 @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( ( ( P2 @ X )
=> ( list_all @ A
@ ^ [Y2: A] :
( ~ ( P2 @ Y2 )
| ( X = Y2 ) )
@ Xs ) )
& ( ~ ( P2 @ X )
=> ( list_ex1 @ A @ P2 @ Xs ) ) ) ) ).
% list_ex1_simps(2)
thf(fact_7881_list_Opred__mono,axiom,
! [A: $tType,P2: A > $o,Pa: A > $o] :
( ( ord_less_eq @ ( A > $o ) @ P2 @ Pa )
=> ( ord_less_eq @ ( ( list @ A ) > $o ) @ ( list_all @ A @ P2 ) @ ( list_all @ A @ Pa ) ) ) ).
% list.pred_mono
thf(fact_7882_list__all__cong,axiom,
! [A: $tType,X: list @ A,Ya: list @ A,P2: A > $o,Pa: A > $o] :
( ( X = Ya )
=> ( ! [Z2: A] :
( ( member2 @ A @ Z2 @ ( set2 @ A @ Ya ) )
=> ( ( P2 @ Z2 )
= ( Pa @ Z2 ) ) )
=> ( ( list_all @ A @ P2 @ X )
= ( list_all @ A @ Pa @ Ya ) ) ) ) ).
% list_all_cong
thf(fact_7883_list_Opred__mono__strong,axiom,
! [A: $tType,P2: A > $o,X: list @ A,Pa: A > $o] :
( ( list_all @ A @ P2 @ X )
=> ( ! [Z2: A] :
( ( member2 @ A @ Z2 @ ( set2 @ A @ X ) )
=> ( ( P2 @ Z2 )
=> ( Pa @ Z2 ) ) )
=> ( list_all @ A @ Pa @ X ) ) ) ).
% list.pred_mono_strong
thf(fact_7884_Ball__set__list__all,axiom,
! [A: $tType,Xs: list @ A,P2: A > $o] :
( ( ! [X2: A] :
( ( member2 @ A @ X2 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X2 ) ) )
= ( list_all @ A @ P2 @ Xs ) ) ).
% Ball_set_list_all
thf(fact_7885_list__all__iff,axiom,
! [A: $tType] :
( ( list_all @ A )
= ( ^ [P: A > $o,X2: list @ A] :
! [Y2: A] :
( ( member2 @ A @ Y2 @ ( set2 @ A @ X2 ) )
=> ( P @ Y2 ) ) ) ) ).
% list_all_iff
thf(fact_7886_list_Opred__set,axiom,
! [A: $tType] :
( ( list_all @ A )
= ( ^ [P: A > $o,X2: list @ A] :
! [Y2: A] :
( ( member2 @ A @ Y2 @ ( set2 @ A @ X2 ) )
=> ( P @ Y2 ) ) ) ) ).
% list.pred_set
thf(fact_7887_list_Opred__True,axiom,
! [A: $tType] :
( ( list_all @ A
@ ^ [Uu3: A] : $true )
= ( ^ [Uu3: list @ A] : $true ) ) ).
% list.pred_True
thf(fact_7888_list_Omap__cong__pred,axiom,
! [B: $tType,A: $tType,X: list @ A,Ya: list @ A,F2: A > B,G: A > B] :
( ( X = Ya )
=> ( ( list_all @ A
@ ^ [Z6: A] :
( ( F2 @ Z6 )
= ( G @ Z6 ) )
@ Ya )
=> ( ( map @ A @ B @ F2 @ X )
= ( map @ A @ B @ G @ Ya ) ) ) ) ).
% list.map_cong_pred
thf(fact_7889_list_Opred__inject_I1_J,axiom,
! [A: $tType,P2: A > $o] : ( list_all @ A @ P2 @ ( nil @ A ) ) ).
% list.pred_inject(1)
thf(fact_7890_list_Opred__map,axiom,
! [B: $tType,A: $tType,Q: B > $o,F2: A > B,X: list @ A] :
( ( list_all @ B @ Q @ ( map @ A @ B @ F2 @ X ) )
= ( list_all @ A @ ( comp @ B @ $o @ A @ Q @ F2 ) @ X ) ) ).
% list.pred_map
thf(fact_7891_list__all__length,axiom,
! [A: $tType] :
( ( list_all @ A )
= ( ^ [P: A > $o,Xs2: list @ A] :
! [N: nat] :
( ( ord_less @ nat @ N @ ( size_size @ ( list @ A ) @ Xs2 ) )
=> ( P @ ( nth @ A @ Xs2 @ N ) ) ) ) ) ).
% list_all_length
thf(fact_7892_Set_Ois__empty__def,axiom,
! [A: $tType] :
( ( is_empty @ A )
= ( ^ [A6: set @ A] :
( A6
= ( bot_bot @ ( set @ A ) ) ) ) ) ).
% Set.is_empty_def
thf(fact_7893_list_Opred__transfer,axiom,
! [A: $tType,B: $tType,R: A > B > $o] :
( bNF_rel_fun @ ( A > $o ) @ ( B > $o ) @ ( ( list @ A ) > $o ) @ ( ( list @ B ) > $o )
@ ( bNF_rel_fun @ A @ B @ $o @ $o @ R
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ $o @ $o @ ( list_all2 @ A @ B @ R )
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( list_all @ A )
@ ( list_all @ B ) ) ).
% list.pred_transfer
thf(fact_7894_mono__transfer,axiom,
! [A: $tType,C: $tType,D: $tType,B: $tType] :
( ( ( order @ B )
& ( order @ D )
& ( order @ C )
& ( order @ A ) )
=> ! [A4: A > B > $o,B3: C > D > $o] :
( ( bi_total @ A @ B @ A4 )
=> ( ( bNF_rel_fun @ A @ B @ ( A > $o ) @ ( B > $o ) @ A4
@ ( bNF_rel_fun @ A @ B @ $o @ $o @ A4
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( ord_less_eq @ A )
@ ( ord_less_eq @ B ) )
=> ( ( bNF_rel_fun @ C @ D @ ( C > $o ) @ ( D > $o ) @ B3
@ ( bNF_rel_fun @ C @ D @ $o @ $o @ B3
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( ord_less_eq @ C )
@ ( ord_less_eq @ D ) )
=> ( bNF_rel_fun @ ( A > C ) @ ( B > D ) @ $o @ $o @ ( bNF_rel_fun @ A @ B @ C @ D @ A4 @ B3 )
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 )
@ ( order_mono @ A @ C )
@ ( order_mono @ B @ D ) ) ) ) ) ) ).
% mono_transfer
thf(fact_7895_prod__set__simps_I2_J,axiom,
! [A: $tType,B: $tType,X: A,Y: B] :
( ( basic_snds @ A @ B @ ( product_Pair @ A @ B @ X @ Y ) )
= ( insert2 @ B @ Y @ ( bot_bot @ ( set @ B ) ) ) ) ).
% prod_set_simps(2)
thf(fact_7896_list_Obi__total__rel,axiom,
! [B: $tType,A: $tType,R: A > B > $o] :
( ( bi_total @ A @ B @ R )
=> ( bi_total @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ B @ R ) ) ) ).
% list.bi_total_rel
thf(fact_7897_int_Obi__total,axiom,
bi_total @ ( product_prod @ nat @ nat ) @ int @ pcr_int ).
% int.bi_total
thf(fact_7898_prod__set__defs_I2_J,axiom,
! [D: $tType,C: $tType] :
( ( basic_snds @ C @ D )
= ( ^ [P6: product_prod @ C @ D] : ( insert2 @ D @ ( product_snd @ C @ D @ P6 ) @ ( bot_bot @ ( set @ D ) ) ) ) ) ).
% prod_set_defs(2)
thf(fact_7899_monotone__parametric,axiom,
! [A: $tType,C: $tType,D: $tType,B: $tType,A4: A > B > $o,B3: C > D > $o] :
( ( bi_total @ A @ B @ A4 )
=> ( bNF_rel_fun @ ( A > A > $o ) @ ( B > B > $o ) @ ( ( C > C > $o ) > ( A > C ) > $o ) @ ( ( D > D > $o ) > ( B > D ) > $o )
@ ( bNF_rel_fun @ A @ B @ ( A > $o ) @ ( B > $o ) @ A4
@ ( bNF_rel_fun @ A @ B @ $o @ $o @ A4
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) ) )
@ ( bNF_rel_fun @ ( C > C > $o ) @ ( D > D > $o ) @ ( ( A > C ) > $o ) @ ( ( B > D ) > $o )
@ ( bNF_rel_fun @ C @ D @ ( C > $o ) @ ( D > $o ) @ B3
@ ( bNF_rel_fun @ C @ D @ $o @ $o @ B3
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) ) )
@ ( bNF_rel_fun @ ( A > C ) @ ( B > D ) @ $o @ $o @ ( bNF_rel_fun @ A @ B @ C @ D @ A4 @ B3 )
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) ) )
@ ( comple7038119648293358887notone @ A @ C )
@ ( comple7038119648293358887notone @ B @ D ) ) ) ).
% monotone_parametric
thf(fact_7900_fun__ord__parametric,axiom,
! [C: $tType,D: $tType,A: $tType,B: $tType,F: $tType,E2: $tType,C5: A > B > $o,A4: C > E2 > $o,B3: D > F > $o] :
( ( bi_total @ A @ B @ C5 )
=> ( bNF_rel_fun @ ( C > D > $o ) @ ( E2 > F > $o ) @ ( ( A > C ) > ( A > D ) > $o ) @ ( ( B > E2 ) > ( B > F ) > $o )
@ ( bNF_rel_fun @ C @ E2 @ ( D > $o ) @ ( F > $o ) @ A4
@ ( bNF_rel_fun @ D @ F @ $o @ $o @ B3
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) ) )
@ ( bNF_rel_fun @ ( A > C ) @ ( B > E2 ) @ ( ( A > D ) > $o ) @ ( ( B > F ) > $o ) @ ( bNF_rel_fun @ A @ B @ C @ E2 @ C5 @ A4 )
@ ( bNF_rel_fun @ ( A > D ) @ ( B > F ) @ $o @ $o @ ( bNF_rel_fun @ A @ B @ D @ F @ C5 @ B3 )
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) ) )
@ ( partial_fun_ord @ C @ D @ A )
@ ( partial_fun_ord @ E2 @ F @ B ) ) ) ).
% fun_ord_parametric
thf(fact_7901_fixp__induct,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [P2: A > $o,F2: A > A] :
( ( comple1908693960933563346ssible @ A @ ( complete_Sup_Sup @ A ) @ ( ord_less_eq @ A ) @ P2 )
=> ( ( comple7038119648293358887notone @ A @ A @ ( ord_less_eq @ A ) @ ( ord_less_eq @ A ) @ F2 )
=> ( ( P2 @ ( complete_Sup_Sup @ A @ ( bot_bot @ ( set @ A ) ) ) )
=> ( ! [X5: A] :
( ( P2 @ X5 )
=> ( P2 @ ( F2 @ X5 ) ) )
=> ( P2 @ ( comple115746919287870866o_fixp @ A @ F2 ) ) ) ) ) ) ) ).
% fixp_induct
thf(fact_7902_less__than__iff,axiom,
! [X: nat,Y: nat] :
( ( member2 @ ( product_prod @ nat @ nat ) @ ( product_Pair @ nat @ nat @ X @ Y ) @ less_than )
= ( ord_less @ nat @ X @ Y ) ) ).
% less_than_iff
thf(fact_7903_fixp__unfold,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [F2: A > A] :
( ( comple7038119648293358887notone @ A @ A @ ( ord_less_eq @ A ) @ ( ord_less_eq @ A ) @ F2 )
=> ( ( comple115746919287870866o_fixp @ A @ F2 )
= ( F2 @ ( comple115746919287870866o_fixp @ A @ F2 ) ) ) ) ) ).
% fixp_unfold
thf(fact_7904_fixp__lowerbound,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [F2: A > A,Z: A] :
( ( comple7038119648293358887notone @ A @ A @ ( ord_less_eq @ A ) @ ( ord_less_eq @ A ) @ F2 )
=> ( ( ord_less_eq @ A @ ( F2 @ Z ) @ Z )
=> ( ord_less_eq @ A @ ( comple115746919287870866o_fixp @ A @ F2 ) @ Z ) ) ) ) ).
% fixp_lowerbound
thf(fact_7905_lenlex__def,axiom,
! [A: $tType] :
( ( lenlex @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
( inv_image @ ( product_prod @ nat @ ( list @ A ) ) @ ( list @ A ) @ ( lex_prod @ nat @ ( list @ A ) @ less_than @ ( lex @ A @ R4 ) )
@ ^ [Xs2: list @ A] : ( product_Pair @ nat @ ( list @ A ) @ ( size_size @ ( list @ A ) @ Xs2 ) @ Xs2 ) ) ) ) ).
% lenlex_def
thf(fact_7906_mlex__prod__def,axiom,
! [A: $tType] :
( ( mlex_prod @ A )
= ( ^ [F3: A > nat,R5: set @ ( product_prod @ A @ A )] :
( inv_image @ ( product_prod @ nat @ A ) @ A @ ( lex_prod @ nat @ A @ less_than @ R5 )
@ ^ [X2: A] : ( product_Pair @ nat @ A @ ( F3 @ X2 ) @ X2 ) ) ) ) ).
% mlex_prod_def
thf(fact_7907_in__inv__image,axiom,
! [A: $tType,B: $tType,X: A,Y: A,R2: set @ ( product_prod @ B @ B ),F2: A > B] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( inv_image @ B @ A @ R2 @ F2 ) )
= ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ ( F2 @ X ) @ ( F2 @ Y ) ) @ R2 ) ) ).
% in_inv_image
thf(fact_7908_inv__image__def,axiom,
! [A: $tType,B: $tType] :
( ( inv_image @ B @ A )
= ( ^ [R4: set @ ( product_prod @ B @ B ),F3: A > B] :
( collect @ ( product_prod @ A @ A )
@ ( product_case_prod @ A @ A @ $o
@ ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ ( F3 @ X2 ) @ ( F3 @ Y2 ) ) @ R4 ) ) ) ) ) ).
% inv_image_def
thf(fact_7909_measures__def,axiom,
! [A: $tType] :
( ( measures @ A )
= ( ^ [Fs2: list @ ( A > nat )] :
( inv_image @ ( list @ nat ) @ A @ ( lex @ nat @ less_than )
@ ^ [A5: A] :
( map @ ( A > nat ) @ nat
@ ^ [F3: A > nat] : ( F3 @ A5 )
@ Fs2 ) ) ) ) ).
% measures_def
thf(fact_7910_irrefl__tranclI,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),X: A] :
( ( ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ ( converse @ A @ A @ R2 ) @ ( transitive_rtrancl @ A @ R2 ) )
= ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) )
=> ~ ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ X ) @ ( transitive_trancl @ A @ R2 ) ) ) ).
% irrefl_tranclI
thf(fact_7911_converse__iff,axiom,
! [A: $tType,B: $tType,A3: A,B2: B,R2: set @ ( product_prod @ B @ A )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ ( converse @ B @ A @ R2 ) )
= ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ B2 @ A3 ) @ R2 ) ) ).
% converse_iff
thf(fact_7912_converse__empty,axiom,
! [B: $tType,A: $tType] :
( ( converse @ B @ A @ ( bot_bot @ ( set @ ( product_prod @ B @ A ) ) ) )
= ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) ) ).
% converse_empty
thf(fact_7913_converse__def,axiom,
! [B: $tType,A: $tType] :
( ( converse @ A @ B )
= ( ^ [R4: set @ ( product_prod @ A @ B )] :
( collect @ ( product_prod @ B @ A )
@ ( product_case_prod @ B @ A @ $o
@ ( conversep @ A @ B
@ ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R4 ) ) ) ) ) ) ).
% converse_def
thf(fact_7914_trancl__converseD,axiom,
! [A: $tType,X: A,Y: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_trancl @ A @ ( converse @ A @ A @ R2 ) ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( converse @ A @ A @ ( transitive_trancl @ A @ R2 ) ) ) ) ).
% trancl_converseD
thf(fact_7915_trancl__converseI,axiom,
! [A: $tType,X: A,Y: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( converse @ A @ A @ ( transitive_trancl @ A @ R2 ) ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_trancl @ A @ ( converse @ A @ A @ R2 ) ) ) ) ).
% trancl_converseI
thf(fact_7916_converseI,axiom,
! [B: $tType,A: $tType,A3: A,B2: B,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ R2 )
=> ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ B2 @ A3 ) @ ( converse @ A @ B @ R2 ) ) ) ).
% converseI
thf(fact_7917_converseE,axiom,
! [A: $tType,B: $tType,Yx: product_prod @ A @ B,R2: set @ ( product_prod @ B @ A )] :
( ( member2 @ ( product_prod @ A @ B ) @ Yx @ ( converse @ B @ A @ R2 ) )
=> ~ ! [X5: B,Y4: A] :
( ( Yx
= ( product_Pair @ A @ B @ Y4 @ X5 ) )
=> ~ ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ X5 @ Y4 ) @ R2 ) ) ) ).
% converseE
thf(fact_7918_converseD,axiom,
! [A: $tType,B: $tType,A3: A,B2: B,R2: set @ ( product_prod @ B @ A )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A3 @ B2 ) @ ( converse @ B @ A @ R2 ) )
=> ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ B2 @ A3 ) @ R2 ) ) ).
% converseD
thf(fact_7919_converse_Osimps,axiom,
! [B: $tType,A: $tType,A12: B,A23: A,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ A12 @ A23 ) @ ( converse @ A @ B @ R2 ) )
= ( ? [A5: A,B4: B] :
( ( A12 = B4 )
& ( A23 = A5 )
& ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A5 @ B4 ) @ R2 ) ) ) ) ).
% converse.simps
thf(fact_7920_converse_Ocases,axiom,
! [B: $tType,A: $tType,A12: B,A23: A,R2: set @ ( product_prod @ A @ B )] :
( ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ A12 @ A23 ) @ ( converse @ A @ B @ R2 ) )
=> ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ A23 @ A12 ) @ R2 ) ) ).
% converse.cases
thf(fact_7921_in__listrel1__converse,axiom,
! [A: $tType,X: list @ A,Y: list @ A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Y ) @ ( listrel1 @ A @ ( converse @ A @ A @ R2 ) ) )
= ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Y ) @ ( converse @ ( list @ A ) @ ( list @ A ) @ ( listrel1 @ A @ R2 ) ) ) ) ).
% in_listrel1_converse
thf(fact_7922_rtrancl__converseD,axiom,
! [A: $tType,X: A,Y: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_rtrancl @ A @ ( converse @ A @ A @ R2 ) ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ X ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ).
% rtrancl_converseD
thf(fact_7923_rtrancl__converseI,axiom,
! [A: $tType,Y: A,X: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ X ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_rtrancl @ A @ ( converse @ A @ A @ R2 ) ) ) ) ).
% rtrancl_converseI
thf(fact_7924_converse__unfold,axiom,
! [A: $tType,B: $tType] :
( ( converse @ B @ A )
= ( ^ [R4: set @ ( product_prod @ B @ A )] :
( collect @ ( product_prod @ A @ B )
@ ( product_case_prod @ A @ B @ $o
@ ^ [Y2: A,X2: B] : ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ X2 @ Y2 ) @ R4 ) ) ) ) ) ).
% converse_unfold
thf(fact_7925_conversep__converse__eq,axiom,
! [A: $tType,B: $tType,R2: set @ ( product_prod @ A @ B )] :
( ( conversep @ A @ B
@ ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R2 ) )
= ( ^ [X2: B,Y2: A] : ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ X2 @ Y2 ) @ ( converse @ A @ B @ R2 ) ) ) ) ).
% conversep_converse_eq
thf(fact_7926_listrel1__converse,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( listrel1 @ A @ ( converse @ A @ A @ R2 ) )
= ( converse @ ( list @ A ) @ ( list @ A ) @ ( listrel1 @ A @ R2 ) ) ) ).
% listrel1_converse
thf(fact_7927_Image__subset__eq,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ B @ A ),A4: set @ B,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ ( image @ B @ A @ R2 @ A4 ) @ B3 )
= ( ord_less_eq @ ( set @ B ) @ A4 @ ( uminus_uminus @ ( set @ B ) @ ( image @ A @ B @ ( converse @ B @ A @ R2 ) @ ( uminus_uminus @ ( set @ A ) @ B3 ) ) ) ) ) ).
% Image_subset_eq
thf(fact_7928_Image__INT__eq,axiom,
! [A: $tType,B: $tType,C: $tType,R2: set @ ( product_prod @ B @ A ),A4: set @ C,B3: C > ( set @ B )] :
( ( single_valued @ A @ B @ ( converse @ B @ A @ R2 ) )
=> ( ( A4
!= ( bot_bot @ ( set @ C ) ) )
=> ( ( image @ B @ A @ R2 @ ( complete_Inf_Inf @ ( set @ B ) @ ( image2 @ C @ ( set @ B ) @ B3 @ A4 ) ) )
= ( complete_Inf_Inf @ ( set @ A )
@ ( image2 @ C @ ( set @ A )
@ ^ [X2: C] : ( image @ B @ A @ R2 @ ( B3 @ X2 ) )
@ A4 ) ) ) ) ) ).
% Image_INT_eq
thf(fact_7929_trans__wf__iff,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( trans @ A @ R2 )
=> ( ( wf @ A @ R2 )
= ( ! [A5: A] :
( wf @ A
@ ( inf_inf @ ( set @ ( product_prod @ A @ A ) ) @ R2
@ ( product_Sigma @ A @ A @ ( image @ A @ A @ ( converse @ A @ A @ R2 ) @ ( insert2 @ A @ A5 @ ( bot_bot @ ( set @ A ) ) ) )
@ ^ [Uu3: A] : ( image @ A @ A @ ( converse @ A @ A @ R2 ) @ ( insert2 @ A @ A5 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ).
% trans_wf_iff
thf(fact_7930_lenlex__transI,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( trans @ A @ R2 )
=> ( trans @ ( list @ A ) @ ( lenlex @ A @ R2 ) ) ) ).
% lenlex_transI
thf(fact_7931_lex__transI,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( trans @ A @ R2 )
=> ( trans @ ( list @ A ) @ ( lex @ A @ R2 ) ) ) ).
% lex_transI
thf(fact_7932_single__valued__empty,axiom,
! [B: $tType,A: $tType] : ( single_valued @ A @ B @ ( bot_bot @ ( set @ ( product_prod @ A @ B ) ) ) ) ).
% single_valued_empty
thf(fact_7933_trans__empty,axiom,
! [A: $tType] : ( trans @ A @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ).
% trans_empty
thf(fact_7934_lexord__transI,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( trans @ A @ R2 )
=> ( trans @ ( list @ A ) @ ( lexord @ A @ R2 ) ) ) ).
% lexord_transI
thf(fact_7935_listrel__trans,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( trans @ A @ R2 )
=> ( trans @ ( list @ A ) @ ( listrel @ A @ A @ R2 ) ) ) ).
% listrel_trans
thf(fact_7936_lexn__transI,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),N2: nat] :
( ( trans @ A @ R2 )
=> ( trans @ ( list @ A ) @ ( lexn @ A @ R2 @ N2 ) ) ) ).
% lexn_transI
thf(fact_7937_transp__trans__eq,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( transp @ A
@ ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R2 ) )
= ( trans @ A @ R2 ) ) ).
% transp_trans_eq
thf(fact_7938_lexord__trans,axiom,
! [A: $tType,X: list @ A,Y: list @ A,R2: set @ ( product_prod @ A @ A ),Z: list @ A] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Y ) @ ( lexord @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Y @ Z ) @ ( lexord @ A @ R2 ) )
=> ( ( trans @ A @ R2 )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Z ) @ ( lexord @ A @ R2 ) ) ) ) ) ).
% lexord_trans
thf(fact_7939_transD,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),X: A,Y: A,Z: A] :
( ( trans @ A @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ Z ) @ R2 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ R2 ) ) ) ) ).
% transD
thf(fact_7940_transE,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),X: A,Y: A,Z: A] :
( ( trans @ A @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ Z ) @ R2 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ R2 ) ) ) ) ).
% transE
thf(fact_7941_transI,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ! [X5: A,Y4: A,Z2: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Y4 ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y4 @ Z2 ) @ R2 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X5 @ Z2 ) @ R2 ) ) )
=> ( trans @ A @ R2 ) ) ).
% transI
thf(fact_7942_trans__def,axiom,
! [A: $tType] :
( ( trans @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
! [X2: A,Y2: A,Z6: A] :
( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R4 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y2 @ Z6 ) @ R4 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Z6 ) @ R4 ) ) ) ) ) ).
% trans_def
thf(fact_7943_single__valued__def,axiom,
! [B: $tType,A: $tType] :
( ( single_valued @ A @ B )
= ( ^ [R4: set @ ( product_prod @ A @ B )] :
! [X2: A,Y2: B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R4 )
=> ! [Z6: B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Z6 ) @ R4 )
=> ( Y2 = Z6 ) ) ) ) ) ).
% single_valued_def
thf(fact_7944_single__valuedI,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ B )] :
( ! [X5: A,Y4: B,Z2: B] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X5 @ Y4 ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X5 @ Z2 ) @ R2 )
=> ( Y4 = Z2 ) ) )
=> ( single_valued @ A @ B @ R2 ) ) ).
% single_valuedI
thf(fact_7945_single__valuedD,axiom,
! [A: $tType,B: $tType,R2: set @ ( product_prod @ A @ B ),X: A,Y: B,Z: B] :
( ( single_valued @ A @ B @ R2 )
=> ( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Y ) @ R2 )
=> ( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X @ Z ) @ R2 )
=> ( Y = Z ) ) ) ) ).
% single_valuedD
thf(fact_7946_lenlex__trans,axiom,
! [A: $tType,X: list @ A,Y: list @ A,R2: set @ ( product_prod @ A @ A ),Z: list @ A] :
( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Y ) @ ( lenlex @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ Y @ Z ) @ ( lenlex @ A @ R2 ) )
=> ( ( trans @ A @ R2 )
=> ( member2 @ ( product_prod @ ( list @ A ) @ ( list @ A ) ) @ ( product_Pair @ ( list @ A ) @ ( list @ A ) @ X @ Z ) @ ( lenlex @ A @ R2 ) ) ) ) ) ).
% lenlex_trans
thf(fact_7947_single__valued__confluent,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),X: A,Y: A,Z: A] :
( ( single_valued @ A @ A @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ ( transitive_rtrancl @ A @ R2 ) )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ Z ) @ ( transitive_rtrancl @ A @ R2 ) )
| ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Z @ Y ) @ ( transitive_rtrancl @ A @ R2 ) ) ) ) ) ) ).
% single_valued_confluent
thf(fact_7948_under__incr,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( trans @ A @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ord_less_eq @ ( set @ A ) @ ( order_under @ A @ R2 @ A3 ) @ ( order_under @ A @ R2 @ B2 ) ) ) ) ).
% under_incr
thf(fact_7949_trans__singleton,axiom,
! [A: $tType,A3: A] : ( trans @ A @ ( insert2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ A3 ) @ ( bot_bot @ ( set @ ( product_prod @ A @ A ) ) ) ) ) ).
% trans_singleton
thf(fact_7950_trans__join,axiom,
! [A: $tType] :
( ( trans @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
! [X2: product_prod @ A @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ X2 @ R4 )
=> ( product_case_prod @ A @ A @ $o
@ ^ [Y2: A,Y16: A] :
! [Z6: product_prod @ A @ A] :
( ( member2 @ ( product_prod @ A @ A ) @ Z6 @ R4 )
=> ( product_case_prod @ A @ A @ $o
@ ^ [Y24: A,Aa4: A] :
( ( Y16 = Y24 )
=> ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y2 @ Aa4 ) @ R4 ) )
@ Z6 ) )
@ X2 ) ) ) ) ).
% trans_join
thf(fact_7951_underS__incr,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A,B2: A] :
( ( trans @ A @ R2 )
=> ( ( antisym @ A @ R2 )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ B2 ) @ R2 )
=> ( ord_less_eq @ ( set @ A ) @ ( order_underS @ A @ R2 @ A3 ) @ ( order_underS @ A @ R2 @ B2 ) ) ) ) ) ).
% underS_incr
thf(fact_7952_wf__finite__segments,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( irrefl @ A @ R2 )
=> ( ( trans @ A @ R2 )
=> ( ! [X5: A] :
( finite_finite @ A
@ ( collect @ A
@ ^ [Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y2 @ X5 ) @ R2 ) ) )
=> ( wf @ A @ R2 ) ) ) ) ).
% wf_finite_segments
thf(fact_7953_single__valuedp__single__valued__eq,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ B )] :
( ( single_valuedp @ A @ B
@ ^ [X2: A,Y2: B] : ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ X2 @ Y2 ) @ R2 ) )
= ( single_valued @ A @ B @ R2 ) ) ).
% single_valuedp_single_valued_eq
thf(fact_7954_elimnum,axiom,
! [Info: option @ ( product_prod @ nat @ nat ),Deg: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,N2: nat] :
( ( vEBT_invar_vebt @ ( vEBT_Node @ Info @ Deg @ TreeList2 @ Summary ) @ N2 )
=> ( ( vEBT_VEBT_elim_dead @ ( vEBT_Node @ Info @ Deg @ TreeList2 @ Summary ) @ ( extended_enat2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ N2 ) ) )
= ( vEBT_Node @ Info @ Deg @ TreeList2 @ Summary ) ) ) ).
% elimnum
thf(fact_7955_idiff__enat__0__right,axiom,
! [N2: extended_enat] :
( ( minus_minus @ extended_enat @ N2 @ ( extended_enat2 @ ( zero_zero @ nat ) ) )
= N2 ) ).
% idiff_enat_0_right
thf(fact_7956_idiff__enat__0,axiom,
! [N2: extended_enat] :
( ( minus_minus @ extended_enat @ ( extended_enat2 @ ( zero_zero @ nat ) ) @ N2 )
= ( extended_enat2 @ ( zero_zero @ nat ) ) ) ).
% idiff_enat_0
thf(fact_7957_plus__enat__simps_I1_J,axiom,
! [M: nat,N2: nat] :
( ( plus_plus @ extended_enat @ ( extended_enat2 @ M ) @ ( extended_enat2 @ N2 ) )
= ( extended_enat2 @ ( plus_plus @ nat @ M @ N2 ) ) ) ).
% plus_enat_simps(1)
thf(fact_7958_max__enat__simps_I1_J,axiom,
! [M: nat,N2: nat] :
( ( ord_max @ extended_enat @ ( extended_enat2 @ M ) @ ( extended_enat2 @ N2 ) )
= ( extended_enat2 @ ( ord_max @ nat @ M @ N2 ) ) ) ).
% max_enat_simps(1)
thf(fact_7959_enat__ord__simps_I2_J,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ extended_enat @ ( extended_enat2 @ M ) @ ( extended_enat2 @ N2 ) )
= ( ord_less @ nat @ M @ N2 ) ) ).
% enat_ord_simps(2)
thf(fact_7960_enat__ord__simps_I1_J,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ extended_enat @ ( extended_enat2 @ M ) @ ( extended_enat2 @ N2 ) )
= ( ord_less_eq @ nat @ M @ N2 ) ) ).
% enat_ord_simps(1)
thf(fact_7961_numeral__less__enat__iff,axiom,
! [M: num,N2: nat] :
( ( ord_less @ extended_enat @ ( numeral_numeral @ extended_enat @ M ) @ ( extended_enat2 @ N2 ) )
= ( ord_less @ nat @ ( numeral_numeral @ nat @ M ) @ N2 ) ) ).
% numeral_less_enat_iff
thf(fact_7962_numeral__le__enat__iff,axiom,
! [M: num,N2: nat] :
( ( ord_less_eq @ extended_enat @ ( numeral_numeral @ extended_enat @ M ) @ ( extended_enat2 @ N2 ) )
= ( ord_less_eq @ nat @ ( numeral_numeral @ nat @ M ) @ N2 ) ) ).
% numeral_le_enat_iff
thf(fact_7963_zero__enat__def,axiom,
( ( zero_zero @ extended_enat )
= ( extended_enat2 @ ( zero_zero @ nat ) ) ) ).
% zero_enat_def
thf(fact_7964_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_7965_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_7966_less__enatE,axiom,
! [N2: extended_enat,M: nat] :
( ( ord_less @ extended_enat @ N2 @ ( extended_enat2 @ M ) )
=> ~ ! [K3: nat] :
( ( N2
= ( extended_enat2 @ K3 ) )
=> ~ ( ord_less @ nat @ K3 @ M ) ) ) ).
% less_enatE
thf(fact_7967_single__valuedp__bot,axiom,
! [B: $tType,A: $tType] : ( single_valuedp @ A @ B @ ( bot_bot @ ( A > B > $o ) ) ) ).
% single_valuedp_bot
thf(fact_7968_Suc__ile__eq,axiom,
! [M: nat,N2: extended_enat] :
( ( ord_less_eq @ extended_enat @ ( extended_enat2 @ ( suc @ M ) ) @ N2 )
= ( ord_less @ extended_enat @ ( extended_enat2 @ M ) @ N2 ) ) ).
% Suc_ile_eq
thf(fact_7969_iadd__le__enat__iff,axiom,
! [X: extended_enat,Y: extended_enat,N2: nat] :
( ( ord_less_eq @ extended_enat @ ( plus_plus @ extended_enat @ X @ Y ) @ ( extended_enat2 @ N2 ) )
= ( ? [Y7: nat,X10: nat] :
( ( X
= ( extended_enat2 @ X10 ) )
& ( Y
= ( extended_enat2 @ Y7 ) )
& ( ord_less_eq @ nat @ ( plus_plus @ nat @ X10 @ Y7 ) @ N2 ) ) ) ) ).
% iadd_le_enat_iff
thf(fact_7970_VEBT__internal_Oelim__dead_Osimps_I3_J,axiom,
! [Info: option @ ( product_prod @ nat @ nat ),Deg: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,L: nat] :
( ( vEBT_VEBT_elim_dead @ ( vEBT_Node @ Info @ Deg @ TreeList2 @ Summary ) @ ( extended_enat2 @ L ) )
= ( vEBT_Node @ Info @ Deg
@ ( take @ vEBT_VEBT @ ( divide_divide @ nat @ L @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
@ ( map @ vEBT_VEBT @ vEBT_VEBT
@ ^ [T3: vEBT_VEBT] : ( vEBT_VEBT_elim_dead @ T3 @ ( extended_enat2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
@ TreeList2 ) )
@ ( vEBT_VEBT_elim_dead @ Summary @ ( extended_enat2 @ ( divide_divide @ nat @ L @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ).
% VEBT_internal.elim_dead.simps(3)
thf(fact_7971_VEBT__internal_Oelim__dead_Oelims,axiom,
! [X: vEBT_VEBT,Xa2: extended_enat,Y: vEBT_VEBT] :
( ( ( vEBT_VEBT_elim_dead @ X @ Xa2 )
= Y )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( Y
!= ( vEBT_Leaf @ A7 @ B5 ) ) )
=> ( ! [Info2: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Info2 @ Deg2 @ TreeList3 @ Summary2 ) )
=> ( ( Xa2
= ( extend4730790105801354508finity @ extended_enat ) )
=> ( Y
!= ( vEBT_Node @ Info2 @ Deg2
@ ( map @ vEBT_VEBT @ vEBT_VEBT
@ ^ [T3: vEBT_VEBT] : ( vEBT_VEBT_elim_dead @ T3 @ ( extended_enat2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
@ TreeList3 )
@ ( vEBT_VEBT_elim_dead @ Summary2 @ ( extend4730790105801354508finity @ extended_enat ) ) ) ) ) )
=> ~ ! [Info2: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Info2 @ Deg2 @ TreeList3 @ Summary2 ) )
=> ! [L4: nat] :
( ( Xa2
= ( extended_enat2 @ L4 ) )
=> ( Y
!= ( vEBT_Node @ Info2 @ Deg2
@ ( take @ vEBT_VEBT @ ( divide_divide @ nat @ L4 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
@ ( map @ vEBT_VEBT @ vEBT_VEBT
@ ^ [T3: vEBT_VEBT] : ( vEBT_VEBT_elim_dead @ T3 @ ( extended_enat2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
@ TreeList3 ) )
@ ( vEBT_VEBT_elim_dead @ Summary2 @ ( extended_enat2 @ ( divide_divide @ nat @ L4 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) ) ) ) ) ) ) ).
% VEBT_internal.elim_dead.elims
thf(fact_7972_elimcomplete,axiom,
! [Info: option @ ( product_prod @ nat @ nat ),Deg: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT,N2: nat] :
( ( vEBT_invar_vebt @ ( vEBT_Node @ Info @ Deg @ TreeList2 @ Summary ) @ N2 )
=> ( ( vEBT_VEBT_elim_dead @ ( vEBT_Node @ Info @ Deg @ TreeList2 @ Summary ) @ ( extend4730790105801354508finity @ extended_enat ) )
= ( vEBT_Node @ Info @ Deg @ TreeList2 @ Summary ) ) ) ).
% elimcomplete
thf(fact_7973_times__enat__simps_I4_J,axiom,
! [M: nat] :
( ( ( M
= ( zero_zero @ nat ) )
=> ( ( times_times @ extended_enat @ ( extended_enat2 @ M ) @ ( extend4730790105801354508finity @ extended_enat ) )
= ( zero_zero @ extended_enat ) ) )
& ( ( M
!= ( zero_zero @ nat ) )
=> ( ( times_times @ extended_enat @ ( extended_enat2 @ M ) @ ( extend4730790105801354508finity @ extended_enat ) )
= ( extend4730790105801354508finity @ extended_enat ) ) ) ) ).
% times_enat_simps(4)
thf(fact_7974_times__enat__simps_I3_J,axiom,
! [N2: nat] :
( ( ( N2
= ( zero_zero @ nat ) )
=> ( ( times_times @ extended_enat @ ( extend4730790105801354508finity @ extended_enat ) @ ( extended_enat2 @ N2 ) )
= ( zero_zero @ extended_enat ) ) )
& ( ( N2
!= ( zero_zero @ nat ) )
=> ( ( times_times @ extended_enat @ ( extend4730790105801354508finity @ extended_enat ) @ ( extended_enat2 @ N2 ) )
= ( extend4730790105801354508finity @ extended_enat ) ) ) ) ).
% times_enat_simps(3)
thf(fact_7975_VEBT__internal_Oelim__dead_Ocases,axiom,
! [X: product_prod @ vEBT_VEBT @ extended_enat] :
( ! [A7: $o,B5: $o,Uu2: extended_enat] :
( X
!= ( product_Pair @ vEBT_VEBT @ extended_enat @ ( vEBT_Leaf @ A7 @ B5 ) @ Uu2 ) )
=> ( ! [Info2: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( X
!= ( product_Pair @ vEBT_VEBT @ extended_enat @ ( vEBT_Node @ Info2 @ Deg2 @ TreeList3 @ Summary2 ) @ ( extend4730790105801354508finity @ extended_enat ) ) )
=> ~ ! [Info2: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT,L4: nat] :
( X
!= ( product_Pair @ vEBT_VEBT @ extended_enat @ ( vEBT_Node @ Info2 @ Deg2 @ TreeList3 @ Summary2 ) @ ( extended_enat2 @ L4 ) ) ) ) ) ).
% VEBT_internal.elim_dead.cases
thf(fact_7976_Sup__enat__def,axiom,
( ( complete_Sup_Sup @ extended_enat )
= ( ^ [A6: set @ extended_enat] :
( if @ extended_enat
@ ( A6
= ( bot_bot @ ( set @ extended_enat ) ) )
@ ( zero_zero @ extended_enat )
@ ( if @ extended_enat @ ( finite_finite @ extended_enat @ A6 ) @ ( lattic643756798349783984er_Max @ extended_enat @ A6 ) @ ( extend4730790105801354508finity @ extended_enat ) ) ) ) ) ).
% Sup_enat_def
thf(fact_7977_bot__enat__def,axiom,
( ( bot_bot @ extended_enat )
= ( zero_zero @ extended_enat ) ) ).
% bot_enat_def
thf(fact_7978_Inf__enat__def,axiom,
( ( complete_Inf_Inf @ extended_enat )
= ( ^ [A6: set @ extended_enat] :
( if @ extended_enat
@ ( A6
= ( bot_bot @ ( set @ extended_enat ) ) )
@ ( extend4730790105801354508finity @ extended_enat )
@ ( ord_Least @ extended_enat
@ ^ [X2: extended_enat] : ( member2 @ extended_enat @ X2 @ A6 ) ) ) ) ) ).
% Inf_enat_def
thf(fact_7979_VEBT__internal_Oelim__dead_Osimps_I2_J,axiom,
! [Info: option @ ( product_prod @ nat @ nat ),Deg: nat,TreeList2: list @ vEBT_VEBT,Summary: vEBT_VEBT] :
( ( vEBT_VEBT_elim_dead @ ( vEBT_Node @ Info @ Deg @ TreeList2 @ Summary ) @ ( extend4730790105801354508finity @ extended_enat ) )
= ( vEBT_Node @ Info @ Deg
@ ( map @ vEBT_VEBT @ vEBT_VEBT
@ ^ [T3: vEBT_VEBT] : ( vEBT_VEBT_elim_dead @ T3 @ ( extended_enat2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
@ TreeList2 )
@ ( vEBT_VEBT_elim_dead @ Summary @ ( extend4730790105801354508finity @ extended_enat ) ) ) ) ).
% VEBT_internal.elim_dead.simps(2)
thf(fact_7980_VEBT__internal_Oelim__dead_Opelims,axiom,
! [X: vEBT_VEBT,Xa2: extended_enat,Y: vEBT_VEBT] :
( ( ( vEBT_VEBT_elim_dead @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ vEBT_VEBT @ extended_enat ) @ vEBT_V312737461966249ad_rel @ ( product_Pair @ vEBT_VEBT @ extended_enat @ X @ Xa2 ) )
=> ( ! [A7: $o,B5: $o] :
( ( X
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ( ( Y
= ( vEBT_Leaf @ A7 @ B5 ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ extended_enat ) @ vEBT_V312737461966249ad_rel @ ( product_Pair @ vEBT_VEBT @ extended_enat @ ( vEBT_Leaf @ A7 @ B5 ) @ Xa2 ) ) ) )
=> ( ! [Info2: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Info2 @ Deg2 @ TreeList3 @ Summary2 ) )
=> ( ( Xa2
= ( extend4730790105801354508finity @ extended_enat ) )
=> ( ( Y
= ( vEBT_Node @ Info2 @ Deg2
@ ( map @ vEBT_VEBT @ vEBT_VEBT
@ ^ [T3: vEBT_VEBT] : ( vEBT_VEBT_elim_dead @ T3 @ ( extended_enat2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
@ TreeList3 )
@ ( vEBT_VEBT_elim_dead @ Summary2 @ ( extend4730790105801354508finity @ extended_enat ) ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ extended_enat ) @ vEBT_V312737461966249ad_rel @ ( product_Pair @ vEBT_VEBT @ extended_enat @ ( vEBT_Node @ Info2 @ Deg2 @ TreeList3 @ Summary2 ) @ ( extend4730790105801354508finity @ extended_enat ) ) ) ) ) )
=> ~ ! [Info2: option @ ( product_prod @ nat @ nat ),Deg2: nat,TreeList3: list @ vEBT_VEBT,Summary2: vEBT_VEBT] :
( ( X
= ( vEBT_Node @ Info2 @ Deg2 @ TreeList3 @ Summary2 ) )
=> ! [L4: nat] :
( ( Xa2
= ( extended_enat2 @ L4 ) )
=> ( ( Y
= ( vEBT_Node @ Info2 @ Deg2
@ ( take @ vEBT_VEBT @ ( divide_divide @ nat @ L4 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) )
@ ( map @ vEBT_VEBT @ vEBT_VEBT
@ ^ [T3: vEBT_VEBT] : ( vEBT_VEBT_elim_dead @ T3 @ ( extended_enat2 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) )
@ TreeList3 ) )
@ ( vEBT_VEBT_elim_dead @ Summary2 @ ( extended_enat2 @ ( divide_divide @ nat @ L4 @ ( power_power @ nat @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) @ ( divide_divide @ nat @ Deg2 @ ( numeral_numeral @ nat @ ( bit0 @ one2 ) ) ) ) ) ) ) ) )
=> ~ ( accp @ ( product_prod @ vEBT_VEBT @ extended_enat ) @ vEBT_V312737461966249ad_rel @ ( product_Pair @ vEBT_VEBT @ extended_enat @ ( vEBT_Node @ Info2 @ Deg2 @ TreeList3 @ Summary2 ) @ ( extended_enat2 @ L4 ) ) ) ) ) ) ) ) ) ) ).
% VEBT_internal.elim_dead.pelims
thf(fact_7981_times__enat__def,axiom,
( ( times_times @ extended_enat )
= ( ^ [M2: extended_enat,N: extended_enat] :
( extended_case_enat @ extended_enat
@ ^ [O: nat] :
( extended_case_enat @ extended_enat
@ ^ [P6: nat] : ( extended_enat2 @ ( times_times @ nat @ O @ P6 ) )
@ ( if @ extended_enat
@ ( O
= ( zero_zero @ nat ) )
@ ( zero_zero @ extended_enat )
@ ( extend4730790105801354508finity @ extended_enat ) )
@ N )
@ ( if @ extended_enat
@ ( N
= ( zero_zero @ extended_enat ) )
@ ( zero_zero @ extended_enat )
@ ( extend4730790105801354508finity @ extended_enat ) )
@ M2 ) ) ) ).
% times_enat_def
thf(fact_7982_plus__enat__def,axiom,
( ( plus_plus @ extended_enat )
= ( ^ [M2: extended_enat,N: extended_enat] :
( extended_case_enat @ extended_enat
@ ^ [O: nat] :
( extended_case_enat @ extended_enat
@ ^ [P6: nat] : ( extended_enat2 @ ( plus_plus @ nat @ O @ P6 ) )
@ ( extend4730790105801354508finity @ extended_enat )
@ N )
@ ( extend4730790105801354508finity @ extended_enat )
@ M2 ) ) ) ).
% plus_enat_def
thf(fact_7983_eSuc__Max,axiom,
! [A4: set @ extended_enat] :
( ( finite_finite @ extended_enat @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ extended_enat ) ) )
=> ( ( extended_eSuc @ ( lattic643756798349783984er_Max @ extended_enat @ A4 ) )
= ( lattic643756798349783984er_Max @ extended_enat @ ( image2 @ extended_enat @ extended_enat @ extended_eSuc @ A4 ) ) ) ) ) ).
% eSuc_Max
thf(fact_7984_eSuc__def,axiom,
( extended_eSuc
= ( extended_case_enat @ extended_enat
@ ^ [N: nat] : ( extended_enat2 @ ( suc @ N ) )
@ ( extend4730790105801354508finity @ extended_enat ) ) ) ).
% eSuc_def
thf(fact_7985_eSuc__enat,axiom,
! [N2: nat] :
( ( extended_eSuc @ ( extended_enat2 @ N2 ) )
= ( extended_enat2 @ ( suc @ N2 ) ) ) ).
% eSuc_enat
thf(fact_7986_eSuc__enat__iff,axiom,
! [X: extended_enat,Y: nat] :
( ( ( extended_eSuc @ X )
= ( extended_enat2 @ Y ) )
= ( ? [N: nat] :
( ( Y
= ( suc @ N ) )
& ( X
= ( extended_enat2 @ N ) ) ) ) ) ).
% eSuc_enat_iff
thf(fact_7987_enat__eSuc__iff,axiom,
! [Y: nat,X: extended_enat] :
( ( ( extended_enat2 @ Y )
= ( extended_eSuc @ X ) )
= ( ? [N: nat] :
( ( Y
= ( suc @ N ) )
& ( ( extended_enat2 @ N )
= X ) ) ) ) ).
% enat_eSuc_iff
thf(fact_7988_eSuc__Sup,axiom,
! [A4: set @ extended_enat] :
( ( A4
!= ( bot_bot @ ( set @ extended_enat ) ) )
=> ( ( extended_eSuc @ ( complete_Sup_Sup @ extended_enat @ A4 ) )
= ( complete_Sup_Sup @ extended_enat @ ( image2 @ extended_enat @ extended_enat @ extended_eSuc @ A4 ) ) ) ) ).
% eSuc_Sup
thf(fact_7989_has__vector__derivative__scaleR,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: real > real,F8: real,X: real,S: set @ real,G: real > A,G6: A] :
( ( has_field_derivative @ real @ F2 @ F8 @ ( topolo174197925503356063within @ real @ X @ S ) )
=> ( ( has_ve8173657378732805170vative @ A @ G @ G6 @ ( topolo174197925503356063within @ real @ X @ S ) )
=> ( has_ve8173657378732805170vative @ A
@ ^ [X2: real] : ( real_V8093663219630862766scaleR @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( plus_plus @ A @ ( real_V8093663219630862766scaleR @ A @ ( F2 @ X ) @ G6 ) @ ( real_V8093663219630862766scaleR @ A @ F8 @ ( G @ X ) ) )
@ ( topolo174197925503356063within @ real @ X @ S ) ) ) ) ) ).
% has_vector_derivative_scaleR
thf(fact_7990_successively__transfer,axiom,
! [A: $tType,B: $tType,A4: A > B > $o] :
( bNF_rel_fun @ ( A > A > $o ) @ ( B > B > $o ) @ ( ( list @ A ) > $o ) @ ( ( list @ B ) > $o )
@ ( bNF_rel_fun @ A @ B @ ( A > $o ) @ ( B > $o ) @ A4
@ ( bNF_rel_fun @ A @ B @ $o @ $o @ A4
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) ) )
@ ( bNF_rel_fun @ ( list @ A ) @ ( list @ B ) @ $o @ $o @ ( list_all2 @ A @ B @ A4 )
@ ^ [Y5: $o,Z3: $o] : ( Y5 = Z3 ) )
@ ( successively @ A )
@ ( successively @ B ) ) ).
% successively_transfer
thf(fact_7991_successively__rev,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A] :
( ( successively @ A @ P2 @ ( rev @ A @ Xs ) )
= ( successively @ A
@ ^ [X2: A,Y2: A] : ( P2 @ Y2 @ X2 )
@ Xs ) ) ).
% successively_rev
thf(fact_7992_successively__map,axiom,
! [A: $tType,B: $tType,P2: A > A > $o,F2: B > A,Xs: list @ B] :
( ( successively @ A @ P2 @ ( map @ B @ A @ F2 @ Xs ) )
= ( successively @ B
@ ^ [X2: B,Y2: B] : ( P2 @ ( F2 @ X2 ) @ ( F2 @ Y2 ) )
@ Xs ) ) ).
% successively_map
thf(fact_7993_has__vector__derivative__add,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [F2: real > A,F8: A,Net: filter @ real,G: real > A,G6: A] :
( ( has_ve8173657378732805170vative @ A @ F2 @ F8 @ Net )
=> ( ( has_ve8173657378732805170vative @ A @ G @ G6 @ Net )
=> ( has_ve8173657378732805170vative @ A
@ ^ [X2: real] : ( plus_plus @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( plus_plus @ A @ F8 @ G6 )
@ Net ) ) ) ) ).
% has_vector_derivative_add
thf(fact_7994_has__vector__derivative__add__const,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [G: real > A,Z: A,F8: A,Net: filter @ real] :
( ( has_ve8173657378732805170vative @ A
@ ^ [T3: real] : ( plus_plus @ A @ ( G @ T3 ) @ Z )
@ F8
@ Net )
= ( has_ve8173657378732805170vative @ A @ G @ F8 @ Net ) ) ) ).
% has_vector_derivative_add_const
thf(fact_7995_has__vector__derivative__const,axiom,
! [A: $tType] :
( ( real_V822414075346904944vector @ A )
=> ! [C2: A,Net: filter @ real] :
( has_ve8173657378732805170vative @ A
@ ^ [X2: real] : C2
@ ( zero_zero @ A )
@ Net ) ) ).
% has_vector_derivative_const
thf(fact_7996_distinct__adj__def,axiom,
! [A: $tType] :
( ( distinct_adj @ A )
= ( successively @ A
@ ^ [X2: A,Y2: A] : ( X2 != Y2 ) ) ) ).
% distinct_adj_def
thf(fact_7997_successively_Oelims_I2_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A] :
( ( successively @ A @ X @ Xa2 )
=> ( ( Xa2
!= ( nil @ A ) )
=> ( ! [X5: A] :
( Xa2
!= ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ~ ! [X5: A,Y4: A,Xs3: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) )
=> ~ ( ( X @ X5 @ Y4 )
& ( successively @ A @ X @ ( cons @ A @ Y4 @ Xs3 ) ) ) ) ) ) ) ).
% successively.elims(2)
thf(fact_7998_successively_Oelims_I1_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A,Y: $o] :
( ( ( successively @ A @ X @ Xa2 )
= Y )
=> ( ( ( Xa2
= ( nil @ A ) )
=> ~ Y )
=> ( ( ? [X5: A] :
( Xa2
= ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ~ Y )
=> ~ ! [X5: A,Y4: A,Xs3: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) )
=> ( Y
= ( ~ ( ( X @ X5 @ Y4 )
& ( successively @ A @ X @ ( cons @ A @ Y4 @ Xs3 ) ) ) ) ) ) ) ) ) ).
% successively.elims(1)
thf(fact_7999_successively_Osimps_I2_J,axiom,
! [A: $tType,P2: A > A > $o,X: A] : ( successively @ A @ P2 @ ( cons @ A @ X @ ( nil @ A ) ) ) ).
% successively.simps(2)
thf(fact_8000_successively_Osimps_I1_J,axiom,
! [A: $tType,P2: A > A > $o] : ( successively @ A @ P2 @ ( nil @ A ) ) ).
% successively.simps(1)
thf(fact_8001_successively__altdef,axiom,
! [A: $tType] :
( ( successively @ A )
= ( ^ [P: A > A > $o] :
( rec_list @ $o @ A @ $true
@ ^ [X2: A,Xs2: list @ A,B4: $o] :
( case_list @ $o @ A @ $true
@ ^ [Y2: A,Xa3: list @ A] :
( ( P @ X2 @ Y2 )
& B4 )
@ Xs2 ) ) ) ) ).
% successively_altdef
thf(fact_8002_successively__remdups__adjI,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A] :
( ( successively @ A @ P2 @ Xs )
=> ( successively @ A @ P2 @ ( remdups_adj @ A @ Xs ) ) ) ).
% successively_remdups_adjI
thf(fact_8003_successively__cong,axiom,
! [A: $tType,Xs: list @ A,P2: A > A > $o,Q: A > A > $o,Ys: list @ A] :
( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( member2 @ A @ Y4 @ ( set2 @ A @ Xs ) )
=> ( ( P2 @ X5 @ Y4 )
= ( Q @ X5 @ Y4 ) ) ) )
=> ( ( Xs = Ys )
=> ( ( successively @ A @ P2 @ Xs )
= ( successively @ A @ Q @ Ys ) ) ) ) ).
% successively_cong
thf(fact_8004_successively__mono,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A,Q: A > A > $o] :
( ( successively @ A @ P2 @ Xs )
=> ( ! [X5: A,Y4: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( member2 @ A @ Y4 @ ( set2 @ A @ Xs ) )
=> ( ( P2 @ X5 @ Y4 )
=> ( Q @ X5 @ Y4 ) ) ) )
=> ( successively @ A @ Q @ Xs ) ) ) ).
% successively_mono
thf(fact_8005_successively__remdups__adj__iff,axiom,
! [A: $tType,Xs: list @ A,P2: A > A > $o] :
( ! [X5: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( P2 @ X5 @ X5 ) )
=> ( ( successively @ A @ P2 @ ( remdups_adj @ A @ Xs ) )
= ( successively @ A @ P2 @ Xs ) ) ) ).
% successively_remdups_adj_iff
thf(fact_8006_successively__iff__sorted__wrt__strong,axiom,
! [A: $tType,Xs: list @ A,P2: A > A > $o] :
( ! [X5: A,Y4: A,Z2: A] :
( ( member2 @ A @ X5 @ ( set2 @ A @ Xs ) )
=> ( ( member2 @ A @ Y4 @ ( set2 @ A @ Xs ) )
=> ( ( member2 @ A @ Z2 @ ( set2 @ A @ Xs ) )
=> ( ( P2 @ X5 @ Y4 )
=> ( ( P2 @ Y4 @ Z2 )
=> ( P2 @ X5 @ Z2 ) ) ) ) ) )
=> ( ( successively @ A @ P2 @ Xs )
= ( sorted_wrt @ A @ P2 @ Xs ) ) ) ).
% successively_iff_sorted_wrt_strong
thf(fact_8007_successively__if__sorted__wrt,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A] :
( ( sorted_wrt @ A @ P2 @ Xs )
=> ( successively @ A @ P2 @ Xs ) ) ).
% successively_if_sorted_wrt
thf(fact_8008_successively_Oelims_I3_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A] :
( ~ ( successively @ A @ X @ Xa2 )
=> ~ ! [X5: A,Y4: A,Xs3: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) )
=> ( ( X @ X5 @ Y4 )
& ( successively @ A @ X @ ( cons @ A @ Y4 @ Xs3 ) ) ) ) ) ).
% successively.elims(3)
thf(fact_8009_successively_Osimps_I3_J,axiom,
! [A: $tType,P2: A > A > $o,X: A,Y: A,Xs: list @ A] :
( ( successively @ A @ P2 @ ( cons @ A @ X @ ( cons @ A @ Y @ Xs ) ) )
= ( ( P2 @ X @ Y )
& ( successively @ A @ P2 @ ( cons @ A @ Y @ Xs ) ) ) ) ).
% successively.simps(3)
thf(fact_8010_successively__conv__sorted__wrt,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A] :
( ( transp @ A @ P2 )
=> ( ( successively @ A @ P2 @ Xs )
= ( sorted_wrt @ A @ P2 @ Xs ) ) ) ).
% successively_conv_sorted_wrt
thf(fact_8011_successively__Cons,axiom,
! [A: $tType,P2: A > A > $o,X: A,Xs: list @ A] :
( ( successively @ A @ P2 @ ( cons @ A @ X @ Xs ) )
= ( ( Xs
= ( nil @ A ) )
| ( ( P2 @ X @ ( hd @ A @ Xs ) )
& ( successively @ A @ P2 @ Xs ) ) ) ) ).
% successively_Cons
thf(fact_8012_has__vector__derivative__mult,axiom,
! [A: $tType] :
( ( real_V4412858255891104859lgebra @ A )
=> ! [F2: real > A,F8: A,X: real,S: set @ real,G: real > A,G6: A] :
( ( has_ve8173657378732805170vative @ A @ F2 @ F8 @ ( topolo174197925503356063within @ real @ X @ S ) )
=> ( ( has_ve8173657378732805170vative @ A @ G @ G6 @ ( topolo174197925503356063within @ real @ X @ S ) )
=> ( has_ve8173657378732805170vative @ A
@ ^ [X2: real] : ( times_times @ A @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( plus_plus @ A @ ( times_times @ A @ ( F2 @ X ) @ G6 ) @ ( times_times @ A @ F8 @ ( G @ X ) ) )
@ ( topolo174197925503356063within @ real @ X @ S ) ) ) ) ) ).
% has_vector_derivative_mult
thf(fact_8013_bounded__bilinear_Ohas__vector__derivative,axiom,
! [B: $tType,C: $tType,A: $tType] :
( ( ( real_V822414075346904944vector @ A )
& ( real_V822414075346904944vector @ C )
& ( real_V822414075346904944vector @ B ) )
=> ! [Prod: A > B > C,F2: real > A,F8: A,X: real,S: set @ real,G: real > B,G6: B] :
( ( real_V2442710119149674383linear @ A @ B @ C @ Prod )
=> ( ( has_ve8173657378732805170vative @ A @ F2 @ F8 @ ( topolo174197925503356063within @ real @ X @ S ) )
=> ( ( has_ve8173657378732805170vative @ B @ G @ G6 @ ( topolo174197925503356063within @ real @ X @ S ) )
=> ( has_ve8173657378732805170vative @ C
@ ^ [X2: real] : ( Prod @ ( F2 @ X2 ) @ ( G @ X2 ) )
@ ( plus_plus @ C @ ( Prod @ ( F2 @ X ) @ G6 ) @ ( Prod @ F8 @ ( G @ X ) ) )
@ ( topolo174197925503356063within @ real @ X @ S ) ) ) ) ) ) ).
% bounded_bilinear.has_vector_derivative
thf(fact_8014_successively__append__iff,axiom,
! [A: $tType,P2: A > A > $o,Xs: list @ A,Ys: list @ A] :
( ( successively @ A @ P2 @ ( append @ A @ Xs @ Ys ) )
= ( ( successively @ A @ P2 @ Xs )
& ( successively @ A @ P2 @ Ys )
& ( ( Xs
= ( nil @ A ) )
| ( Ys
= ( nil @ A ) )
| ( P2 @ ( last @ A @ Xs ) @ ( hd @ A @ Ys ) ) ) ) ) ).
% successively_append_iff
thf(fact_8015_successively_Opelims_I1_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A,Y: $o] :
( ( ( successively @ A @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( successively_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ Xa2 ) )
=> ( ( ( Xa2
= ( nil @ A ) )
=> ( Y
=> ~ ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( successively_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( nil @ A ) ) ) ) )
=> ( ! [X5: A] :
( ( Xa2
= ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ( Y
=> ~ ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( successively_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( cons @ A @ X5 @ ( nil @ A ) ) ) ) ) )
=> ~ ! [X5: A,Y4: A,Xs3: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) )
=> ( ( Y
= ( ( X @ X5 @ Y4 )
& ( successively @ A @ X @ ( cons @ A @ Y4 @ Xs3 ) ) ) )
=> ~ ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( successively_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) ) ) ) ) ) ) ) ) ).
% successively.pelims(1)
thf(fact_8016_successively_Opelims_I2_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A] :
( ( successively @ A @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( successively_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ Xa2 ) )
=> ( ( ( Xa2
= ( nil @ A ) )
=> ~ ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( successively_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( nil @ A ) ) ) )
=> ( ! [X5: A] :
( ( Xa2
= ( cons @ A @ X5 @ ( nil @ A ) ) )
=> ~ ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( successively_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( cons @ A @ X5 @ ( nil @ A ) ) ) ) )
=> ~ ! [X5: A,Y4: A,Xs3: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) )
=> ( ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( successively_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) ) )
=> ~ ( ( X @ X5 @ Y4 )
& ( successively @ A @ X @ ( cons @ A @ Y4 @ Xs3 ) ) ) ) ) ) ) ) ) ).
% successively.pelims(2)
thf(fact_8017_successively_Opelims_I3_J,axiom,
! [A: $tType,X: A > A > $o,Xa2: list @ A] :
( ~ ( successively @ A @ X @ Xa2 )
=> ( ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( successively_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ Xa2 ) )
=> ~ ! [X5: A,Y4: A,Xs3: list @ A] :
( ( Xa2
= ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) )
=> ( ( accp @ ( product_prod @ ( A > A > $o ) @ ( list @ A ) ) @ ( successively_rel @ A ) @ ( product_Pair @ ( A > A > $o ) @ ( list @ A ) @ X @ ( cons @ A @ X5 @ ( cons @ A @ Y4 @ Xs3 ) ) ) )
=> ( ( X @ X5 @ Y4 )
& ( successively @ A @ X @ ( cons @ A @ Y4 @ Xs3 ) ) ) ) ) ) ) ).
% successively.pelims(3)
thf(fact_8018_iterates__fixp,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [F2: A > A] :
( ( comple7038119648293358887notone @ A @ A @ ( ord_less_eq @ A ) @ ( ord_less_eq @ A ) @ F2 )
=> ( member2 @ A @ ( comple115746919287870866o_fixp @ A @ F2 ) @ ( comple6359979572994053840erates @ A @ F2 ) ) ) ) ).
% iterates_fixp
thf(fact_8019_tendsto__unique_H,axiom,
! [B: $tType,A: $tType] :
( ( topological_t2_space @ A )
=> ! [F5: filter @ B,F2: B > A] :
( ( F5
!= ( bot_bot @ ( filter @ B ) ) )
=> ( uniq @ A
@ ^ [L2: A] : ( filterlim @ B @ A @ F2 @ ( topolo7230453075368039082e_nhds @ A @ L2 ) @ F5 ) ) ) ) ).
% tendsto_unique'
thf(fact_8020_iterates__le__f,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [X: A,F2: A > A] :
( ( member2 @ A @ X @ ( comple6359979572994053840erates @ A @ F2 ) )
=> ( ( comple7038119648293358887notone @ A @ A @ ( ord_less_eq @ A ) @ ( ord_less_eq @ A ) @ F2 )
=> ( ord_less_eq @ A @ X @ ( F2 @ X ) ) ) ) ) ).
% iterates_le_f
thf(fact_8021_bot__in__iterates,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [F2: A > A] : ( member2 @ A @ ( complete_Sup_Sup @ A @ ( bot_bot @ ( set @ A ) ) ) @ ( comple6359979572994053840erates @ A @ F2 ) ) ) ).
% bot_in_iterates
thf(fact_8022_iterates_Osimps,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [A3: A,F2: A > A] :
( ( member2 @ A @ A3 @ ( comple6359979572994053840erates @ A @ F2 ) )
= ( ? [X2: A] :
( ( A3
= ( F2 @ X2 ) )
& ( member2 @ A @ X2 @ ( comple6359979572994053840erates @ A @ F2 ) ) )
| ? [M9: set @ A] :
( ( A3
= ( complete_Sup_Sup @ A @ M9 ) )
& ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ M9 )
& ! [X2: A] :
( ( member2 @ A @ X2 @ M9 )
=> ( member2 @ A @ X2 @ ( comple6359979572994053840erates @ A @ F2 ) ) ) ) ) ) ) ).
% iterates.simps
thf(fact_8023_iterates_Ocases,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [A3: A,F2: A > A] :
( ( member2 @ A @ A3 @ ( comple6359979572994053840erates @ A @ F2 ) )
=> ( ! [X5: A] :
( ( A3
= ( F2 @ X5 ) )
=> ~ ( member2 @ A @ X5 @ ( comple6359979572994053840erates @ A @ F2 ) ) )
=> ~ ! [M8: set @ A] :
( ( A3
= ( complete_Sup_Sup @ A @ M8 ) )
=> ( ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ M8 )
=> ~ ! [X3: A] :
( ( member2 @ A @ X3 @ M8 )
=> ( member2 @ A @ X3 @ ( comple6359979572994053840erates @ A @ F2 ) ) ) ) ) ) ) ) ).
% iterates.cases
thf(fact_8024_iterates_OSup,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [M7: set @ A,F2: A > A] :
( ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ M7 )
=> ( ! [X5: A] :
( ( member2 @ A @ X5 @ M7 )
=> ( member2 @ A @ X5 @ ( comple6359979572994053840erates @ A @ F2 ) ) )
=> ( member2 @ A @ ( complete_Sup_Sup @ A @ M7 ) @ ( comple6359979572994053840erates @ A @ F2 ) ) ) ) ) ).
% iterates.Sup
thf(fact_8025_chain__iterates,axiom,
! [A: $tType] :
( ( comple9053668089753744459l_ccpo @ A )
=> ! [F2: A > A] :
( ( comple7038119648293358887notone @ A @ A @ ( ord_less_eq @ A ) @ ( ord_less_eq @ A ) @ F2 )
=> ( comple1602240252501008431_chain @ A @ ( ord_less_eq @ A ) @ ( comple6359979572994053840erates @ A @ F2 ) ) ) ) ).
% chain_iterates
thf(fact_8026_subset__singleton__iff__Uniq,axiom,
! [A: $tType,A4: set @ A] :
( ( ? [A5: A] : ( ord_less_eq @ ( set @ A ) @ A4 @ ( insert2 @ A @ A5 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( uniq @ A
@ ^ [X2: A] : ( member2 @ A @ X2 @ A4 ) ) ) ).
% subset_singleton_iff_Uniq
thf(fact_8027_strict__sorted__equal__Uniq,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ! [A4: set @ A] :
( uniq @ ( list @ A )
@ ^ [Xs2: list @ A] :
( ( sorted_wrt @ A @ ( ord_less @ A ) @ Xs2 )
& ( ( set2 @ A @ Xs2 )
= A4 ) ) ) ) ).
% strict_sorted_equal_Uniq
thf(fact_8028_map__of__map,axiom,
! [B: $tType,C: $tType,A: $tType,F2: C > B,Xs: list @ ( product_prod @ A @ C )] :
( ( map_of @ A @ B
@ ( map @ ( product_prod @ A @ C ) @ ( product_prod @ A @ B )
@ ( product_case_prod @ A @ C @ ( product_prod @ A @ B )
@ ^ [K2: A,V5: C] : ( product_Pair @ A @ B @ K2 @ ( F2 @ V5 ) ) )
@ Xs ) )
= ( comp @ ( option @ C ) @ ( option @ B ) @ A @ ( map_option @ C @ B @ F2 ) @ ( map_of @ A @ C @ Xs ) ) ) ).
% map_of_map
thf(fact_8029_card__of__ordLess,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ( ~ ? [F3: A > B] :
( ( inj_on @ A @ B @ F3 @ A4 )
& ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F3 @ A4 ) @ B3 ) ) )
= ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) ) @ ( bNF_We4044943003108391690rdLess @ B @ A ) ) ) ).
% card_of_ordLess
thf(fact_8030_map__option__eq__Some,axiom,
! [A: $tType,B: $tType,F2: B > A,Xo: option @ B,Y: A] :
( ( ( map_option @ B @ A @ F2 @ Xo )
= ( some @ A @ Y ) )
= ( ? [Z6: B] :
( ( Xo
= ( some @ B @ Z6 ) )
& ( ( F2 @ Z6 )
= Y ) ) ) ) ).
% map_option_eq_Some
thf(fact_8031_map__option__o__map__upd,axiom,
! [A: $tType,B: $tType,C: $tType,F2: C > B,M: A > ( option @ C ),A3: A,B2: C] :
( ( comp @ ( option @ C ) @ ( option @ B ) @ A @ ( map_option @ C @ B @ F2 ) @ ( fun_upd @ A @ ( option @ C ) @ M @ A3 @ ( some @ C @ B2 ) ) )
= ( fun_upd @ A @ ( option @ B ) @ ( comp @ ( option @ C ) @ ( option @ B ) @ A @ ( map_option @ C @ B @ F2 ) @ M ) @ A3 @ ( some @ B @ ( F2 @ B2 ) ) ) ) ).
% map_option_o_map_upd
thf(fact_8032_card__of__mono1,axiom,
! [A: $tType,A4: set @ A,B3: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ A @ B3 ) ) @ ( bNF_Wellorder_ordLeq @ A @ A ) ) ) ).
% card_of_mono1
thf(fact_8033_card__of__empty,axiom,
! [B: $tType,A: $tType,A4: set @ B] : ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ ( bot_bot @ ( set @ A ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ A4 ) ) @ ( bNF_Wellorder_ordLeq @ A @ B ) ) ).
% card_of_empty
thf(fact_8034_card__of__empty3,axiom,
! [B: $tType,A: $tType,A4: set @ A] :
( ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ B @ ( bot_bot @ ( set @ B ) ) ) ) @ ( bNF_Wellorder_ordLeq @ A @ B ) )
=> ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ).
% card_of_empty3
thf(fact_8035_card__of__Times2,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) ) )
@ ( bNF_Wellorder_ordLeq @ B @ ( product_prod @ A @ B ) ) ) ) ).
% card_of_Times2
thf(fact_8036_card__of__Times1,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ B @ A )
@ ( product_Sigma @ B @ A @ B3
@ ^ [Uu3: B] : A4 ) ) )
@ ( bNF_Wellorder_ordLeq @ B @ ( product_prod @ B @ A ) ) ) ) ).
% card_of_Times1
thf(fact_8037_option_Osimps_I9_J,axiom,
! [B: $tType,A: $tType,F2: A > B,X22: A] :
( ( map_option @ A @ B @ F2 @ ( some @ A @ X22 ) )
= ( some @ B @ ( F2 @ X22 ) ) ) ).
% option.simps(9)
thf(fact_8038_map__option__cong,axiom,
! [B: $tType,A: $tType,X: option @ A,Y: option @ A,F2: A > B,G: A > B] :
( ( X = Y )
=> ( ! [A7: A] :
( ( Y
= ( some @ A @ A7 ) )
=> ( ( F2 @ A7 )
= ( G @ A7 ) ) )
=> ( ( map_option @ A @ B @ F2 @ X )
= ( map_option @ A @ B @ G @ Y ) ) ) ) ).
% map_option_cong
thf(fact_8039_map__option__case,axiom,
! [A: $tType,B: $tType] :
( ( map_option @ B @ A )
= ( ^ [F3: B > A] :
( case_option @ ( option @ A ) @ B @ ( none @ A )
@ ^ [X2: B] : ( some @ A @ ( F3 @ X2 ) ) ) ) ) ).
% map_option_case
thf(fact_8040_card__of__ordLeq2,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ? [G2: B > A] :
( ( image2 @ B @ A @ G2 @ B3 )
= A4 ) )
= ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) ) @ ( bNF_Wellorder_ordLeq @ A @ B ) ) ) ) ).
% card_of_ordLeq2
thf(fact_8041_surj__imp__ordLeq,axiom,
! [B: $tType,A: $tType,B3: set @ A,F2: B > A,A4: set @ B] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ B3 ) @ ( bNF_Ca6860139660246222851ard_of @ B @ A4 ) ) @ ( bNF_Wellorder_ordLeq @ A @ B ) ) ) ).
% surj_imp_ordLeq
thf(fact_8042_card__of__singl__ordLeq,axiom,
! [A: $tType,B: $tType,A4: set @ A,B2: B] :
( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ ( insert2 @ B @ B2 @ ( bot_bot @ ( set @ B ) ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) ) @ ( bNF_Wellorder_ordLeq @ B @ A ) ) ) ).
% card_of_singl_ordLeq
thf(fact_8043_card__of__ordLess2,axiom,
! [A: $tType,B: $tType,B3: set @ A,A4: set @ B] :
( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ~ ? [F3: B > A] :
( ( image2 @ B @ A @ F3 @ A4 )
= B3 ) )
= ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ A @ B3 ) ) @ ( bNF_We4044943003108391690rdLess @ B @ A ) ) ) ) ).
% card_of_ordLess2
thf(fact_8044_card__of__ordLeq,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B] :
( ( ? [F3: A > B] :
( ( inj_on @ A @ B @ F3 @ A4 )
& ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F3 @ A4 ) @ B3 ) ) )
= ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) ) @ ( bNF_Wellorder_ordLeq @ A @ B ) ) ) ).
% card_of_ordLeq
thf(fact_8045_card__of__Plus__Times__aux,axiom,
! [B: $tType,A: $tType,A12: A,A23: A,A4: set @ A,B3: set @ B] :
( ( ( A12 != A23 )
& ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ A12 @ ( insert2 @ A @ A23 @ ( bot_bot @ ( set @ A ) ) ) ) @ A4 ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) ) @ ( bNF_Wellorder_ordLeq @ A @ B ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ ( sum_sum @ A @ B ) @ ( sum_sum @ A @ B ) ) ) @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ ( sum_sum @ A @ B ) @ ( sum_sum @ A @ B ) ) ) @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ ( sum_sum @ A @ B ) @ ( sum_Plus @ A @ B @ A4 @ B3 ) )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) ) )
@ ( bNF_Wellorder_ordLeq @ ( sum_sum @ A @ B ) @ ( product_prod @ A @ B ) ) ) ) ) ).
% card_of_Plus_Times_aux
thf(fact_8046_card__of__Times__infinite__simps_I4_J,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B] :
( ~ ( finite_finite @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) ) @ ( bNF_Wellorder_ordLeq @ B @ A ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ B @ A )
@ ( product_Sigma @ B @ A @ B3
@ ^ [Uu3: B] : A4 ) ) )
@ ( bNF_Wellorder_ordIso @ A @ ( product_prod @ B @ A ) ) ) ) ) ) ).
% card_of_Times_infinite_simps(4)
thf(fact_8047_card__of__empty__ordIso,axiom,
! [B: $tType,A: $tType] : ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ ( bot_bot @ ( set @ A ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ ( bot_bot @ ( set @ B ) ) ) ) @ ( bNF_Wellorder_ordIso @ A @ B ) ) ).
% card_of_empty_ordIso
thf(fact_8048_card__of__empty2,axiom,
! [B: $tType,A: $tType,A4: set @ A] :
( ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ B @ ( bot_bot @ ( set @ B ) ) ) ) @ ( bNF_Wellorder_ordIso @ A @ B ) )
=> ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ).
% card_of_empty2
thf(fact_8049_card__Plus,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ( finite_finite @ A @ A4 )
=> ( ( finite_finite @ B @ B3 )
=> ( ( finite_card @ ( sum_sum @ A @ B ) @ ( sum_Plus @ A @ B @ A4 @ B3 ) )
= ( plus_plus @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ B @ B3 ) ) ) ) ) ).
% card_Plus
thf(fact_8050_internalize__ordLeq,axiom,
! [A: $tType,B: $tType,R6: set @ ( product_prod @ A @ A ),R2: set @ ( product_prod @ B @ B )] :
( ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ R6 @ R2 ) @ ( bNF_Wellorder_ordLeq @ A @ B ) )
= ( ? [P6: set @ ( product_prod @ B @ B )] :
( ( ord_less_eq @ ( set @ B ) @ ( field2 @ B @ P6 ) @ ( field2 @ B @ R2 ) )
& ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ R6 @ P6 ) @ ( bNF_Wellorder_ordIso @ A @ B ) )
& ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ B @ B ) ) @ P6 @ R2 ) @ ( bNF_Wellorder_ordLeq @ B @ B ) ) ) ) ) ).
% internalize_ordLeq
thf(fact_8051_card__Plus__conv__if,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B] :
( ( ( ( finite_finite @ A @ A4 )
& ( finite_finite @ B @ B3 ) )
=> ( ( finite_card @ ( sum_sum @ A @ B ) @ ( sum_Plus @ A @ B @ A4 @ B3 ) )
= ( plus_plus @ nat @ ( finite_card @ A @ A4 ) @ ( finite_card @ B @ B3 ) ) ) )
& ( ~ ( ( finite_finite @ A @ A4 )
& ( finite_finite @ B @ B3 ) )
=> ( ( finite_card @ ( sum_sum @ A @ B ) @ ( sum_Plus @ A @ B @ A4 @ B3 ) )
= ( zero_zero @ nat ) ) ) ) ).
% card_Plus_conv_if
thf(fact_8052_internalize__card__of__ordLeq2,axiom,
! [A: $tType,B: $tType,A4: set @ A,C5: set @ B] :
( ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ B @ C5 ) ) @ ( bNF_Wellorder_ordLeq @ A @ B ) )
= ( ? [B6: set @ B] :
( ( ord_less_eq @ ( set @ B ) @ B6 @ C5 )
& ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B6 ) ) @ ( bNF_Wellorder_ordIso @ A @ B ) )
& ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B6 ) @ ( bNF_Ca6860139660246222851ard_of @ B @ C5 ) ) @ ( bNF_Wellorder_ordLeq @ B @ B ) ) ) ) ) ).
% internalize_card_of_ordLeq2
thf(fact_8053_card__of__Plus__Times,axiom,
! [B: $tType,A: $tType,A12: A,A23: A,A4: set @ A,B15: B,B24: B,B3: set @ B] :
( ( ( A12 != A23 )
& ( ord_less_eq @ ( set @ A ) @ ( insert2 @ A @ A12 @ ( insert2 @ A @ A23 @ ( bot_bot @ ( set @ A ) ) ) ) @ A4 ) )
=> ( ( ( B15 != B24 )
& ( ord_less_eq @ ( set @ B ) @ ( insert2 @ B @ B15 @ ( insert2 @ B @ B24 @ ( bot_bot @ ( set @ B ) ) ) ) @ B3 ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ ( sum_sum @ A @ B ) @ ( sum_sum @ A @ B ) ) ) @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ ( sum_sum @ A @ B ) @ ( sum_sum @ A @ B ) ) ) @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ ( sum_sum @ A @ B ) @ ( sum_Plus @ A @ B @ A4 @ B3 ) )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) ) )
@ ( bNF_Wellorder_ordLeq @ ( sum_sum @ A @ B ) @ ( product_prod @ A @ B ) ) ) ) ) ).
% card_of_Plus_Times
thf(fact_8054_internalize__card__of__ordLeq,axiom,
! [A: $tType,B: $tType,A4: set @ A,R2: set @ ( product_prod @ B @ B )] :
( ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ R2 ) @ ( bNF_Wellorder_ordLeq @ A @ B ) )
= ( ? [B6: set @ B] :
( ( ord_less_eq @ ( set @ B ) @ B6 @ ( field2 @ B @ R2 ) )
& ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B6 ) ) @ ( bNF_Wellorder_ordIso @ A @ B ) )
& ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B6 ) @ R2 ) @ ( bNF_Wellorder_ordLeq @ B @ B ) ) ) ) ) ).
% internalize_card_of_ordLeq
thf(fact_8055_card__of__Times__infinite__simps_I2_J,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B] :
( ~ ( finite_finite @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) ) @ ( bNF_Wellorder_ordLeq @ B @ A ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) ) )
@ ( bNF_Wellorder_ordIso @ A @ ( product_prod @ A @ B ) ) ) ) ) ) ).
% card_of_Times_infinite_simps(2)
thf(fact_8056_regularCard__def,axiom,
! [A: $tType] :
( ( bNF_Ca7133664381575040944arCard @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A )] :
! [K6: set @ A] :
( ( ( ord_less_eq @ ( set @ A ) @ K6 @ ( field2 @ A @ R4 ) )
& ( bNF_Ca7293521722713021262ofinal @ A @ K6 @ R4 ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ K6 ) @ R4 ) @ ( bNF_Wellorder_ordIso @ A @ A ) ) ) ) ) ).
% regularCard_def
thf(fact_8057_Plus__eq__empty__conv,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ( ( sum_Plus @ A @ B @ A4 @ B3 )
= ( bot_bot @ ( set @ ( sum_sum @ A @ B ) ) ) )
= ( ( A4
= ( bot_bot @ ( set @ A ) ) )
& ( B3
= ( bot_bot @ ( set @ B ) ) ) ) ) ).
% Plus_eq_empty_conv
thf(fact_8058_card__of__bool,axiom,
! [A: $tType,A12: A,A23: A] :
( ( A12 != A23 )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ $o @ $o ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ $o @ $o ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ $o @ ( top_top @ ( set @ $o ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ ( insert2 @ A @ A12 @ ( insert2 @ A @ A23 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) @ ( bNF_Wellorder_ordIso @ $o @ A ) ) ) ).
% card_of_bool
thf(fact_8059_card__of__Func__UNIV,axiom,
! [B: $tType,A: $tType,B3: set @ B] :
( member2 @ ( product_prod @ ( set @ ( product_prod @ ( A > B ) @ ( A > B ) ) ) @ ( set @ ( product_prod @ ( A > B ) @ ( A > B ) ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ ( A > B ) @ ( A > B ) ) ) @ ( set @ ( product_prod @ ( A > B ) @ ( A > B ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ ( A > B ) @ ( bNF_Wellorder_Func @ A @ B @ ( top_top @ ( set @ A ) ) @ B3 ) )
@ ( bNF_Ca6860139660246222851ard_of @ ( A > B )
@ ( collect @ ( A > B )
@ ^ [F3: A > B] : ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F3 @ ( top_top @ ( set @ A ) ) ) @ B3 ) ) ) )
@ ( bNF_Wellorder_ordIso @ ( A > B ) @ ( A > B ) ) ) ).
% card_of_Func_UNIV
thf(fact_8060_card__of__Plus__empty1,axiom,
! [B: $tType,A: $tType,A4: set @ A] : ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( sum_sum @ A @ B ) @ ( sum_sum @ A @ B ) ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( sum_sum @ A @ B ) @ ( sum_sum @ A @ B ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ ( sum_sum @ A @ B ) @ ( sum_Plus @ A @ B @ A4 @ ( bot_bot @ ( set @ B ) ) ) ) ) @ ( bNF_Wellorder_ordIso @ A @ ( sum_sum @ A @ B ) ) ) ).
% card_of_Plus_empty1
thf(fact_8061_card__of__Plus__empty2,axiom,
! [B: $tType,A: $tType,A4: set @ A] : ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( sum_sum @ B @ A ) @ ( sum_sum @ B @ A ) ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( sum_sum @ B @ A ) @ ( sum_sum @ B @ A ) ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Ca6860139660246222851ard_of @ ( sum_sum @ B @ A ) @ ( sum_Plus @ B @ A @ ( bot_bot @ ( set @ B ) ) @ A4 ) ) ) @ ( bNF_Wellorder_ordIso @ A @ ( sum_sum @ B @ A ) ) ) ).
% card_of_Plus_empty2
thf(fact_8062_card__of__Times__infinite__simps_I3_J,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ~ ( finite_finite @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) ) @ ( bNF_Wellorder_ordLeq @ B @ A ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) @ ( set @ ( product_prod @ A @ A ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) @ ( set @ ( product_prod @ A @ A ) )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ B @ A )
@ ( product_Sigma @ B @ A @ B3
@ ^ [Uu3: B] : A4 ) )
@ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) )
@ ( bNF_Wellorder_ordIso @ ( product_prod @ B @ A ) @ A ) ) ) ) ) ).
% card_of_Times_infinite_simps(3)
thf(fact_8063_card__of__Times__infinite__simps_I1_J,axiom,
! [B: $tType,A: $tType,A4: set @ A,B3: set @ B] :
( ~ ( finite_finite @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) ) @ ( bNF_Wellorder_ordLeq @ B @ A ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) @ ( set @ ( product_prod @ A @ A ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) @ ( set @ ( product_prod @ A @ A ) )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) )
@ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) )
@ ( bNF_Wellorder_ordIso @ ( product_prod @ A @ B ) @ A ) ) ) ) ) ).
% card_of_Times_infinite_simps(1)
thf(fact_8064_card__of__Times__infinite,axiom,
! [A: $tType,B: $tType,A4: set @ A,B3: set @ B] :
( ~ ( finite_finite @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) ) @ ( bNF_Wellorder_ordLeq @ B @ A ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) @ ( set @ ( product_prod @ A @ A ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) @ ( set @ ( product_prod @ A @ A ) )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ A4
@ ^ [Uu3: A] : B3 ) )
@ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) )
@ ( bNF_Wellorder_ordIso @ ( product_prod @ A @ B ) @ A ) )
& ( member2 @ ( product_prod @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) @ ( set @ ( product_prod @ A @ A ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) @ ( set @ ( product_prod @ A @ A ) )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ B @ A )
@ ( product_Sigma @ B @ A @ B3
@ ^ [Uu3: B] : A4 ) )
@ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) )
@ ( bNF_Wellorder_ordIso @ ( product_prod @ B @ A ) @ A ) ) ) ) ) ) ).
% card_of_Times_infinite
thf(fact_8065_regularCard__UNION,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A ),As3: A > ( set @ B ),B3: set @ B] :
( ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( bNF_Ca7133664381575040944arCard @ A @ R2 )
=> ( ( bNF_Ca3754400796208372196lChain @ A @ ( set @ B ) @ R2 @ As3 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ A @ ( set @ B ) @ As3 @ ( field2 @ A @ R2 ) ) ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) @ R2 ) @ ( bNF_We4044943003108391690rdLess @ B @ A ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ ( field2 @ A @ R2 ) )
& ( ord_less_eq @ ( set @ B ) @ B3 @ ( As3 @ X5 ) ) ) ) ) ) ) ) ).
% regularCard_UNION
thf(fact_8066_Card__order__Times__infinite,axiom,
! [A: $tType,B: $tType,R2: set @ ( product_prod @ A @ A ),P4: set @ ( product_prod @ B @ B )] :
( ~ ( finite_finite @ A @ ( field2 @ A @ R2 ) )
=> ( ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( ( field2 @ B @ P4 )
!= ( bot_bot @ ( set @ B ) ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ P4 @ R2 ) @ ( bNF_Wellorder_ordLeq @ B @ A ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) @ ( set @ ( product_prod @ A @ A ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) @ ( set @ ( product_prod @ A @ A ) )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ ( field2 @ A @ R2 )
@ ^ [Uu3: A] : ( field2 @ B @ P4 ) ) )
@ R2 )
@ ( bNF_Wellorder_ordIso @ ( product_prod @ A @ B ) @ A ) )
& ( member2 @ ( product_prod @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) @ ( set @ ( product_prod @ A @ A ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) @ ( set @ ( product_prod @ A @ A ) )
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ B @ A )
@ ( product_Sigma @ B @ A @ ( field2 @ B @ P4 )
@ ^ [Uu3: B] : ( field2 @ A @ R2 ) ) )
@ R2 )
@ ( bNF_Wellorder_ordIso @ ( product_prod @ B @ A ) @ A ) ) ) ) ) ) ) ).
% Card_order_Times_infinite
thf(fact_8067_UNIV__bool,axiom,
( ( top_top @ ( set @ $o ) )
= ( insert2 @ $o @ $false @ ( insert2 @ $o @ $true @ ( bot_bot @ ( set @ $o ) ) ) ) ) ).
% UNIV_bool
thf(fact_8068_infinite__Card__order__limit,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),A3: A] :
( ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ~ ( finite_finite @ A @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ A3 @ ( field2 @ A @ R2 ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ ( field2 @ A @ R2 ) )
& ( A3 != X5 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A3 @ X5 ) @ R2 ) ) ) ) ) ).
% infinite_Card_order_limit
thf(fact_8069_Card__order__trans,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A ),X: A,Y: A,Z: A] :
( ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( X != Y )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Y ) @ R2 )
=> ( ( Y != Z )
=> ( ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Y @ Z ) @ R2 )
=> ( ( X != Z )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ Z ) @ R2 ) ) ) ) ) ) ) ).
% Card_order_trans
thf(fact_8070_exists__minim__Card__order,axiom,
! [A: $tType,R: set @ ( set @ ( product_prod @ A @ A ) )] :
( ( R
!= ( bot_bot @ ( set @ ( set @ ( product_prod @ A @ A ) ) ) ) )
=> ( ! [X5: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( set @ ( product_prod @ A @ A ) ) @ X5 @ R )
=> ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ X5 ) @ X5 ) )
=> ? [X5: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( set @ ( product_prod @ A @ A ) ) @ X5 @ R )
& ! [Xa: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( set @ ( product_prod @ A @ A ) ) @ Xa @ R )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) @ X5 @ Xa ) @ ( bNF_Wellorder_ordLeq @ A @ A ) ) ) ) ) ) ).
% exists_minim_Card_order
thf(fact_8071_Card__order__empty,axiom,
! [A: $tType,B: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ ( bot_bot @ ( set @ B ) ) ) @ R2 ) @ ( bNF_Wellorder_ordLeq @ B @ A ) ) ) ).
% Card_order_empty
thf(fact_8072_Card__order__singl__ordLeq,axiom,
! [A: $tType,B: $tType,R2: set @ ( product_prod @ A @ A ),B2: B] :
( ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( ( field2 @ A @ R2 )
!= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ ( insert2 @ B @ B2 @ ( bot_bot @ ( set @ B ) ) ) ) @ R2 ) @ ( bNF_Wellorder_ordLeq @ B @ A ) ) ) ) ).
% Card_order_singl_ordLeq
thf(fact_8073_card__of__empty1,axiom,
! [A: $tType,B: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( ( order_well_order_on @ A @ ( field2 @ A @ R2 ) @ R2 )
| ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ ( bot_bot @ ( set @ B ) ) ) @ R2 ) @ ( bNF_Wellorder_ordLeq @ B @ A ) ) ) ).
% card_of_empty1
thf(fact_8074_Card__order__Times1,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A ),B3: set @ B] :
( ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( B3
!= ( bot_bot @ ( set @ B ) ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( product_prod @ A @ B ) @ ( product_prod @ A @ B ) ) ) @ R2
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ A @ B )
@ ( product_Sigma @ A @ B @ ( field2 @ A @ R2 )
@ ^ [Uu3: A] : B3 ) ) )
@ ( bNF_Wellorder_ordLeq @ A @ ( product_prod @ A @ B ) ) ) ) ) ).
% Card_order_Times1
thf(fact_8075_Card__order__Times2,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A ),A4: set @ B] :
( ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( A4
!= ( bot_bot @ ( set @ B ) ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) )
@ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ ( product_prod @ B @ A ) @ ( product_prod @ B @ A ) ) ) @ R2
@ ( bNF_Ca6860139660246222851ard_of @ ( product_prod @ B @ A )
@ ( product_Sigma @ B @ A @ A4
@ ^ [Uu3: B] : ( field2 @ A @ R2 ) ) ) )
@ ( bNF_Wellorder_ordLeq @ A @ ( product_prod @ B @ A ) ) ) ) ) ).
% Card_order_Times2
thf(fact_8076_toCard__pred__def,axiom,
! [B: $tType,A: $tType] :
( ( bNF_Gr1419584066657907630d_pred @ A @ B )
= ( ^ [A6: set @ A,R4: set @ ( product_prod @ B @ B ),F3: A > B] :
( ( inj_on @ A @ B @ F3 @ A6 )
& ( ord_less_eq @ ( set @ B ) @ ( image2 @ A @ B @ F3 @ A6 ) @ ( field2 @ B @ R4 ) )
& ( bNF_Ca8970107618336181345der_on @ B @ ( field2 @ B @ R4 ) @ R4 ) ) ) ) ).
% toCard_pred_def
thf(fact_8077_cardSuc__UNION,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A ),As3: ( set @ A ) > ( set @ B ),B3: set @ B] :
( ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ~ ( finite_finite @ A @ ( field2 @ A @ R2 ) )
=> ( ( bNF_Ca3754400796208372196lChain @ ( set @ A ) @ ( set @ B ) @ ( bNF_Ca8387033319878233205ardSuc @ A @ R2 ) @ As3 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ ( set @ A ) @ ( set @ B ) @ As3 @ ( field2 @ ( set @ A ) @ ( bNF_Ca8387033319878233205ardSuc @ A @ R2 ) ) ) ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) @ R2 ) @ ( bNF_Wellorder_ordLeq @ B @ A ) )
=> ? [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ ( field2 @ ( set @ A ) @ ( bNF_Ca8387033319878233205ardSuc @ A @ R2 ) ) )
& ( ord_less_eq @ ( set @ B ) @ B3 @ ( As3 @ X5 ) ) ) ) ) ) ) ) ).
% cardSuc_UNION
thf(fact_8078_cardSuc__UNION__Cinfinite,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A ),As3: ( set @ A ) > ( set @ B ),B3: set @ B] :
( ( ( bNF_Ca4139267488887388095finite @ A @ R2 )
& ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 ) )
=> ( ( bNF_Ca3754400796208372196lChain @ ( set @ A ) @ ( set @ B ) @ ( bNF_Ca8387033319878233205ardSuc @ A @ R2 ) @ As3 )
=> ( ( ord_less_eq @ ( set @ B ) @ B3 @ ( complete_Sup_Sup @ ( set @ B ) @ ( image2 @ ( set @ A ) @ ( set @ B ) @ As3 @ ( field2 @ ( set @ A ) @ ( bNF_Ca8387033319878233205ardSuc @ A @ R2 ) ) ) ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ B @ B ) ) @ ( set @ ( product_prod @ A @ A ) ) @ ( bNF_Ca6860139660246222851ard_of @ B @ B3 ) @ R2 ) @ ( bNF_Wellorder_ordLeq @ B @ A ) )
=> ? [X5: set @ A] :
( ( member2 @ ( set @ A ) @ X5 @ ( field2 @ ( set @ A ) @ ( bNF_Ca8387033319878233205ardSuc @ A @ R2 ) ) )
& ( ord_less_eq @ ( set @ B ) @ B3 @ ( As3 @ X5 ) ) ) ) ) ) ) ).
% cardSuc_UNION_Cinfinite
thf(fact_8079_Rep__unit__induct,axiom,
! [Y: $o,P2: $o > $o] :
( ( member2 @ $o @ Y @ ( insert2 @ $o @ $true @ ( bot_bot @ ( set @ $o ) ) ) )
=> ( ! [X5: product_unit] : ( P2 @ ( product_Rep_unit @ X5 ) )
=> ( P2 @ Y ) ) ) ).
% Rep_unit_induct
thf(fact_8080_Cinfinite__limit2,axiom,
! [A: $tType,X1: A,R2: set @ ( product_prod @ A @ A ),X22: A] :
( ( member2 @ A @ X1 @ ( field2 @ A @ R2 ) )
=> ( ( member2 @ A @ X22 @ ( field2 @ A @ R2 ) )
=> ( ( ( bNF_Ca4139267488887388095finite @ A @ R2 )
& ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ ( field2 @ A @ R2 ) )
& ( X1 != X5 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X1 @ X5 ) @ R2 )
& ( X22 != X5 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X22 @ X5 ) @ R2 ) ) ) ) ) ).
% Cinfinite_limit2
thf(fact_8081_Cinfinite__limit,axiom,
! [A: $tType,X: A,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ A @ X @ ( field2 @ A @ R2 ) )
=> ( ( ( bNF_Ca4139267488887388095finite @ A @ R2 )
& ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ ( field2 @ A @ R2 ) )
& ( X != X5 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X @ X5 ) @ R2 ) ) ) ) ).
% Cinfinite_limit
thf(fact_8082_Cinfinite__limit__finite,axiom,
! [A: $tType,X7: set @ A,R2: set @ ( product_prod @ A @ A )] :
( ( finite_finite @ A @ X7 )
=> ( ( ord_less_eq @ ( set @ A ) @ X7 @ ( field2 @ A @ R2 ) )
=> ( ( ( bNF_Ca4139267488887388095finite @ A @ R2 )
& ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 ) )
=> ? [X5: A] :
( ( member2 @ A @ X5 @ ( field2 @ A @ R2 ) )
& ! [Xa: A] :
( ( member2 @ A @ Xa @ X7 )
=> ( ( Xa != X5 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ Xa @ X5 ) @ R2 ) ) ) ) ) ) ) ).
% Cinfinite_limit_finite
thf(fact_8083_Rep__unit,axiom,
! [X: product_unit] : ( member2 @ $o @ ( product_Rep_unit @ X ) @ ( insert2 @ $o @ $true @ ( bot_bot @ ( set @ $o ) ) ) ) ).
% Rep_unit
thf(fact_8084_Rep__unit__cases,axiom,
! [Y: $o] :
( ( member2 @ $o @ Y @ ( insert2 @ $o @ $true @ ( bot_bot @ ( set @ $o ) ) ) )
=> ~ ! [X5: product_unit] :
( Y
= ( ~ ( product_Rep_unit @ X5 ) ) ) ) ).
% Rep_unit_cases
thf(fact_8085_Abs__unit__inverse,axiom,
! [Y: $o] :
( ( member2 @ $o @ Y @ ( insert2 @ $o @ $true @ ( bot_bot @ ( set @ $o ) ) ) )
=> ( ( product_Rep_unit @ ( product_Abs_unit @ Y ) )
= Y ) ) ).
% Abs_unit_inverse
thf(fact_8086_cexp__mono2_H,axiom,
! [B: $tType,C: $tType,A: $tType,P23: set @ ( product_prod @ A @ A ),R22: set @ ( product_prod @ B @ B ),Q2: set @ ( product_prod @ C @ C )] :
( ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ P23 @ R22 ) @ ( bNF_Wellorder_ordLeq @ A @ B ) )
=> ( ( bNF_Ca8970107618336181345der_on @ C @ ( field2 @ C @ Q2 ) @ Q2 )
=> ( ( ( ( field2 @ A @ P23 )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( field2 @ B @ R22 )
= ( bot_bot @ ( set @ B ) ) ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ ( A > C ) @ ( A > C ) ) ) @ ( set @ ( product_prod @ ( B > C ) @ ( B > C ) ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ ( A > C ) @ ( A > C ) ) ) @ ( set @ ( product_prod @ ( B > C ) @ ( B > C ) ) ) @ ( bNF_Cardinal_cexp @ C @ A @ Q2 @ P23 ) @ ( bNF_Cardinal_cexp @ C @ B @ Q2 @ R22 ) ) @ ( bNF_Wellorder_ordLeq @ ( A > C ) @ ( B > C ) ) ) ) ) ) ).
% cexp_mono2'
thf(fact_8087_Abs__unit__inject,axiom,
! [X: $o,Y: $o] :
( ( member2 @ $o @ X @ ( insert2 @ $o @ $true @ ( bot_bot @ ( set @ $o ) ) ) )
=> ( ( member2 @ $o @ Y @ ( insert2 @ $o @ $true @ ( bot_bot @ ( set @ $o ) ) ) )
=> ( ( ( product_Abs_unit @ X )
= ( product_Abs_unit @ Y ) )
= ( X = Y ) ) ) ) ).
% Abs_unit_inject
thf(fact_8088_Abs__unit__induct,axiom,
! [P2: product_unit > $o,X: product_unit] :
( ! [Y4: $o] :
( ( member2 @ $o @ Y4 @ ( insert2 @ $o @ $true @ ( bot_bot @ ( set @ $o ) ) ) )
=> ( P2 @ ( product_Abs_unit @ Y4 ) ) )
=> ( P2 @ X ) ) ).
% Abs_unit_induct
thf(fact_8089_Abs__unit__cases,axiom,
! [X: product_unit] :
~ ! [Y4: $o] :
( ( X
= ( product_Abs_unit @ Y4 ) )
=> ~ ( member2 @ $o @ Y4 @ ( insert2 @ $o @ $true @ ( bot_bot @ ( set @ $o ) ) ) ) ) ).
% Abs_unit_cases
thf(fact_8090_cexp__mono_H,axiom,
! [B: $tType,D: $tType,A: $tType,C: $tType,P12: set @ ( product_prod @ A @ A ),R1: set @ ( product_prod @ B @ B ),P23: set @ ( product_prod @ C @ C ),R22: set @ ( product_prod @ D @ D )] :
( ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ P12 @ R1 ) @ ( bNF_Wellorder_ordLeq @ A @ B ) )
=> ( ( member2 @ ( product_prod @ ( set @ ( product_prod @ C @ C ) ) @ ( set @ ( product_prod @ D @ D ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ C @ C ) ) @ ( set @ ( product_prod @ D @ D ) ) @ P23 @ R22 ) @ ( bNF_Wellorder_ordLeq @ C @ D ) )
=> ( ( ( ( field2 @ C @ P23 )
= ( bot_bot @ ( set @ C ) ) )
=> ( ( field2 @ D @ R22 )
= ( bot_bot @ ( set @ D ) ) ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ ( C > A ) @ ( C > A ) ) ) @ ( set @ ( product_prod @ ( D > B ) @ ( D > B ) ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ ( C > A ) @ ( C > A ) ) ) @ ( set @ ( product_prod @ ( D > B ) @ ( D > B ) ) ) @ ( bNF_Cardinal_cexp @ A @ C @ P12 @ P23 ) @ ( bNF_Cardinal_cexp @ B @ D @ R1 @ R22 ) ) @ ( bNF_Wellorder_ordLeq @ ( C > A ) @ ( D > B ) ) ) ) ) ) ).
% cexp_mono'
thf(fact_8091_czeroI,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( ( field2 @ A @ R2 )
= ( bot_bot @ ( set @ A ) ) )
=> ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ R2 @ ( bNF_Cardinal_czero @ B ) ) @ ( bNF_Wellorder_ordIso @ A @ B ) ) ) ) ).
% czeroI
thf(fact_8092_Cnotzero__imp__not__empty,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( ~ ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ A @ A ) ) @ R2 @ ( bNF_Cardinal_czero @ A ) ) @ ( bNF_Wellorder_ordIso @ A @ A ) )
& ( bNF_Ca8970107618336181345der_on @ A @ ( field2 @ A @ R2 ) @ R2 ) )
=> ( ( field2 @ A @ R2 )
!= ( bot_bot @ ( set @ A ) ) ) ) ).
% Cnotzero_imp_not_empty
thf(fact_8093_czero__def,axiom,
! [A: $tType] :
( ( bNF_Cardinal_czero @ A )
= ( bNF_Ca6860139660246222851ard_of @ A @ ( bot_bot @ ( set @ A ) ) ) ) ).
% czero_def
thf(fact_8094_czeroE,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ R2 @ ( bNF_Cardinal_czero @ B ) ) @ ( bNF_Wellorder_ordIso @ A @ B ) )
=> ( ( field2 @ A @ R2 )
= ( bot_bot @ ( set @ A ) ) ) ) ).
% czeroE
thf(fact_8095_card__of__ordIso__czero__iff__empty,axiom,
! [B: $tType,A: $tType,A4: set @ A] :
( ( member2 @ ( product_prod @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) ) @ ( product_Pair @ ( set @ ( product_prod @ A @ A ) ) @ ( set @ ( product_prod @ B @ B ) ) @ ( bNF_Ca6860139660246222851ard_of @ A @ A4 ) @ ( bNF_Cardinal_czero @ B ) ) @ ( bNF_Wellorder_ordIso @ A @ B ) )
= ( A4
= ( bot_bot @ ( set @ A ) ) ) ) ).
% card_of_ordIso_czero_iff_empty
thf(fact_8096_type__definition__unit,axiom,
type_definition @ product_unit @ $o @ product_Rep_unit @ product_Abs_unit @ ( insert2 @ $o @ $true @ ( bot_bot @ ( set @ $o ) ) ) ).
% type_definition_unit
thf(fact_8097_aboveS__def,axiom,
! [A: $tType] :
( ( order_aboveS @ A )
= ( ^ [R4: set @ ( product_prod @ A @ A ),A5: A] :
( collect @ A
@ ^ [B4: A] :
( ( B4 != A5 )
& ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ A5 @ B4 ) @ R4 ) ) ) ) ) ).
% aboveS_def
thf(fact_8098_relInvImage__def,axiom,
! [B: $tType,A: $tType] :
( ( bNF_Gr7122648621184425601vImage @ A @ B )
= ( ^ [A6: set @ A,R5: set @ ( product_prod @ B @ B ),F3: A > B] :
( collect @ ( product_prod @ A @ A )
@ ^ [Uu3: product_prod @ A @ A] :
? [A1: A,A22: A] :
( ( Uu3
= ( product_Pair @ A @ A @ A1 @ A22 ) )
& ( member2 @ A @ A1 @ A6 )
& ( member2 @ A @ A22 @ A6 )
& ( member2 @ ( product_prod @ B @ B ) @ ( product_Pair @ B @ B @ ( F3 @ A1 ) @ ( F3 @ A22 ) ) @ R5 ) ) ) ) ) ).
% relInvImage_def
thf(fact_8099_Gcd__fin_Oeq__fold,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ( ( semiring_gcd_Gcd_fin @ A )
= ( ^ [A6: set @ A] : ( if @ A @ ( finite_finite @ A @ A6 ) @ ( finite_fold @ A @ A @ ( gcd_gcd @ A ) @ ( zero_zero @ A ) @ A6 ) @ ( one_one @ A ) ) ) ) ) ).
% Gcd_fin.eq_fold
thf(fact_8100_gcd__nat_Oeq__neutr__iff,axiom,
! [A3: nat,B2: nat] :
( ( ( gcd_gcd @ nat @ A3 @ B2 )
= ( zero_zero @ nat ) )
= ( ( A3
= ( zero_zero @ nat ) )
& ( B2
= ( zero_zero @ nat ) ) ) ) ).
% gcd_nat.eq_neutr_iff
thf(fact_8101_gcd__nat_Oleft__neutral,axiom,
! [A3: nat] :
( ( gcd_gcd @ nat @ ( zero_zero @ nat ) @ A3 )
= A3 ) ).
% gcd_nat.left_neutral
thf(fact_8102_gcd__nat_Oneutr__eq__iff,axiom,
! [A3: nat,B2: nat] :
( ( ( zero_zero @ nat )
= ( gcd_gcd @ nat @ A3 @ B2 ) )
= ( ( A3
= ( zero_zero @ nat ) )
& ( B2
= ( zero_zero @ nat ) ) ) ) ).
% gcd_nat.neutr_eq_iff
thf(fact_8103_gcd__nat_Oright__neutral,axiom,
! [A3: nat] :
( ( gcd_gcd @ nat @ A3 @ ( zero_zero @ nat ) )
= A3 ) ).
% gcd_nat.right_neutral
thf(fact_8104_gcd__0__nat,axiom,
! [X: nat] :
( ( gcd_gcd @ nat @ X @ ( zero_zero @ nat ) )
= X ) ).
% gcd_0_nat
thf(fact_8105_gcd__0__left__nat,axiom,
! [X: nat] :
( ( gcd_gcd @ nat @ ( zero_zero @ nat ) @ X )
= X ) ).
% gcd_0_left_nat
thf(fact_8106_gcd__Suc__0,axiom,
! [M: nat] :
( ( gcd_gcd @ nat @ M @ ( suc @ ( zero_zero @ nat ) ) )
= ( suc @ ( zero_zero @ nat ) ) ) ).
% gcd_Suc_0
thf(fact_8107_gcd__pos__nat,axiom,
! [M: nat,N2: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ ( gcd_gcd @ nat @ M @ N2 ) )
= ( ( M
!= ( zero_zero @ nat ) )
| ( N2
!= ( zero_zero @ nat ) ) ) ) ).
% gcd_pos_nat
thf(fact_8108_gcd__eq__0__iff,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [A3: A,B2: A] :
( ( ( gcd_gcd @ A @ A3 @ B2 )
= ( zero_zero @ A ) )
= ( ( A3
= ( zero_zero @ A ) )
& ( B2
= ( zero_zero @ A ) ) ) ) ) ).
% gcd_eq_0_iff
thf(fact_8109_gcd__add1,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [M: A,N2: A] :
( ( gcd_gcd @ A @ ( plus_plus @ A @ M @ N2 ) @ N2 )
= ( gcd_gcd @ A @ M @ N2 ) ) ) ).
% gcd_add1
thf(fact_8110_gcd__add2,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [M: A,N2: A] :
( ( gcd_gcd @ A @ M @ ( plus_plus @ A @ M @ N2 ) )
= ( gcd_gcd @ A @ M @ N2 ) ) ) ).
% gcd_add2
thf(fact_8111_Gcd__2,axiom,
! [A: $tType] :
( ( semiring_Gcd @ A )
=> ! [A3: A,B2: A] :
( ( gcd_Gcd @ A @ ( insert2 @ A @ A3 @ ( insert2 @ A @ B2 @ ( bot_bot @ ( set @ A ) ) ) ) )
= ( gcd_gcd @ A @ A3 @ B2 ) ) ) ).
% Gcd_2
thf(fact_8112_Gcd__in,axiom,
! [A4: set @ nat] :
( ! [A7: nat,B5: nat] :
( ( member2 @ nat @ A7 @ A4 )
=> ( ( member2 @ nat @ B5 @ A4 )
=> ( member2 @ nat @ ( gcd_gcd @ nat @ A7 @ B5 ) @ A4 ) ) )
=> ( ( A4
!= ( bot_bot @ ( set @ nat ) ) )
=> ( member2 @ nat @ ( gcd_Gcd @ nat @ A4 ) @ A4 ) ) ) ).
% Gcd_in
thf(fact_8113_gcd__diff2__nat,axiom,
! [M: nat,N2: nat] :
( ( ord_less_eq @ nat @ M @ N2 )
=> ( ( gcd_gcd @ nat @ ( minus_minus @ nat @ N2 @ M ) @ N2 )
= ( gcd_gcd @ nat @ M @ N2 ) ) ) ).
% gcd_diff2_nat
thf(fact_8114_gcd__diff1__nat,axiom,
! [N2: nat,M: nat] :
( ( ord_less_eq @ nat @ N2 @ M )
=> ( ( gcd_gcd @ nat @ ( minus_minus @ nat @ M @ N2 ) @ N2 )
= ( gcd_gcd @ nat @ M @ N2 ) ) ) ).
% gcd_diff1_nat
thf(fact_8115_gcd__le1__nat,axiom,
! [A3: nat,B2: nat] :
( ( A3
!= ( zero_zero @ nat ) )
=> ( ord_less_eq @ nat @ ( gcd_gcd @ nat @ A3 @ B2 ) @ A3 ) ) ).
% gcd_le1_nat
thf(fact_8116_gcd__le2__nat,axiom,
! [B2: nat,A3: nat] :
( ( B2
!= ( zero_zero @ nat ) )
=> ( ord_less_eq @ nat @ ( gcd_gcd @ nat @ A3 @ B2 ) @ B2 ) ) ).
% gcd_le2_nat
thf(fact_8117_div__gcd__coprime,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [A3: A,B2: A] :
( ( ( A3
!= ( zero_zero @ A ) )
| ( B2
!= ( zero_zero @ A ) ) )
=> ( algebr8660921524188924756oprime @ A @ ( divide_divide @ A @ A3 @ ( gcd_gcd @ A @ A3 @ B2 ) ) @ ( divide_divide @ A @ B2 @ ( gcd_gcd @ A @ A3 @ B2 ) ) ) ) ) ).
% div_gcd_coprime
thf(fact_8118_gcd__nat_Oelims,axiom,
! [X: nat,Xa2: nat,Y: nat] :
( ( ( gcd_gcd @ nat @ X @ Xa2 )
= Y )
=> ( ( ( Xa2
= ( zero_zero @ nat ) )
=> ( Y = X ) )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( Y
= ( gcd_gcd @ nat @ Xa2 @ ( modulo_modulo @ nat @ X @ Xa2 ) ) ) ) ) ) ).
% gcd_nat.elims
thf(fact_8119_gcd__nat_Osimps,axiom,
( ( gcd_gcd @ nat )
= ( ^ [X2: nat,Y2: nat] :
( if @ nat
@ ( Y2
= ( zero_zero @ nat ) )
@ X2
@ ( gcd_gcd @ nat @ Y2 @ ( modulo_modulo @ nat @ X2 @ Y2 ) ) ) ) ) ).
% gcd_nat.simps
thf(fact_8120_gcd__non__0__nat,axiom,
! [Y: nat,X: nat] :
( ( Y
!= ( zero_zero @ nat ) )
=> ( ( gcd_gcd @ nat @ X @ Y )
= ( gcd_gcd @ nat @ Y @ ( modulo_modulo @ nat @ X @ Y ) ) ) ) ).
% gcd_non_0_nat
thf(fact_8121_Gcd__fin_Osubset,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [B3: set @ A,A4: set @ A] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( gcd_gcd @ A @ ( semiring_gcd_Gcd_fin @ A @ B3 ) @ ( semiring_gcd_Gcd_fin @ A @ A4 ) )
= ( semiring_gcd_Gcd_fin @ A @ A4 ) ) ) ) ).
% Gcd_fin.subset
thf(fact_8122_gcd__add__mult,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [M: A,K: A,N2: A] :
( ( gcd_gcd @ A @ M @ ( plus_plus @ A @ ( times_times @ A @ K @ M ) @ N2 ) )
= ( gcd_gcd @ A @ M @ N2 ) ) ) ).
% gcd_add_mult
thf(fact_8123_bezout__nat,axiom,
! [A3: nat,B2: nat] :
( ( A3
!= ( zero_zero @ nat ) )
=> ? [X5: nat,Y4: nat] :
( ( times_times @ nat @ A3 @ X5 )
= ( plus_plus @ nat @ ( times_times @ nat @ B2 @ Y4 ) @ ( gcd_gcd @ nat @ A3 @ B2 ) ) ) ) ).
% bezout_nat
thf(fact_8124_gcd__coprime__exists,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [A3: A,B2: A] :
( ( ( gcd_gcd @ A @ A3 @ B2 )
!= ( zero_zero @ A ) )
=> ? [A28: A,B18: A] :
( ( A3
= ( times_times @ A @ A28 @ ( gcd_gcd @ A @ A3 @ B2 ) ) )
& ( B2
= ( times_times @ A @ B18 @ ( gcd_gcd @ A @ A3 @ B2 ) ) )
& ( algebr8660921524188924756oprime @ A @ A28 @ B18 ) ) ) ) ).
% gcd_coprime_exists
thf(fact_8125_gcd__coprime,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [A3: A,B2: A,A8: A,B7: A] :
( ( ( gcd_gcd @ A @ A3 @ B2 )
!= ( zero_zero @ A ) )
=> ( ( A3
= ( times_times @ A @ A8 @ ( gcd_gcd @ A @ A3 @ B2 ) ) )
=> ( ( B2
= ( times_times @ A @ B7 @ ( gcd_gcd @ A @ A3 @ B2 ) ) )
=> ( algebr8660921524188924756oprime @ A @ A8 @ B7 ) ) ) ) ) ).
% gcd_coprime
thf(fact_8126_bezout__gcd__nat_H,axiom,
! [B2: nat,A3: nat] :
? [X5: nat,Y4: nat] :
( ( ( ord_less_eq @ nat @ ( times_times @ nat @ B2 @ Y4 ) @ ( times_times @ nat @ A3 @ X5 ) )
& ( ( minus_minus @ nat @ ( times_times @ nat @ A3 @ X5 ) @ ( times_times @ nat @ B2 @ Y4 ) )
= ( gcd_gcd @ nat @ A3 @ B2 ) ) )
| ( ( ord_less_eq @ nat @ ( times_times @ nat @ A3 @ Y4 ) @ ( times_times @ nat @ B2 @ X5 ) )
& ( ( minus_minus @ nat @ ( times_times @ nat @ B2 @ X5 ) @ ( times_times @ nat @ A3 @ Y4 ) )
= ( gcd_gcd @ nat @ A3 @ B2 ) ) ) ) ).
% bezout_gcd_nat'
thf(fact_8127_Gcd__nat__set__eq__fold,axiom,
! [Xs: list @ nat] :
( ( gcd_Gcd @ nat @ ( set2 @ nat @ Xs ) )
= ( fold @ nat @ nat @ ( gcd_gcd @ nat ) @ Xs @ ( zero_zero @ nat ) ) ) ).
% Gcd_nat_set_eq_fold
thf(fact_8128_Gcd__fin_Oinsert__remove,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [A3: A,A4: set @ A] :
( ( semiring_gcd_Gcd_fin @ A @ ( insert2 @ A @ A3 @ A4 ) )
= ( gcd_gcd @ A @ A3 @ ( semiring_gcd_Gcd_fin @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% Gcd_fin.insert_remove
thf(fact_8129_Gcd__fin_Oremove,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [A3: A,A4: set @ A] :
( ( member2 @ A @ A3 @ A4 )
=> ( ( semiring_gcd_Gcd_fin @ A @ A4 )
= ( gcd_gcd @ A @ A3 @ ( semiring_gcd_Gcd_fin @ A @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ).
% Gcd_fin.remove
thf(fact_8130_Gcd__set__eq__fold,axiom,
! [A: $tType] :
( ( semiring_Gcd @ A )
=> ! [Xs: list @ A] :
( ( gcd_Gcd @ A @ ( set2 @ A @ Xs ) )
= ( fold @ A @ A @ ( gcd_gcd @ A ) @ Xs @ ( zero_zero @ A ) ) ) ) ).
% Gcd_set_eq_fold
thf(fact_8131_Gcd__fin_Oset__eq__fold,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ! [Xs: list @ A] :
( ( semiring_gcd_Gcd_fin @ A @ ( set2 @ A @ Xs ) )
= ( fold @ A @ A @ ( gcd_gcd @ A ) @ Xs @ ( zero_zero @ A ) ) ) ) ).
% Gcd_fin.set_eq_fold
thf(fact_8132_gcd__nat_Osemilattice__neutr__order__axioms,axiom,
( semila1105856199041335345_order @ nat @ ( gcd_gcd @ nat ) @ ( zero_zero @ nat ) @ ( dvd_dvd @ nat )
@ ^ [M2: nat,N: nat] :
( ( dvd_dvd @ nat @ M2 @ N )
& ( M2 != N ) ) ) ).
% gcd_nat.semilattice_neutr_order_axioms
thf(fact_8133_gcd__is__Max__divisors__nat,axiom,
! [N2: nat,M: nat] :
( ( ord_less @ nat @ ( zero_zero @ nat ) @ N2 )
=> ( ( gcd_gcd @ nat @ M @ N2 )
= ( lattic643756798349783984er_Max @ nat
@ ( collect @ nat
@ ^ [D5: nat] :
( ( dvd_dvd @ nat @ D5 @ M )
& ( dvd_dvd @ nat @ D5 @ N2 ) ) ) ) ) ) ).
% gcd_is_Max_divisors_nat
thf(fact_8134_gcd__nat_Opelims,axiom,
! [X: nat,Xa2: nat,Y: nat] :
( ( ( gcd_gcd @ nat @ X @ Xa2 )
= Y )
=> ( ( accp @ ( product_prod @ nat @ nat ) @ gcd_nat_rel @ ( product_Pair @ nat @ nat @ X @ Xa2 ) )
=> ~ ( ( ( ( Xa2
= ( zero_zero @ nat ) )
=> ( Y = X ) )
& ( ( Xa2
!= ( zero_zero @ nat ) )
=> ( Y
= ( gcd_gcd @ nat @ Xa2 @ ( modulo_modulo @ nat @ X @ Xa2 ) ) ) ) )
=> ~ ( accp @ ( product_prod @ nat @ nat ) @ gcd_nat_rel @ ( product_Pair @ nat @ nat @ X @ Xa2 ) ) ) ) ) ).
% gcd_nat.pelims
thf(fact_8135_Gcd__fin__def,axiom,
! [A: $tType] :
( ( semiring_gcd @ A )
=> ( ( semiring_gcd_Gcd_fin @ A )
= ( bounde2362111253966948842tice_F @ A @ ( gcd_gcd @ A ) @ ( zero_zero @ A ) @ ( one_one @ A ) ) ) ) ).
% Gcd_fin_def
thf(fact_8136_bounded__quasi__semilattice__set_Oinsert__remove,axiom,
! [A: $tType,F2: A > A > A,Top: A,Bot: A,Normalize: A > A,A3: A,A4: set @ A] :
( ( bounde6485984586167503788ce_set @ A @ F2 @ Top @ Bot @ Normalize )
=> ( ( bounde2362111253966948842tice_F @ A @ F2 @ Top @ Bot @ ( insert2 @ A @ A3 @ A4 ) )
= ( F2 @ A3 @ ( bounde2362111253966948842tice_F @ A @ F2 @ Top @ Bot @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ).
% bounded_quasi_semilattice_set.insert_remove
thf(fact_8137_bounded__quasi__semilattice__set_Oremove,axiom,
! [A: $tType,F2: A > A > A,Top: A,Bot: A,Normalize: A > A,A3: A,A4: set @ A] :
( ( bounde6485984586167503788ce_set @ A @ F2 @ Top @ Bot @ Normalize )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( ( bounde2362111253966948842tice_F @ A @ F2 @ Top @ Bot @ A4 )
= ( F2 @ A3 @ ( bounde2362111253966948842tice_F @ A @ F2 @ Top @ Bot @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ A3 @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ).
% bounded_quasi_semilattice_set.remove
thf(fact_8138_bounded__quasi__semilattice__set_Osubset,axiom,
! [A: $tType,F2: A > A > A,Top: A,Bot: A,Normalize: A > A,B3: set @ A,A4: set @ A] :
( ( bounde6485984586167503788ce_set @ A @ F2 @ Top @ Bot @ Normalize )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( F2 @ ( bounde2362111253966948842tice_F @ A @ F2 @ Top @ Bot @ B3 ) @ ( bounde2362111253966948842tice_F @ A @ F2 @ Top @ Bot @ A4 ) )
= ( bounde2362111253966948842tice_F @ A @ F2 @ Top @ Bot @ A4 ) ) ) ) ).
% bounded_quasi_semilattice_set.subset
thf(fact_8139_bounded__quasi__semilattice__set_Oempty,axiom,
! [A: $tType,F2: A > A > A,Top: A,Bot: A,Normalize: A > A] :
( ( bounde6485984586167503788ce_set @ A @ F2 @ Top @ Bot @ Normalize )
=> ( ( bounde2362111253966948842tice_F @ A @ F2 @ Top @ Bot @ ( bot_bot @ ( set @ A ) ) )
= Top ) ) ).
% bounded_quasi_semilattice_set.empty
thf(fact_8140_bounded__quasi__semilattice__set_Oset__eq__fold,axiom,
! [A: $tType,F2: A > A > A,Top: A,Bot: A,Normalize: A > A,Xs: list @ A] :
( ( bounde6485984586167503788ce_set @ A @ F2 @ Top @ Bot @ Normalize )
=> ( ( bounde2362111253966948842tice_F @ A @ F2 @ Top @ Bot @ ( set2 @ A @ Xs ) )
= ( fold @ A @ A @ F2 @ Xs @ Top ) ) ) ).
% bounded_quasi_semilattice_set.set_eq_fold
thf(fact_8141_semilattice__order__set_Osubset__imp,axiom,
! [A: $tType,F2: A > A > A,Less_eq: A > A > $o,Less: A > A > $o,A4: set @ A,B3: set @ A] :
( ( lattic4895041142388067077er_set @ A @ F2 @ Less_eq @ Less )
=> ( ( ord_less_eq @ ( set @ A ) @ A4 @ B3 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( Less_eq @ ( lattic1715443433743089157tice_F @ A @ F2 @ B3 ) @ ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) ) ) ) ) ) ).
% semilattice_order_set.subset_imp
thf(fact_8142_map__tailrec__rev_Opelims,axiom,
! [A: $tType,B: $tType,X: A > B,Xa2: list @ A,Xb: list @ B,Y: list @ B] :
( ( ( map_tailrec_rev @ A @ B @ X @ Xa2 @ Xb )
= Y )
=> ( ( accp @ ( product_prod @ ( A > B ) @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) ) @ ( map_tailrec_rev_rel @ A @ B ) @ ( product_Pair @ ( A > B ) @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ X @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ Xa2 @ Xb ) ) )
=> ( ( ( Xa2
= ( nil @ A ) )
=> ( ( Y = Xb )
=> ~ ( accp @ ( product_prod @ ( A > B ) @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) ) @ ( map_tailrec_rev_rel @ A @ B ) @ ( product_Pair @ ( A > B ) @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ X @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ ( nil @ A ) @ Xb ) ) ) ) )
=> ~ ! [A7: A,As2: list @ A] :
( ( Xa2
= ( cons @ A @ A7 @ As2 ) )
=> ( ( Y
= ( map_tailrec_rev @ A @ B @ X @ As2 @ ( cons @ B @ ( X @ A7 ) @ Xb ) ) )
=> ~ ( accp @ ( product_prod @ ( A > B ) @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) ) @ ( map_tailrec_rev_rel @ A @ B ) @ ( product_Pair @ ( A > B ) @ ( product_prod @ ( list @ A ) @ ( list @ B ) ) @ X @ ( product_Pair @ ( list @ A ) @ ( list @ B ) @ ( cons @ A @ A7 @ As2 ) @ Xb ) ) ) ) ) ) ) ) ).
% map_tailrec_rev.pelims
thf(fact_8143_Max__def,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( lattic643756798349783984er_Max @ A )
= ( lattic1715443433743089157tice_F @ A @ ( ord_max @ A ) ) ) ) ).
% Max_def
thf(fact_8144_semilattice__order__set_OcoboundedI,axiom,
! [A: $tType,F2: A > A > A,Less_eq: A > A > $o,Less: A > A > $o,A4: set @ A,A3: A] :
( ( lattic4895041142388067077er_set @ A @ F2 @ Less_eq @ Less )
=> ( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ A3 @ A4 )
=> ( Less_eq @ ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) @ A3 ) ) ) ) ).
% semilattice_order_set.coboundedI
thf(fact_8145_Inf__fin__def,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ( ( lattic7752659483105999362nf_fin @ A )
= ( lattic1715443433743089157tice_F @ A @ ( inf_inf @ A ) ) ) ) ).
% Inf_fin_def
thf(fact_8146_semilattice__set_OF_Ocong,axiom,
! [A: $tType] :
( ( lattic1715443433743089157tice_F @ A )
= ( lattic1715443433743089157tice_F @ A ) ) ).
% semilattice_set.F.cong
thf(fact_8147_Min__def,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( ( lattic643756798350308766er_Min @ A )
= ( lattic1715443433743089157tice_F @ A @ ( ord_min @ A ) ) ) ) ).
% Min_def
thf(fact_8148_Sup__fin__def,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ( ( lattic5882676163264333800up_fin @ A )
= ( lattic1715443433743089157tice_F @ A @ ( sup_sup @ A ) ) ) ) ).
% Sup_fin_def
thf(fact_8149_semilattice__order__set_Obounded__iff,axiom,
! [A: $tType,F2: A > A > A,Less_eq: A > A > $o,Less: A > A > $o,A4: set @ A,X: A] :
( ( lattic4895041142388067077er_set @ A @ F2 @ Less_eq @ Less )
=> ( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( Less_eq @ X @ ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) )
= ( ! [X2: A] :
( ( member2 @ A @ X2 @ A4 )
=> ( Less_eq @ X @ X2 ) ) ) ) ) ) ) ).
% semilattice_order_set.bounded_iff
thf(fact_8150_semilattice__order__set_OboundedI,axiom,
! [A: $tType,F2: A > A > A,Less_eq: A > A > $o,Less: A > A > $o,A4: set @ A,X: A] :
( ( lattic4895041142388067077er_set @ A @ F2 @ Less_eq @ Less )
=> ( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [A7: A] :
( ( member2 @ A @ A7 @ A4 )
=> ( Less_eq @ X @ A7 ) )
=> ( Less_eq @ X @ ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) ) ) ) ) ) ).
% semilattice_order_set.boundedI
thf(fact_8151_semilattice__order__set_OboundedE,axiom,
! [A: $tType,F2: A > A > A,Less_eq: A > A > $o,Less: A > A > $o,A4: set @ A,X: A] :
( ( lattic4895041142388067077er_set @ A @ F2 @ Less_eq @ Less )
=> ( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( Less_eq @ X @ ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) )
=> ! [A15: A] :
( ( member2 @ A @ A15 @ A4 )
=> ( Less_eq @ X @ A15 ) ) ) ) ) ) ).
% semilattice_order_set.boundedE
thf(fact_8152_semilattice__set_Oeq__fold_H,axiom,
! [A: $tType,F2: A > A > A,A4: set @ A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ A4 )
= ( the2 @ A
@ ( finite_fold @ A @ ( option @ A )
@ ^ [X2: A,Y2: option @ A] : ( some @ A @ ( case_option @ A @ A @ X2 @ ( F2 @ X2 ) @ Y2 ) )
@ ( none @ A )
@ A4 ) ) ) ) ).
% semilattice_set.eq_fold'
thf(fact_8153_semilattice__set_Oremove,axiom,
! [A: $tType,F2: A > A > A,A4: set @ A,X: A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ A4 )
= X ) )
& ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ A4 )
= ( F2 @ X @ ( lattic1715443433743089157tice_F @ A @ F2 @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ) ).
% semilattice_set.remove
thf(fact_8154_semilattice__set_Oin__idem,axiom,
! [A: $tType,F2: A > A > A,A4: set @ A,X: A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( member2 @ A @ X @ A4 )
=> ( ( F2 @ X @ ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) )
= ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) ) ) ) ) ).
% semilattice_set.in_idem
thf(fact_8155_Max_Osemilattice__set__axioms,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( lattic149705377957585745ce_set @ A @ ( ord_max @ A ) ) ) ).
% Max.semilattice_set_axioms
thf(fact_8156_Sup__fin_Osemilattice__set__axioms,axiom,
! [A: $tType] :
( ( semilattice_sup @ A )
=> ( lattic149705377957585745ce_set @ A @ ( sup_sup @ A ) ) ) ).
% Sup_fin.semilattice_set_axioms
thf(fact_8157_Min_Osemilattice__set__axioms,axiom,
! [A: $tType] :
( ( linorder @ A )
=> ( lattic149705377957585745ce_set @ A @ ( ord_min @ A ) ) ) ).
% Min.semilattice_set_axioms
thf(fact_8158_Inf__fin_Osemilattice__set__axioms,axiom,
! [A: $tType] :
( ( semilattice_inf @ A )
=> ( lattic149705377957585745ce_set @ A @ ( inf_inf @ A ) ) ) ).
% Inf_fin.semilattice_set_axioms
thf(fact_8159_semilattice__order__set_Oaxioms_I2_J,axiom,
! [A: $tType,F2: A > A > A,Less_eq: A > A > $o,Less: A > A > $o] :
( ( lattic4895041142388067077er_set @ A @ F2 @ Less_eq @ Less )
=> ( lattic149705377957585745ce_set @ A @ F2 ) ) ).
% semilattice_order_set.axioms(2)
thf(fact_8160_semilattice__set_Osingleton,axiom,
! [A: $tType,F2: A > A > A,X: A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= X ) ) ).
% semilattice_set.singleton
thf(fact_8161_semilattice__set_Ohom__commute,axiom,
! [A: $tType,F2: A > A > A,H2: A > A,N7: set @ A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ! [X5: A,Y4: A] :
( ( H2 @ ( F2 @ X5 @ Y4 ) )
= ( F2 @ ( H2 @ X5 ) @ ( H2 @ Y4 ) ) )
=> ( ( finite_finite @ A @ N7 )
=> ( ( N7
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( H2 @ ( lattic1715443433743089157tice_F @ A @ F2 @ N7 ) )
= ( lattic1715443433743089157tice_F @ A @ F2 @ ( image2 @ A @ A @ H2 @ N7 ) ) ) ) ) ) ) ).
% semilattice_set.hom_commute
thf(fact_8162_semilattice__set_Osubset,axiom,
! [A: $tType,F2: A > A > A,A4: set @ A,B3: set @ A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( F2 @ ( lattic1715443433743089157tice_F @ A @ F2 @ B3 ) @ ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) )
= ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) ) ) ) ) ) ).
% semilattice_set.subset
thf(fact_8163_semilattice__set_Oclosed,axiom,
! [A: $tType,F2: A > A > A,A4: set @ A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ! [X5: A,Y4: A] : ( member2 @ A @ ( F2 @ X5 @ Y4 ) @ ( insert2 @ A @ X5 @ ( insert2 @ A @ Y4 @ ( bot_bot @ ( set @ A ) ) ) ) )
=> ( member2 @ A @ ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) @ A4 ) ) ) ) ) ).
% semilattice_set.closed
thf(fact_8164_semilattice__set_Oinsert,axiom,
! [A: $tType,F2: A > A > A,A4: set @ A,X: A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ ( insert2 @ A @ X @ A4 ) )
= ( F2 @ X @ ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) ) ) ) ) ) ).
% semilattice_set.insert
thf(fact_8165_semilattice__set_Oinsert__not__elem,axiom,
! [A: $tType,F2: A > A > A,A4: set @ A,X: A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( finite_finite @ A @ A4 )
=> ( ~ ( member2 @ A @ X @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ ( insert2 @ A @ X @ A4 ) )
= ( F2 @ X @ ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) ) ) ) ) ) ) ).
% semilattice_set.insert_not_elem
thf(fact_8166_semilattice__set_Ounion,axiom,
! [A: $tType,F2: A > A > A,A4: set @ A,B3: set @ A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( A4
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( finite_finite @ A @ B3 )
=> ( ( B3
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ ( sup_sup @ ( set @ A ) @ A4 @ B3 ) )
= ( F2 @ ( lattic1715443433743089157tice_F @ A @ F2 @ A4 ) @ ( lattic1715443433743089157tice_F @ A @ F2 @ B3 ) ) ) ) ) ) ) ) ).
% semilattice_set.union
thf(fact_8167_semilattice__set_Oeq__fold,axiom,
! [A: $tType,F2: A > A > A,A4: set @ A,X: A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ ( insert2 @ A @ X @ A4 ) )
= ( finite_fold @ A @ A @ F2 @ X @ A4 ) ) ) ) ).
% semilattice_set.eq_fold
thf(fact_8168_semilattice__set_Oset__eq__fold,axiom,
! [A: $tType,F2: A > A > A,X: A,Xs: list @ A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ ( set2 @ A @ ( cons @ A @ X @ Xs ) ) )
= ( fold @ A @ A @ F2 @ Xs @ X ) ) ) ).
% semilattice_set.set_eq_fold
thf(fact_8169_semilattice__set_Oinfinite,axiom,
! [A: $tType,F2: A > A > A,A4: set @ A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ~ ( finite_finite @ A @ A4 )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ A4 )
= ( the2 @ A @ ( none @ A ) ) ) ) ) ).
% semilattice_set.infinite
thf(fact_8170_semilattice__set_Oinsert__remove,axiom,
! [A: $tType,F2: A > A > A,A4: set @ A,X: A] :
( ( lattic149705377957585745ce_set @ A @ F2 )
=> ( ( finite_finite @ A @ A4 )
=> ( ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ ( insert2 @ A @ X @ A4 ) )
= X ) )
& ( ( ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) )
!= ( bot_bot @ ( set @ A ) ) )
=> ( ( lattic1715443433743089157tice_F @ A @ F2 @ ( insert2 @ A @ X @ A4 ) )
= ( F2 @ X @ ( lattic1715443433743089157tice_F @ A @ F2 @ ( minus_minus @ ( set @ A ) @ A4 @ ( insert2 @ A @ X @ ( bot_bot @ ( set @ A ) ) ) ) ) ) ) ) ) ) ) ).
% semilattice_set.insert_remove
thf(fact_8171_cr__int__def,axiom,
( cr_int
= ( ^ [X2: product_prod @ nat @ nat] :
( ^ [Y5: int,Z3: int] : ( Y5 = Z3 )
@ ( abs_Integ @ X2 ) ) ) ) ).
% cr_int_def
thf(fact_8172_antisymp__antisym__eq,axiom,
! [A: $tType,R2: set @ ( product_prod @ A @ A )] :
( ( antisymp @ A
@ ^ [X2: A,Y2: A] : ( member2 @ ( product_prod @ A @ A ) @ ( product_Pair @ A @ A @ X2 @ Y2 ) @ R2 ) )
= ( antisym @ A @ R2 ) ) ).
% antisymp_antisym_eq
thf(fact_8173_antisym__bot,axiom,
! [A: $tType] : ( antisymp @ A @ ( bot_bot @ ( A > A > $o ) ) ) ).
% antisym_bot
thf(fact_8174_int_Opcr__cr__eq,axiom,
pcr_int = cr_int ).
% int.pcr_cr_eq
thf(fact_8175_Quotient__int,axiom,
quotient @ ( product_prod @ nat @ nat ) @ int @ intrel @ abs_Integ @ rep_Integ @ cr_int ).
% Quotient_int
thf(fact_8176_pair__in__swap__image,axiom,
! [A: $tType,B: $tType,Y: A,X: B,A4: set @ ( product_prod @ B @ A )] :
( ( member2 @ ( product_prod @ A @ B ) @ ( product_Pair @ A @ B @ Y @ X ) @ ( image2 @ ( product_prod @ B @ A ) @ ( product_prod @ A @ B ) @ ( product_swap @ B @ A ) @ A4 ) )
= ( member2 @ ( product_prod @ B @ A ) @ ( product_Pair @ B @ A @ X @ Y ) @ A4 ) ) ).
% pair_in_swap_image
thf(fact_8177_swap__simp,axiom,
! [A: $tType,B: $tType,X: B,Y: A] :
( ( product_swap @ B @ A @ ( product_Pair @ B @ A @ X @ Y ) )
= ( product_Pair @ A @ B @ Y @ X ) ) ).
% swap_simp
thf(fact_8178_list_OQuotient,axiom,
! [B: $tType,A: $tType,R: A > A > $o,Abs: A > B,Rep: B > A,T4: A > B > $o] :
( ( quotient @ A @ B @ R @ Abs @ Rep @ T4 )
=> ( quotient @ ( list @ A ) @ ( list @ B ) @ ( list_all2 @ A @ A @ R ) @ ( map @ A @ B @ Abs ) @ ( map @ B @ A @ Rep ) @ ( list_all2 @ A @ B @ T4 ) ) ) ).
% list.Quotient
thf(fact_8179_prod_Oswap__def,axiom,
! [B: $tType,A: $tType] :
( ( product_swap @ A @ B )
= ( ^ [P6: product_prod @ A @ B] : ( product_Pair @ B @ A @ ( product_snd @ A @ B @ P6 ) @ ( product_fst @ A @ B @ P6 ) ) ) ) ).
% prod.swap_def
thf(fact_8180_inv__into__Field__embed,axiom,
! [B: $tType,A: $tType,R2: set @ ( product_prod @ A @ A ),R6: set @ ( product_prod @ B @ B ),F2: A > B] :
( ( order_well_order_on @ A @ ( field2 @ A @ R2 ) @ R2 )
=> ( ( bNF_Wellorder_embed @ A @ B @ R2 @ R6 @ F2 )
=> ( ( ord_less_eq @ ( set @ B ) @ ( field2 @ B @ R6 ) @ ( image2 @ A @ B @ F2 @ ( field2 @ A @ R2 ) ) )
=> ( bNF_Wellorder_embed @ B @ A @ R6 @ R2 @ ( hilbert_inv_into @ A @ B @ ( field2 @ A @ R2 ) @ F2 ) ) ) ) ) ).
% inv_into_Field_embed
thf(fact_8181_bind__singleton__conv__image,axiom,
! [A: $tType,B: $tType,A4: set @ B,F2: B > A] :
( ( bind2 @ B @ A @ A4
@ ^ [X2: B] : ( insert2 @ A @ ( F2 @ X2 ) @ ( bot_bot @ ( set @ A ) ) ) )
= ( image2 @ B @ A @ F2 @ A4 ) ) ).
% bind_singleton_conv_image
thf(fact_8182_empty__bind,axiom,
! [B: $tType,A: $tType,F2: B > ( set @ A )] :
( ( bind2 @ B @ A @ ( bot_bot @ ( set @ B ) ) @ F2 )
= ( bot_bot @ ( set @ A ) ) ) ).
% empty_bind
thf(fact_8183_inv__into__image__cancel,axiom,
! [B: $tType,A: $tType,F2: A > B,A4: set @ A,S3: set @ A] :
( ( inj_on @ A @ B @ F2 @ A4 )
=> ( ( ord_less_eq @ ( set @ A ) @ S3 @ A4 )
=> ( ( image2 @ B @ A @ ( hilbert_inv_into @ A @ B @ A4 @ F2 ) @ ( image2 @ A @ B @ F2 @ S3 ) )
= S3 ) ) ) ).
% inv_into_image_cancel
thf(fact_8184_bij__betw__inv__into__subset,axiom,
! [B: $tType,A: $tType,F2: A > B,A4: set @ A,A16: set @ B,B3: set @ A,B14: set @ B] :
( ( bij_betw @ A @ B @ F2 @ A4 @ A16 )
=> ( ( ord_less_eq @ ( set @ A ) @ B3 @ A4 )
=> ( ( ( image2 @ A @ B @ F2 @ B3 )
= B14 )
=> ( bij_betw @ B @ A @ ( hilbert_inv_into @ A @ B @ A4 @ F2 ) @ B14 @ B3 ) ) ) ) ).
% bij_betw_inv_into_subset
thf(fact_8185_image__inv__into__cancel,axiom,
! [B: $tType,A: $tType,F2: B > A,A4: set @ B,A16: set @ A,B14: set @ A] :
( ( ( image2 @ B @ A @ F2 @ A4 )
= A16 )
=> ( ( ord_less_eq @ ( set @ A ) @ B14 @ A16 )
=> ( ( image2 @ B @ A @ F2 @ ( image2 @ A @ B @ ( hilbert_inv_into @ B @ A @ A4 @ F2 ) @ B14 ) )
= B14 ) ) ) ).
% image_inv_into_cancel
thf(fact_8186_inj__on__inv__into,axiom,
! [B: $tType,A: $tType,B3: set @ A,F2: B > A,A4: set @ B] :
( ( ord_less_eq @ ( set @ A ) @ B3 @ ( image2 @ B @ A @ F2 @ A4 ) )
=> ( inj_on @ A @ B @ ( hilbert_inv_into @ B @ A @ A4 @ F2 ) @ B3 ) ) ).
% inj_on_inv_into
% Type constructors (623)
thf(tcon_fun___Countable__Complete__Lattices_Ocountable__complete__distrib__lattice,axiom,
! [A10: $tType,A29: $tType] :
( ( comple592849572758109894attice @ A29 )
=> ( counta4013691401010221786attice @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Conditionally__Complete__Lattices_Oconditionally__complete__lattice,axiom,
! [A10: $tType,A29: $tType] :
( ( comple6319245703460814977attice @ A29 )
=> ( condit1219197933456340205attice @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Countable__Complete__Lattices_Ocountable__complete__lattice,axiom,
! [A10: $tType,A29: $tType] :
( ( counta3822494911875563373attice @ A29 )
=> ( counta3822494911875563373attice @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Complete__Lattices_Ocomplete__distrib__lattice,axiom,
! [A10: $tType,A29: $tType] :
( ( comple592849572758109894attice @ A29 )
=> ( comple592849572758109894attice @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Lattices_Obounded__semilattice__sup__bot,axiom,
! [A10: $tType,A29: $tType] :
( ( bounded_lattice @ A29 )
=> ( bounde4967611905675639751up_bot @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Lattices_Obounded__semilattice__inf__top,axiom,
! [A10: $tType,A29: $tType] :
( ( bounded_lattice @ A29 )
=> ( bounde4346867609351753570nf_top @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Complete__Lattices_Ocomplete__lattice,axiom,
! [A10: $tType,A29: $tType] :
( ( comple6319245703460814977attice @ A29 )
=> ( comple6319245703460814977attice @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Boolean__Algebras_Oboolean__algebra,axiom,
! [A10: $tType,A29: $tType] :
( ( boolea8198339166811842893lgebra @ A29 )
=> ( boolea8198339166811842893lgebra @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Lattices_Obounded__lattice__top,axiom,
! [A10: $tType,A29: $tType] :
( ( bounded_lattice @ A29 )
=> ( bounded_lattice_top @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Lattices_Obounded__lattice__bot,axiom,
! [A10: $tType,A29: $tType] :
( ( bounded_lattice @ A29 )
=> ( bounded_lattice_bot @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Complete__Partial__Order_Occpo,axiom,
! [A10: $tType,A29: $tType] :
( ( comple6319245703460814977attice @ A29 )
=> ( comple9053668089753744459l_ccpo @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Lattices_Osemilattice__sup,axiom,
! [A10: $tType,A29: $tType] :
( ( semilattice_sup @ A29 )
=> ( semilattice_sup @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Lattices_Osemilattice__inf,axiom,
! [A10: $tType,A29: $tType] :
( ( semilattice_inf @ A29 )
=> ( semilattice_inf @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Lattices_Odistrib__lattice,axiom,
! [A10: $tType,A29: $tType] :
( ( distrib_lattice @ A29 )
=> ( distrib_lattice @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Lattices_Obounded__lattice,axiom,
! [A10: $tType,A29: $tType] :
( ( bounded_lattice @ A29 )
=> ( bounded_lattice @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Orderings_Oorder__top,axiom,
! [A10: $tType,A29: $tType] :
( ( order_top @ A29 )
=> ( order_top @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Orderings_Oorder__bot,axiom,
! [A10: $tType,A29: $tType] :
( ( order_bot @ A29 )
=> ( order_bot @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Orderings_Opreorder,axiom,
! [A10: $tType,A29: $tType] :
( ( preorder @ A29 )
=> ( preorder @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Lattices_Olattice,axiom,
! [A10: $tType,A29: $tType] :
( ( lattice @ A29 )
=> ( lattice @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Orderings_Oorder,axiom,
! [A10: $tType,A29: $tType] :
( ( order @ A29 )
=> ( order @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Orderings_Oord,axiom,
! [A10: $tType,A29: $tType] :
( ( ord @ A29 )
=> ( ord @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Orderings_Obot,axiom,
! [A10: $tType,A29: $tType] :
( ( bot @ A29 )
=> ( bot @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Groups_Ouminus,axiom,
! [A10: $tType,A29: $tType] :
( ( uminus @ A29 )
=> ( uminus @ ( A10 > A29 ) ) ) ).
thf(tcon_fun___Groups_Ominus,axiom,
! [A10: $tType,A29: $tType] :
( ( minus @ A29 )
=> ( minus @ ( A10 > A29 ) ) ) ).
thf(tcon_Int_Oint___Conditionally__Complete__Lattices_Oconditionally__complete__linorder,axiom,
condit6923001295902523014norder @ int ).
thf(tcon_Int_Oint___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_1,axiom,
condit1219197933456340205attice @ int ).
thf(tcon_Int_Oint___Bit__Operations_Ounique__euclidean__semiring__with__bit__operations,axiom,
bit_un5681908812861735899ations @ int ).
thf(tcon_Int_Oint___Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct,axiom,
semiri1453513574482234551roduct @ int ).
thf(tcon_Int_Oint___Euclidean__Division_Ounique__euclidean__semiring__with__nat,axiom,
euclid5411537665997757685th_nat @ int ).
thf(tcon_Int_Oint___Groups_Oordered__ab__semigroup__monoid__add__imp__le,axiom,
ordere1937475149494474687imp_le @ int ).
thf(tcon_Int_Oint___Euclidean__Division_Ounique__euclidean__semiring,axiom,
euclid3128863361964157862miring @ int ).
thf(tcon_Int_Oint___Euclidean__Division_Oeuclidean__semiring__cancel,axiom,
euclid4440199948858584721cancel @ int ).
thf(tcon_Int_Oint___Divides_Ounique__euclidean__semiring__numeral,axiom,
unique1627219031080169319umeral @ int ).
thf(tcon_Int_Oint___Euclidean__Division_Oeuclidean__ring__cancel,axiom,
euclid8851590272496341667cancel @ int ).
thf(tcon_Int_Oint___Rings_Osemiring__no__zero__divisors__cancel,axiom,
semiri6575147826004484403cancel @ int ).
thf(tcon_Int_Oint___Groups_Ostrict__ordered__ab__semigroup__add,axiom,
strict9044650504122735259up_add @ int ).
thf(tcon_Int_Oint___Groups_Oordered__cancel__ab__semigroup__add,axiom,
ordere580206878836729694up_add @ int ).
thf(tcon_Int_Oint___Groups_Oordered__ab__semigroup__add__imp__le,axiom,
ordere2412721322843649153imp_le @ int ).
thf(tcon_Int_Oint___Bit__Operations_Osemiring__bit__operations,axiom,
bit_se359711467146920520ations @ int ).
thf(tcon_Int_Oint___Rings_Olinordered__comm__semiring__strict,axiom,
linord2810124833399127020strict @ int ).
thf(tcon_Int_Oint___Groups_Ostrict__ordered__comm__monoid__add,axiom,
strict7427464778891057005id_add @ int ).
thf(tcon_Int_Oint___Groups_Oordered__cancel__comm__monoid__add,axiom,
ordere8940638589300402666id_add @ int ).
thf(tcon_Int_Oint___Euclidean__Division_Oeuclidean__semiring,axiom,
euclid3725896446679973847miring @ int ).
thf(tcon_Int_Oint___Topological__Spaces_Otopological__space,axiom,
topolo4958980785337419405_space @ int ).
thf(tcon_Int_Oint___Topological__Spaces_Olinorder__topology,axiom,
topolo1944317154257567458pology @ int ).
thf(tcon_Int_Oint___Topological__Spaces_Odiscrete__topology,axiom,
topolo8865339358273720382pology @ int ).
thf(tcon_Int_Oint___Rings_Olinordered__semiring__1__strict,axiom,
linord715952674999750819strict @ int ).
thf(tcon_Int_Oint___Limits_Otopological__comm__monoid__add,axiom,
topolo5987344860129210374id_add @ int ).
thf(tcon_Int_Oint___Groups_Olinordered__ab__semigroup__add,axiom,
linord4140545234300271783up_add @ int ).
thf(tcon_Int_Oint___Bit__Operations_Oring__bit__operations,axiom,
bit_ri3973907225187159222ations @ int ).
thf(tcon_Int_Oint___Topological__Spaces_Oorder__topology,axiom,
topolo2564578578187576103pology @ int ).
thf(tcon_Int_Oint___Rings_Osemiring__1__no__zero__divisors,axiom,
semiri2026040879449505780visors @ int ).
thf(tcon_Int_Oint___Rings_Olinordered__nonzero__semiring,axiom,
linord181362715937106298miring @ int ).
thf(tcon_Int_Oint___Limits_Otopological__semigroup__mult,axiom,
topolo4211221413907600880p_mult @ int ).
thf(tcon_Int_Oint___Rings_Olinordered__semiring__strict,axiom,
linord8928482502909563296strict @ int ).
thf(tcon_Int_Oint___Rings_Osemiring__no__zero__divisors,axiom,
semiri3467727345109120633visors @ int ).
thf(tcon_Int_Oint___Groups_Oordered__ab__semigroup__add,axiom,
ordere6658533253407199908up_add @ int ).
thf(tcon_Int_Oint___Groups_Oordered__ab__group__add__abs,axiom,
ordere166539214618696060dd_abs @ int ).
thf(tcon_Int_Oint___Groups_Oordered__comm__monoid__add,axiom,
ordere6911136660526730532id_add @ int ).
thf(tcon_Int_Oint___Groups_Olinordered__ab__group__add,axiom,
linord5086331880401160121up_add @ int ).
thf(tcon_Int_Oint___Groups_Ocancel__ab__semigroup__add,axiom,
cancel2418104881723323429up_add @ int ).
thf(tcon_Int_Oint___Rings_Oring__1__no__zero__divisors,axiom,
ring_15535105094025558882visors @ int ).
thf(tcon_Int_Oint___Limits_Otopological__monoid__add,axiom,
topolo6943815403480290642id_add @ int ).
thf(tcon_Int_Oint___Groups_Ocancel__comm__monoid__add,axiom,
cancel1802427076303600483id_add @ int ).
thf(tcon_Int_Oint___Rings_Olinordered__ring__strict,axiom,
linord4710134922213307826strict @ int ).
thf(tcon_Int_Oint___Rings_Ocomm__semiring__1__cancel,axiom,
comm_s4317794764714335236cancel @ int ).
thf(tcon_Int_Oint___Bit__Operations_Osemiring__bits,axiom,
bit_semiring_bits @ int ).
thf(tcon_Int_Oint___Topological__Spaces_Ot2__space,axiom,
topological_t2_space @ int ).
thf(tcon_Int_Oint___Topological__Spaces_Ot1__space,axiom,
topological_t1_space @ int ).
thf(tcon_Int_Oint___Rings_Oordered__comm__semiring,axiom,
ordere2520102378445227354miring @ int ).
thf(tcon_Int_Oint___Rings_Olinordered__semiring__1,axiom,
linord6961819062388156250ring_1 @ int ).
thf(tcon_Int_Oint___Groups_Oordered__ab__group__add,axiom,
ordered_ab_group_add @ int ).
thf(tcon_Int_Oint___Groups_Ocancel__semigroup__add,axiom,
cancel_semigroup_add @ int ).
thf(tcon_Int_Oint___Rings_Olinordered__semiring,axiom,
linordered_semiring @ int ).
thf(tcon_Int_Oint___Rings_Oordered__semiring__0,axiom,
ordered_semiring_0 @ int ).
thf(tcon_Int_Oint___Rings_Olinordered__semidom,axiom,
linordered_semidom @ int ).
thf(tcon_Int_Oint___Lattices_Osemilattice__sup_2,axiom,
semilattice_sup @ int ).
thf(tcon_Int_Oint___Lattices_Osemilattice__inf_3,axiom,
semilattice_inf @ int ).
thf(tcon_Int_Oint___Lattices_Odistrib__lattice_4,axiom,
distrib_lattice @ int ).
thf(tcon_Int_Oint___Groups_Oab__semigroup__mult,axiom,
ab_semigroup_mult @ int ).
thf(tcon_Int_Oint___Rings_Osemiring__1__cancel,axiom,
semiring_1_cancel @ int ).
thf(tcon_Int_Oint___Rings_Oalgebraic__semidom,axiom,
algebraic_semidom @ int ).
thf(tcon_Int_Oint___Groups_Ocomm__monoid__mult,axiom,
comm_monoid_mult @ int ).
thf(tcon_Int_Oint___Groups_Oab__semigroup__add,axiom,
ab_semigroup_add @ int ).
thf(tcon_Int_Oint___Rings_Oordered__semiring,axiom,
ordered_semiring @ int ).
thf(tcon_Int_Oint___Rings_Oordered__ring__abs,axiom,
ordered_ring_abs @ int ).
thf(tcon_Int_Oint___Parity_Osemiring__parity,axiom,
semiring_parity @ int ).
thf(tcon_Int_Oint___Groups_Ocomm__monoid__add,axiom,
comm_monoid_add @ int ).
thf(tcon_Int_Oint___Rings_Osemiring__modulo,axiom,
semiring_modulo @ int ).
thf(tcon_Int_Oint___Rings_Olinordered__ring,axiom,
linordered_ring @ int ).
thf(tcon_Int_Oint___Rings_Olinordered__idom,axiom,
linordered_idom @ int ).
thf(tcon_Int_Oint___Rings_Ocomm__semiring__1,axiom,
comm_semiring_1 @ int ).
thf(tcon_Int_Oint___Rings_Ocomm__semiring__0,axiom,
comm_semiring_0 @ int ).
thf(tcon_Int_Oint___Groups_Osemigroup__mult,axiom,
semigroup_mult @ int ).
thf(tcon_Int_Oint___Rings_Osemidom__modulo,axiom,
semidom_modulo @ int ).
thf(tcon_Int_Oint___Rings_Osemidom__divide,axiom,
semidom_divide @ int ).
thf(tcon_Int_Oint___Num_Osemiring__numeral,axiom,
semiring_numeral @ int ).
thf(tcon_Int_Oint___Groups_Osemigroup__add,axiom,
semigroup_add @ int ).
thf(tcon_Int_Oint___Rings_Ozero__less__one,axiom,
zero_less_one @ int ).
thf(tcon_Int_Oint___Rings_Ocomm__semiring,axiom,
comm_semiring @ int ).
thf(tcon_Int_Oint___Nat_Osemiring__char__0,axiom,
semiring_char_0 @ int ).
thf(tcon_Int_Oint___Groups_Oab__group__add,axiom,
ab_group_add @ int ).
thf(tcon_Int_Oint___Rings_Ozero__neq__one,axiom,
zero_neq_one @ int ).
thf(tcon_Int_Oint___Rings_Oordered__ring,axiom,
ordered_ring @ int ).
thf(tcon_Int_Oint___Rings_Oidom__abs__sgn,axiom,
idom_abs_sgn @ int ).
thf(tcon_Int_Oint___Parity_Oring__parity,axiom,
ring_parity @ int ).
thf(tcon_Int_Oint___Orderings_Opreorder_5,axiom,
preorder @ int ).
thf(tcon_Int_Oint___Orderings_Olinorder,axiom,
linorder @ int ).
thf(tcon_Int_Oint___Groups_Omonoid__mult,axiom,
monoid_mult @ int ).
thf(tcon_Int_Oint___Rings_Oidom__modulo,axiom,
idom_modulo @ int ).
thf(tcon_Int_Oint___Rings_Oidom__divide,axiom,
idom_divide @ int ).
thf(tcon_Int_Oint___Rings_Ocomm__ring__1,axiom,
comm_ring_1 @ int ).
thf(tcon_Int_Oint___Groups_Omonoid__add,axiom,
monoid_add @ int ).
thf(tcon_Int_Oint___Rings_Osemiring__1,axiom,
semiring_1 @ int ).
thf(tcon_Int_Oint___Rings_Osemiring__0,axiom,
semiring_0 @ int ).
thf(tcon_Int_Oint___Orderings_Ono__top,axiom,
no_top @ int ).
thf(tcon_Int_Oint___Orderings_Ono__bot,axiom,
no_bot @ int ).
thf(tcon_Int_Oint___Lattices_Olattice_6,axiom,
lattice @ int ).
thf(tcon_Int_Oint___Groups_Ogroup__add,axiom,
group_add @ int ).
thf(tcon_Int_Oint___GCD_Osemiring__gcd,axiom,
semiring_gcd @ int ).
thf(tcon_Int_Oint___GCD_Osemiring__Gcd,axiom,
semiring_Gcd @ int ).
thf(tcon_Int_Oint___Rings_Omult__zero,axiom,
mult_zero @ int ).
thf(tcon_Int_Oint___Rings_Ocomm__ring,axiom,
comm_ring @ int ).
thf(tcon_Int_Oint___Orderings_Oorder_7,axiom,
order @ int ).
thf(tcon_Int_Oint___Num_Oneg__numeral,axiom,
neg_numeral @ int ).
thf(tcon_Int_Oint___Nat_Oring__char__0,axiom,
ring_char_0 @ int ).
thf(tcon_Int_Oint___Rings_Osemiring,axiom,
semiring @ int ).
thf(tcon_Int_Oint___Rings_Osemidom,axiom,
semidom @ int ).
thf(tcon_Int_Oint___Orderings_Oord_8,axiom,
ord @ int ).
thf(tcon_Int_Oint___Groups_Ouminus_9,axiom,
uminus @ int ).
thf(tcon_Int_Oint___Rings_Oring__1,axiom,
ring_1 @ int ).
thf(tcon_Int_Oint___Rings_Oabs__if,axiom,
abs_if @ int ).
thf(tcon_Int_Oint___Groups_Ominus_10,axiom,
minus @ int ).
thf(tcon_Int_Oint___Power_Opower,axiom,
power @ int ).
thf(tcon_Int_Oint___Num_Onumeral,axiom,
numeral @ int ).
thf(tcon_Int_Oint___Groups_Ozero,axiom,
zero @ int ).
thf(tcon_Int_Oint___Groups_Oplus,axiom,
plus @ int ).
thf(tcon_Int_Oint___Rings_Oring,axiom,
ring @ int ).
thf(tcon_Int_Oint___Rings_Oidom,axiom,
idom @ int ).
thf(tcon_Int_Oint___Groups_Oone,axiom,
one @ int ).
thf(tcon_Int_Oint___Rings_Odvd,axiom,
dvd @ int ).
thf(tcon_Nat_Onat___Conditionally__Complete__Lattices_Oconditionally__complete__linorder_11,axiom,
condit6923001295902523014norder @ nat ).
thf(tcon_Nat_Onat___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_12,axiom,
condit1219197933456340205attice @ nat ).
thf(tcon_Nat_Onat___Bit__Operations_Ounique__euclidean__semiring__with__bit__operations_13,axiom,
bit_un5681908812861735899ations @ nat ).
thf(tcon_Nat_Onat___Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct_14,axiom,
semiri1453513574482234551roduct @ nat ).
thf(tcon_Nat_Onat___Euclidean__Division_Ounique__euclidean__semiring__with__nat_15,axiom,
euclid5411537665997757685th_nat @ nat ).
thf(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__monoid__add__imp__le_16,axiom,
ordere1937475149494474687imp_le @ nat ).
thf(tcon_Nat_Onat___Euclidean__Division_Ounique__euclidean__semiring_17,axiom,
euclid3128863361964157862miring @ nat ).
thf(tcon_Nat_Onat___Euclidean__Division_Oeuclidean__semiring__cancel_18,axiom,
euclid4440199948858584721cancel @ nat ).
thf(tcon_Nat_Onat___Divides_Ounique__euclidean__semiring__numeral_19,axiom,
unique1627219031080169319umeral @ nat ).
thf(tcon_Nat_Onat___Rings_Osemiring__no__zero__divisors__cancel_20,axiom,
semiri6575147826004484403cancel @ nat ).
thf(tcon_Nat_Onat___Groups_Ostrict__ordered__ab__semigroup__add_21,axiom,
strict9044650504122735259up_add @ nat ).
thf(tcon_Nat_Onat___Groups_Oordered__cancel__comm__monoid__diff,axiom,
ordere1170586879665033532d_diff @ nat ).
thf(tcon_Nat_Onat___Groups_Oordered__cancel__ab__semigroup__add_22,axiom,
ordere580206878836729694up_add @ nat ).
thf(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__add__imp__le_23,axiom,
ordere2412721322843649153imp_le @ nat ).
thf(tcon_Nat_Onat___Bit__Operations_Osemiring__bit__operations_24,axiom,
bit_se359711467146920520ations @ nat ).
thf(tcon_Nat_Onat___Rings_Olinordered__comm__semiring__strict_25,axiom,
linord2810124833399127020strict @ nat ).
thf(tcon_Nat_Onat___Groups_Ostrict__ordered__comm__monoid__add_26,axiom,
strict7427464778891057005id_add @ nat ).
thf(tcon_Nat_Onat___Groups_Oordered__cancel__comm__monoid__add_27,axiom,
ordere8940638589300402666id_add @ nat ).
thf(tcon_Nat_Onat___Groups_Ocanonically__ordered__monoid__add,axiom,
canoni5634975068530333245id_add @ nat ).
thf(tcon_Nat_Onat___Euclidean__Division_Oeuclidean__semiring_28,axiom,
euclid3725896446679973847miring @ nat ).
thf(tcon_Nat_Onat___Topological__Spaces_Otopological__space_29,axiom,
topolo4958980785337419405_space @ nat ).
thf(tcon_Nat_Onat___Topological__Spaces_Olinorder__topology_30,axiom,
topolo1944317154257567458pology @ nat ).
thf(tcon_Nat_Onat___Topological__Spaces_Odiscrete__topology_31,axiom,
topolo8865339358273720382pology @ nat ).
thf(tcon_Nat_Onat___Limits_Otopological__comm__monoid__add_32,axiom,
topolo5987344860129210374id_add @ nat ).
thf(tcon_Nat_Onat___Groups_Olinordered__ab__semigroup__add_33,axiom,
linord4140545234300271783up_add @ nat ).
thf(tcon_Nat_Onat___Topological__Spaces_Oorder__topology_34,axiom,
topolo2564578578187576103pology @ nat ).
thf(tcon_Nat_Onat___Rings_Osemiring__1__no__zero__divisors_35,axiom,
semiri2026040879449505780visors @ nat ).
thf(tcon_Nat_Onat___Rings_Olinordered__nonzero__semiring_36,axiom,
linord181362715937106298miring @ nat ).
thf(tcon_Nat_Onat___Limits_Otopological__semigroup__mult_37,axiom,
topolo4211221413907600880p_mult @ nat ).
thf(tcon_Nat_Onat___Rings_Olinordered__semiring__strict_38,axiom,
linord8928482502909563296strict @ nat ).
thf(tcon_Nat_Onat___Rings_Osemiring__no__zero__divisors_39,axiom,
semiri3467727345109120633visors @ nat ).
thf(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__add_40,axiom,
ordere6658533253407199908up_add @ nat ).
thf(tcon_Nat_Onat___Groups_Oordered__comm__monoid__add_41,axiom,
ordere6911136660526730532id_add @ nat ).
thf(tcon_Nat_Onat___Groups_Ocancel__ab__semigroup__add_42,axiom,
cancel2418104881723323429up_add @ nat ).
thf(tcon_Nat_Onat___Limits_Otopological__monoid__add_43,axiom,
topolo6943815403480290642id_add @ nat ).
thf(tcon_Nat_Onat___Groups_Ocancel__comm__monoid__add_44,axiom,
cancel1802427076303600483id_add @ nat ).
thf(tcon_Nat_Onat___Rings_Ocomm__semiring__1__cancel_45,axiom,
comm_s4317794764714335236cancel @ nat ).
thf(tcon_Nat_Onat___Bit__Operations_Osemiring__bits_46,axiom,
bit_semiring_bits @ nat ).
thf(tcon_Nat_Onat___Topological__Spaces_Ot2__space_47,axiom,
topological_t2_space @ nat ).
thf(tcon_Nat_Onat___Topological__Spaces_Ot1__space_48,axiom,
topological_t1_space @ nat ).
thf(tcon_Nat_Onat___Rings_Oordered__comm__semiring_49,axiom,
ordere2520102378445227354miring @ nat ).
thf(tcon_Nat_Onat___Groups_Ocancel__semigroup__add_50,axiom,
cancel_semigroup_add @ nat ).
thf(tcon_Nat_Onat___Rings_Olinordered__semiring_51,axiom,
linordered_semiring @ nat ).
thf(tcon_Nat_Onat___Rings_Oordered__semiring__0_52,axiom,
ordered_semiring_0 @ nat ).
thf(tcon_Nat_Onat___Rings_Olinordered__semidom_53,axiom,
linordered_semidom @ nat ).
thf(tcon_Nat_Onat___Lattices_Osemilattice__sup_54,axiom,
semilattice_sup @ nat ).
thf(tcon_Nat_Onat___Lattices_Osemilattice__inf_55,axiom,
semilattice_inf @ nat ).
thf(tcon_Nat_Onat___Lattices_Odistrib__lattice_56,axiom,
distrib_lattice @ nat ).
thf(tcon_Nat_Onat___Groups_Oab__semigroup__mult_57,axiom,
ab_semigroup_mult @ nat ).
thf(tcon_Nat_Onat___Rings_Osemiring__1__cancel_58,axiom,
semiring_1_cancel @ nat ).
thf(tcon_Nat_Onat___Rings_Oalgebraic__semidom_59,axiom,
algebraic_semidom @ nat ).
thf(tcon_Nat_Onat___Groups_Ocomm__monoid__mult_60,axiom,
comm_monoid_mult @ nat ).
thf(tcon_Nat_Onat___Groups_Ocomm__monoid__diff,axiom,
comm_monoid_diff @ nat ).
thf(tcon_Nat_Onat___Groups_Oab__semigroup__add_61,axiom,
ab_semigroup_add @ nat ).
thf(tcon_Nat_Onat___Rings_Oordered__semiring_62,axiom,
ordered_semiring @ nat ).
thf(tcon_Nat_Onat___Parity_Osemiring__parity_63,axiom,
semiring_parity @ nat ).
thf(tcon_Nat_Onat___Groups_Ocomm__monoid__add_64,axiom,
comm_monoid_add @ nat ).
thf(tcon_Nat_Onat___Rings_Osemiring__modulo_65,axiom,
semiring_modulo @ nat ).
thf(tcon_Nat_Onat___Rings_Ocomm__semiring__1_66,axiom,
comm_semiring_1 @ nat ).
thf(tcon_Nat_Onat___Rings_Ocomm__semiring__0_67,axiom,
comm_semiring_0 @ nat ).
thf(tcon_Nat_Onat___Groups_Osemigroup__mult_68,axiom,
semigroup_mult @ nat ).
thf(tcon_Nat_Onat___Rings_Osemidom__modulo_69,axiom,
semidom_modulo @ nat ).
thf(tcon_Nat_Onat___Rings_Osemidom__divide_70,axiom,
semidom_divide @ nat ).
thf(tcon_Nat_Onat___Num_Osemiring__numeral_71,axiom,
semiring_numeral @ nat ).
thf(tcon_Nat_Onat___Groups_Osemigroup__add_72,axiom,
semigroup_add @ nat ).
thf(tcon_Nat_Onat___Rings_Ozero__less__one_73,axiom,
zero_less_one @ nat ).
thf(tcon_Nat_Onat___Rings_Ocomm__semiring_74,axiom,
comm_semiring @ nat ).
thf(tcon_Nat_Onat___Orderings_Owellorder,axiom,
wellorder @ nat ).
thf(tcon_Nat_Onat___Orderings_Oorder__bot_75,axiom,
order_bot @ nat ).
thf(tcon_Nat_Onat___Nat_Osemiring__char__0_76,axiom,
semiring_char_0 @ nat ).
thf(tcon_Nat_Onat___Rings_Ozero__neq__one_77,axiom,
zero_neq_one @ nat ).
thf(tcon_Nat_Onat___Orderings_Opreorder_78,axiom,
preorder @ nat ).
thf(tcon_Nat_Onat___Orderings_Olinorder_79,axiom,
linorder @ nat ).
thf(tcon_Nat_Onat___Groups_Omonoid__mult_80,axiom,
monoid_mult @ nat ).
thf(tcon_Nat_Onat___Groups_Omonoid__add_81,axiom,
monoid_add @ nat ).
thf(tcon_Nat_Onat___Rings_Osemiring__1_82,axiom,
semiring_1 @ nat ).
thf(tcon_Nat_Onat___Rings_Osemiring__0_83,axiom,
semiring_0 @ nat ).
thf(tcon_Nat_Onat___Orderings_Ono__top_84,axiom,
no_top @ nat ).
thf(tcon_Nat_Onat___Lattices_Olattice_85,axiom,
lattice @ nat ).
thf(tcon_Nat_Onat___GCD_Osemiring__gcd_86,axiom,
semiring_gcd @ nat ).
thf(tcon_Nat_Onat___GCD_Osemiring__Gcd_87,axiom,
semiring_Gcd @ nat ).
thf(tcon_Nat_Onat___Rings_Omult__zero_88,axiom,
mult_zero @ nat ).
thf(tcon_Nat_Onat___Orderings_Oorder_89,axiom,
order @ nat ).
thf(tcon_Nat_Onat___Rings_Osemiring_90,axiom,
semiring @ nat ).
thf(tcon_Nat_Onat___Rings_Osemidom_91,axiom,
semidom @ nat ).
thf(tcon_Nat_Onat___Orderings_Oord_92,axiom,
ord @ nat ).
thf(tcon_Nat_Onat___Orderings_Obot_93,axiom,
bot @ nat ).
thf(tcon_Nat_Onat___Groups_Ominus_94,axiom,
minus @ nat ).
thf(tcon_Nat_Onat___Power_Opower_95,axiom,
power @ nat ).
thf(tcon_Nat_Onat___Num_Onumeral_96,axiom,
numeral @ nat ).
thf(tcon_Nat_Onat___Groups_Ozero_97,axiom,
zero @ nat ).
thf(tcon_Nat_Onat___Groups_Oplus_98,axiom,
plus @ nat ).
thf(tcon_Nat_Onat___Groups_Oone_99,axiom,
one @ nat ).
thf(tcon_Nat_Onat___Rings_Odvd_100,axiom,
dvd @ nat ).
thf(tcon_Nat_Onat___Nat_Osize,axiom,
size @ nat ).
thf(tcon_Num_Onum___Orderings_Opreorder_101,axiom,
preorder @ num ).
thf(tcon_Num_Onum___Orderings_Olinorder_102,axiom,
linorder @ num ).
thf(tcon_Num_Onum___Orderings_Oorder_103,axiom,
order @ num ).
thf(tcon_Num_Onum___Orderings_Oord_104,axiom,
ord @ num ).
thf(tcon_Num_Onum___Groups_Oplus_105,axiom,
plus @ num ).
thf(tcon_Num_Onum___Nat_Osize_106,axiom,
size @ num ).
thf(tcon_Set_Oset___Countable__Complete__Lattices_Ocountable__complete__distrib__lattice_107,axiom,
! [A10: $tType] : ( counta4013691401010221786attice @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_108,axiom,
! [A10: $tType] : ( condit1219197933456340205attice @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Countable__Complete__Lattices_Ocountable__complete__lattice_109,axiom,
! [A10: $tType] : ( counta3822494911875563373attice @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Complete__Lattices_Ocomplete__distrib__lattice_110,axiom,
! [A10: $tType] : ( comple592849572758109894attice @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Lattices_Obounded__semilattice__sup__bot_111,axiom,
! [A10: $tType] : ( bounde4967611905675639751up_bot @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Lattices_Obounded__semilattice__inf__top_112,axiom,
! [A10: $tType] : ( bounde4346867609351753570nf_top @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Complete__Lattices_Ocomplete__lattice_113,axiom,
! [A10: $tType] : ( comple6319245703460814977attice @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Boolean__Algebras_Oboolean__algebra_114,axiom,
! [A10: $tType] : ( boolea8198339166811842893lgebra @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Lattices_Obounded__lattice__top_115,axiom,
! [A10: $tType] : ( bounded_lattice_top @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Lattices_Obounded__lattice__bot_116,axiom,
! [A10: $tType] : ( bounded_lattice_bot @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Complete__Partial__Order_Occpo_117,axiom,
! [A10: $tType] : ( comple9053668089753744459l_ccpo @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Lattices_Osemilattice__sup_118,axiom,
! [A10: $tType] : ( semilattice_sup @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Lattices_Osemilattice__inf_119,axiom,
! [A10: $tType] : ( semilattice_inf @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Lattices_Odistrib__lattice_120,axiom,
! [A10: $tType] : ( distrib_lattice @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Lattices_Obounded__lattice_121,axiom,
! [A10: $tType] : ( bounded_lattice @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Orderings_Oorder__top_122,axiom,
! [A10: $tType] : ( order_top @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Orderings_Oorder__bot_123,axiom,
! [A10: $tType] : ( order_bot @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Orderings_Opreorder_124,axiom,
! [A10: $tType] : ( preorder @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Lattices_Olattice_125,axiom,
! [A10: $tType] : ( lattice @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Orderings_Oorder_126,axiom,
! [A10: $tType] : ( order @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Orderings_Oord_127,axiom,
! [A10: $tType] : ( ord @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Orderings_Obot_128,axiom,
! [A10: $tType] : ( bot @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Groups_Ouminus_129,axiom,
! [A10: $tType] : ( uminus @ ( set @ A10 ) ) ).
thf(tcon_Set_Oset___Groups_Ominus_130,axiom,
! [A10: $tType] : ( minus @ ( set @ A10 ) ) ).
thf(tcon_HOL_Obool___Countable__Complete__Lattices_Ocountable__complete__distrib__lattice_131,axiom,
counta4013691401010221786attice @ $o ).
thf(tcon_HOL_Obool___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_132,axiom,
condit1219197933456340205attice @ $o ).
thf(tcon_HOL_Obool___Countable__Complete__Lattices_Ocountable__complete__lattice_133,axiom,
counta3822494911875563373attice @ $o ).
thf(tcon_HOL_Obool___Complete__Lattices_Ocomplete__distrib__lattice_134,axiom,
comple592849572758109894attice @ $o ).
thf(tcon_HOL_Obool___Topological__Spaces_Otopological__space_135,axiom,
topolo4958980785337419405_space @ $o ).
thf(tcon_HOL_Obool___Topological__Spaces_Olinorder__topology_136,axiom,
topolo1944317154257567458pology @ $o ).
thf(tcon_HOL_Obool___Topological__Spaces_Odiscrete__topology_137,axiom,
topolo8865339358273720382pology @ $o ).
thf(tcon_HOL_Obool___Lattices_Obounded__semilattice__sup__bot_138,axiom,
bounde4967611905675639751up_bot @ $o ).
thf(tcon_HOL_Obool___Lattices_Obounded__semilattice__inf__top_139,axiom,
bounde4346867609351753570nf_top @ $o ).
thf(tcon_HOL_Obool___Complete__Lattices_Ocomplete__lattice_140,axiom,
comple6319245703460814977attice @ $o ).
thf(tcon_HOL_Obool___Topological__Spaces_Oorder__topology_141,axiom,
topolo2564578578187576103pology @ $o ).
thf(tcon_HOL_Obool___Boolean__Algebras_Oboolean__algebra_142,axiom,
boolea8198339166811842893lgebra @ $o ).
thf(tcon_HOL_Obool___Lattices_Obounded__lattice__top_143,axiom,
bounded_lattice_top @ $o ).
thf(tcon_HOL_Obool___Lattices_Obounded__lattice__bot_144,axiom,
bounded_lattice_bot @ $o ).
thf(tcon_HOL_Obool___Topological__Spaces_Ot2__space_145,axiom,
topological_t2_space @ $o ).
thf(tcon_HOL_Obool___Topological__Spaces_Ot1__space_146,axiom,
topological_t1_space @ $o ).
thf(tcon_HOL_Obool___Complete__Partial__Order_Occpo_147,axiom,
comple9053668089753744459l_ccpo @ $o ).
thf(tcon_HOL_Obool___Lattices_Osemilattice__sup_148,axiom,
semilattice_sup @ $o ).
thf(tcon_HOL_Obool___Lattices_Osemilattice__inf_149,axiom,
semilattice_inf @ $o ).
thf(tcon_HOL_Obool___Lattices_Odistrib__lattice_150,axiom,
distrib_lattice @ $o ).
thf(tcon_HOL_Obool___Lattices_Obounded__lattice_151,axiom,
bounded_lattice @ $o ).
thf(tcon_HOL_Obool___Orderings_Oorder__top_152,axiom,
order_top @ $o ).
thf(tcon_HOL_Obool___Orderings_Oorder__bot_153,axiom,
order_bot @ $o ).
thf(tcon_HOL_Obool___Orderings_Opreorder_154,axiom,
preorder @ $o ).
thf(tcon_HOL_Obool___Orderings_Olinorder_155,axiom,
linorder @ $o ).
thf(tcon_HOL_Obool___Lattices_Olattice_156,axiom,
lattice @ $o ).
thf(tcon_HOL_Obool___Orderings_Oorder_157,axiom,
order @ $o ).
thf(tcon_HOL_Obool___Orderings_Oord_158,axiom,
ord @ $o ).
thf(tcon_HOL_Obool___Orderings_Obot_159,axiom,
bot @ $o ).
thf(tcon_HOL_Obool___Groups_Ouminus_160,axiom,
uminus @ $o ).
thf(tcon_HOL_Obool___Groups_Ominus_161,axiom,
minus @ $o ).
thf(tcon_List_Olist___Nat_Osize_162,axiom,
! [A10: $tType] : ( size @ ( list @ A10 ) ) ).
thf(tcon_Real_Oreal___Conditionally__Complete__Lattices_Oconditionally__complete__linorder_163,axiom,
condit6923001295902523014norder @ real ).
thf(tcon_Real_Oreal___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_164,axiom,
condit1219197933456340205attice @ real ).
thf(tcon_Real_Oreal___Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct_165,axiom,
semiri1453513574482234551roduct @ real ).
thf(tcon_Real_Oreal___Conditionally__Complete__Lattices_Olinear__continuum,axiom,
condit5016429287641298734tinuum @ real ).
thf(tcon_Real_Oreal___Groups_Oordered__ab__semigroup__monoid__add__imp__le_166,axiom,
ordere1937475149494474687imp_le @ real ).
thf(tcon_Real_Oreal___Topological__Spaces_Olinear__continuum__topology,axiom,
topolo8458572112393995274pology @ real ).
thf(tcon_Real_Oreal___Topological__Spaces_Ofirst__countable__topology,axiom,
topolo3112930676232923870pology @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Oreal__normed__div__algebra,axiom,
real_V8999393235501362500lgebra @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Oreal__normed__algebra__1,axiom,
real_V2822296259951069270ebra_1 @ real ).
thf(tcon_Real_Oreal___Rings_Osemiring__no__zero__divisors__cancel_167,axiom,
semiri6575147826004484403cancel @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Oreal__normed__algebra,axiom,
real_V4412858255891104859lgebra @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Oordered__real__vector,axiom,
real_V5355595471888546746vector @ real ).
thf(tcon_Real_Oreal___Groups_Ostrict__ordered__ab__semigroup__add_168,axiom,
strict9044650504122735259up_add @ real ).
thf(tcon_Real_Oreal___Groups_Oordered__cancel__ab__semigroup__add_169,axiom,
ordere580206878836729694up_add @ real ).
thf(tcon_Real_Oreal___Groups_Oordered__ab__semigroup__add__imp__le_170,axiom,
ordere2412721322843649153imp_le @ real ).
thf(tcon_Real_Oreal___Rings_Olinordered__comm__semiring__strict_171,axiom,
linord2810124833399127020strict @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Oreal__normed__vector,axiom,
real_V822414075346904944vector @ real ).
thf(tcon_Real_Oreal___Groups_Ostrict__ordered__comm__monoid__add_172,axiom,
strict7427464778891057005id_add @ real ).
thf(tcon_Real_Oreal___Groups_Oordered__cancel__comm__monoid__add_173,axiom,
ordere8940638589300402666id_add @ real ).
thf(tcon_Real_Oreal___Topological__Spaces_Otopological__space_174,axiom,
topolo4958980785337419405_space @ real ).
thf(tcon_Real_Oreal___Topological__Spaces_Olinorder__topology_175,axiom,
topolo1944317154257567458pology @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Oreal__normed__field,axiom,
real_V3459762299906320749_field @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Oreal__div__algebra,axiom,
real_V5047593784448816457lgebra @ real ).
thf(tcon_Real_Oreal___Archimedean__Field_Oarchimedean__field,axiom,
archim462609752435547400_field @ real ).
thf(tcon_Real_Oreal___Rings_Olinordered__semiring__1__strict_176,axiom,
linord715952674999750819strict @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Ouniformity__dist,axiom,
real_V768167426530841204y_dist @ real ).
thf(tcon_Real_Oreal___Orderings_Ounbounded__dense__linorder,axiom,
unboun7993243217541854897norder @ real ).
thf(tcon_Real_Oreal___Limits_Otopological__comm__monoid__add_177,axiom,
topolo5987344860129210374id_add @ real ).
thf(tcon_Real_Oreal___Groups_Olinordered__ab__semigroup__add_178,axiom,
linord4140545234300271783up_add @ real ).
thf(tcon_Real_Oreal___Topological__Spaces_Oorder__topology_179,axiom,
topolo2564578578187576103pology @ real ).
thf(tcon_Real_Oreal___Rings_Osemiring__1__no__zero__divisors_180,axiom,
semiri2026040879449505780visors @ real ).
thf(tcon_Real_Oreal___Rings_Olinordered__nonzero__semiring_181,axiom,
linord181362715937106298miring @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Oreal__algebra__1,axiom,
real_V2191834092415804123ebra_1 @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Ocomplete__space,axiom,
real_V8037385150606011577_space @ real ).
thf(tcon_Real_Oreal___Limits_Otopological__semigroup__mult_182,axiom,
topolo4211221413907600880p_mult @ real ).
thf(tcon_Real_Oreal___Topological__Spaces_Ouniform__space,axiom,
topolo7287701948861334536_space @ real ).
thf(tcon_Real_Oreal___Topological__Spaces_Operfect__space,axiom,
topolo8386298272705272623_space @ real ).
thf(tcon_Real_Oreal___Rings_Olinordered__semiring__strict_183,axiom,
linord8928482502909563296strict @ real ).
thf(tcon_Real_Oreal___Rings_Osemiring__no__zero__divisors_184,axiom,
semiri3467727345109120633visors @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Ometric__space,axiom,
real_V7819770556892013058_space @ real ).
thf(tcon_Real_Oreal___Limits_Otopological__ab__group__add,axiom,
topolo1287966508704411220up_add @ real ).
thf(tcon_Real_Oreal___Groups_Oordered__ab__semigroup__add_185,axiom,
ordere6658533253407199908up_add @ real ).
thf(tcon_Real_Oreal___Groups_Oordered__ab__group__add__abs_186,axiom,
ordere166539214618696060dd_abs @ real ).
thf(tcon_Real_Oreal___Archimedean__Field_Ofloor__ceiling,axiom,
archim2362893244070406136eiling @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Oreal__vector,axiom,
real_V4867850818363320053vector @ real ).
thf(tcon_Real_Oreal___Groups_Oordered__comm__monoid__add_187,axiom,
ordere6911136660526730532id_add @ real ).
thf(tcon_Real_Oreal___Groups_Olinordered__ab__group__add_188,axiom,
linord5086331880401160121up_add @ real ).
thf(tcon_Real_Oreal___Groups_Ocancel__ab__semigroup__add_189,axiom,
cancel2418104881723323429up_add @ real ).
thf(tcon_Real_Oreal___Rings_Oring__1__no__zero__divisors_190,axiom,
ring_15535105094025558882visors @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Oreal__field,axiom,
real_V7773925162809079976_field @ real ).
thf(tcon_Real_Oreal___Limits_Otopological__monoid__add_191,axiom,
topolo6943815403480290642id_add @ real ).
thf(tcon_Real_Oreal___Groups_Ocancel__comm__monoid__add_192,axiom,
cancel1802427076303600483id_add @ real ).
thf(tcon_Real_Oreal___Rings_Olinordered__ring__strict_193,axiom,
linord4710134922213307826strict @ real ).
thf(tcon_Real_Oreal___Rings_Ocomm__semiring__1__cancel_194,axiom,
comm_s4317794764714335236cancel @ real ).
thf(tcon_Real_Oreal___Limits_Otopological__group__add,axiom,
topolo1633459387980952147up_add @ real ).
thf(tcon_Real_Oreal___Topological__Spaces_Ot2__space_195,axiom,
topological_t2_space @ real ).
thf(tcon_Real_Oreal___Topological__Spaces_Ot1__space_196,axiom,
topological_t1_space @ real ).
thf(tcon_Real_Oreal___Rings_Oordered__comm__semiring_197,axiom,
ordere2520102378445227354miring @ real ).
thf(tcon_Real_Oreal___Rings_Olinordered__semiring__1_198,axiom,
linord6961819062388156250ring_1 @ real ).
thf(tcon_Real_Oreal___Groups_Oordered__ab__group__add_199,axiom,
ordered_ab_group_add @ real ).
thf(tcon_Real_Oreal___Groups_Ocancel__semigroup__add_200,axiom,
cancel_semigroup_add @ real ).
thf(tcon_Real_Oreal___Rings_Olinordered__semiring_201,axiom,
linordered_semiring @ real ).
thf(tcon_Real_Oreal___Real__Vector__Spaces_Obanach,axiom,
real_Vector_banach @ real ).
thf(tcon_Real_Oreal___Rings_Oordered__semiring__0_202,axiom,
ordered_semiring_0 @ real ).
thf(tcon_Real_Oreal___Rings_Olinordered__semidom_203,axiom,
linordered_semidom @ real ).
thf(tcon_Real_Oreal___Orderings_Odense__linorder,axiom,
dense_linorder @ real ).
thf(tcon_Real_Oreal___Lattices_Osemilattice__sup_204,axiom,
semilattice_sup @ real ).
thf(tcon_Real_Oreal___Lattices_Osemilattice__inf_205,axiom,
semilattice_inf @ real ).
thf(tcon_Real_Oreal___Lattices_Odistrib__lattice_206,axiom,
distrib_lattice @ real ).
thf(tcon_Real_Oreal___Groups_Oab__semigroup__mult_207,axiom,
ab_semigroup_mult @ real ).
thf(tcon_Real_Oreal___Rings_Osemiring__1__cancel_208,axiom,
semiring_1_cancel @ real ).
thf(tcon_Real_Oreal___Groups_Ocomm__monoid__mult_209,axiom,
comm_monoid_mult @ real ).
thf(tcon_Real_Oreal___Groups_Oab__semigroup__add_210,axiom,
ab_semigroup_add @ real ).
thf(tcon_Real_Oreal___Fields_Olinordered__field,axiom,
linordered_field @ real ).
thf(tcon_Real_Oreal___Rings_Oordered__semiring_211,axiom,
ordered_semiring @ real ).
thf(tcon_Real_Oreal___Rings_Oordered__ring__abs_212,axiom,
ordered_ring_abs @ real ).
thf(tcon_Real_Oreal___Groups_Ocomm__monoid__add_213,axiom,
comm_monoid_add @ real ).
thf(tcon_Real_Oreal___Rings_Olinordered__ring_214,axiom,
linordered_ring @ real ).
thf(tcon_Real_Oreal___Rings_Olinordered__idom_215,axiom,
linordered_idom @ real ).
thf(tcon_Real_Oreal___Rings_Ocomm__semiring__1_216,axiom,
comm_semiring_1 @ real ).
thf(tcon_Real_Oreal___Rings_Ocomm__semiring__0_217,axiom,
comm_semiring_0 @ real ).
thf(tcon_Real_Oreal___Orderings_Odense__order,axiom,
dense_order @ real ).
thf(tcon_Real_Oreal___Groups_Osemigroup__mult_218,axiom,
semigroup_mult @ real ).
thf(tcon_Real_Oreal___Rings_Osemidom__divide_219,axiom,
semidom_divide @ real ).
thf(tcon_Real_Oreal___Num_Osemiring__numeral_220,axiom,
semiring_numeral @ real ).
thf(tcon_Real_Oreal___Groups_Osemigroup__add_221,axiom,
semigroup_add @ real ).
thf(tcon_Real_Oreal___Fields_Ofield__abs__sgn,axiom,
field_abs_sgn @ real ).
thf(tcon_Real_Oreal___Fields_Odivision__ring,axiom,
division_ring @ real ).
thf(tcon_Real_Oreal___Rings_Ozero__less__one_222,axiom,
zero_less_one @ real ).
thf(tcon_Real_Oreal___Rings_Ocomm__semiring_223,axiom,
comm_semiring @ real ).
thf(tcon_Real_Oreal___Nat_Osemiring__char__0_224,axiom,
semiring_char_0 @ real ).
thf(tcon_Real_Oreal___Groups_Oab__group__add_225,axiom,
ab_group_add @ real ).
thf(tcon_Real_Oreal___Fields_Ofield__char__0,axiom,
field_char_0 @ real ).
thf(tcon_Real_Oreal___Rings_Ozero__neq__one_226,axiom,
zero_neq_one @ real ).
thf(tcon_Real_Oreal___Rings_Oordered__ring_227,axiom,
ordered_ring @ real ).
thf(tcon_Real_Oreal___Rings_Oidom__abs__sgn_228,axiom,
idom_abs_sgn @ real ).
thf(tcon_Real_Oreal___Orderings_Opreorder_229,axiom,
preorder @ real ).
thf(tcon_Real_Oreal___Orderings_Olinorder_230,axiom,
linorder @ real ).
thf(tcon_Real_Oreal___Groups_Omonoid__mult_231,axiom,
monoid_mult @ real ).
thf(tcon_Real_Oreal___Transcendental_Oln,axiom,
ln @ real ).
thf(tcon_Real_Oreal___Rings_Oidom__divide_232,axiom,
idom_divide @ real ).
thf(tcon_Real_Oreal___Rings_Ocomm__ring__1_233,axiom,
comm_ring_1 @ real ).
thf(tcon_Real_Oreal___Groups_Omonoid__add_234,axiom,
monoid_add @ real ).
thf(tcon_Real_Oreal___Rings_Osemiring__1_235,axiom,
semiring_1 @ real ).
thf(tcon_Real_Oreal___Rings_Osemiring__0_236,axiom,
semiring_0 @ real ).
thf(tcon_Real_Oreal___Orderings_Ono__top_237,axiom,
no_top @ real ).
thf(tcon_Real_Oreal___Orderings_Ono__bot_238,axiom,
no_bot @ real ).
thf(tcon_Real_Oreal___Lattices_Olattice_239,axiom,
lattice @ real ).
thf(tcon_Real_Oreal___Groups_Ogroup__add_240,axiom,
group_add @ real ).
thf(tcon_Real_Oreal___Rings_Omult__zero_241,axiom,
mult_zero @ real ).
thf(tcon_Real_Oreal___Rings_Ocomm__ring_242,axiom,
comm_ring @ real ).
thf(tcon_Real_Oreal___Orderings_Oorder_243,axiom,
order @ real ).
thf(tcon_Real_Oreal___Num_Oneg__numeral_244,axiom,
neg_numeral @ real ).
thf(tcon_Real_Oreal___Nat_Oring__char__0_245,axiom,
ring_char_0 @ real ).
thf(tcon_Real_Oreal___Rings_Osemiring_246,axiom,
semiring @ real ).
thf(tcon_Real_Oreal___Fields_Oinverse,axiom,
inverse @ real ).
thf(tcon_Real_Oreal___Rings_Osemidom_247,axiom,
semidom @ real ).
thf(tcon_Real_Oreal___Orderings_Oord_248,axiom,
ord @ real ).
thf(tcon_Real_Oreal___Groups_Ouminus_249,axiom,
uminus @ real ).
thf(tcon_Real_Oreal___Rings_Oring__1_250,axiom,
ring_1 @ real ).
thf(tcon_Real_Oreal___Rings_Oabs__if_251,axiom,
abs_if @ real ).
thf(tcon_Real_Oreal___Groups_Ominus_252,axiom,
minus @ real ).
thf(tcon_Real_Oreal___Fields_Ofield,axiom,
field @ real ).
thf(tcon_Real_Oreal___Power_Opower_253,axiom,
power @ real ).
thf(tcon_Real_Oreal___Num_Onumeral_254,axiom,
numeral @ real ).
thf(tcon_Real_Oreal___Groups_Ozero_255,axiom,
zero @ real ).
thf(tcon_Real_Oreal___Groups_Oplus_256,axiom,
plus @ real ).
thf(tcon_Real_Oreal___Rings_Oring_257,axiom,
ring @ real ).
thf(tcon_Real_Oreal___Rings_Oidom_258,axiom,
idom @ real ).
thf(tcon_Real_Oreal___Groups_Oone_259,axiom,
one @ real ).
thf(tcon_Real_Oreal___Rings_Odvd_260,axiom,
dvd @ real ).
thf(tcon_String_Ochar___Nat_Osize_261,axiom,
size @ char ).
thf(tcon_Sum__Type_Osum___Nat_Osize_262,axiom,
! [A10: $tType,A29: $tType] : ( size @ ( sum_sum @ A10 @ A29 ) ) ).
thf(tcon_Filter_Ofilter___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_263,axiom,
! [A10: $tType] : ( condit1219197933456340205attice @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Countable__Complete__Lattices_Ocountable__complete__lattice_264,axiom,
! [A10: $tType] : ( counta3822494911875563373attice @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Lattices_Obounded__semilattice__sup__bot_265,axiom,
! [A10: $tType] : ( bounde4967611905675639751up_bot @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Lattices_Obounded__semilattice__inf__top_266,axiom,
! [A10: $tType] : ( bounde4346867609351753570nf_top @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Complete__Lattices_Ocomplete__lattice_267,axiom,
! [A10: $tType] : ( comple6319245703460814977attice @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Lattices_Obounded__lattice__top_268,axiom,
! [A10: $tType] : ( bounded_lattice_top @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Lattices_Obounded__lattice__bot_269,axiom,
! [A10: $tType] : ( bounded_lattice_bot @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Complete__Partial__Order_Occpo_270,axiom,
! [A10: $tType] : ( comple9053668089753744459l_ccpo @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Lattices_Osemilattice__sup_271,axiom,
! [A10: $tType] : ( semilattice_sup @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Lattices_Osemilattice__inf_272,axiom,
! [A10: $tType] : ( semilattice_inf @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Lattices_Odistrib__lattice_273,axiom,
! [A10: $tType] : ( distrib_lattice @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Lattices_Obounded__lattice_274,axiom,
! [A10: $tType] : ( bounded_lattice @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Orderings_Oorder__top_275,axiom,
! [A10: $tType] : ( order_top @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Orderings_Oorder__bot_276,axiom,
! [A10: $tType] : ( order_bot @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Orderings_Opreorder_277,axiom,
! [A10: $tType] : ( preorder @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Lattices_Olattice_278,axiom,
! [A10: $tType] : ( lattice @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Orderings_Oorder_279,axiom,
! [A10: $tType] : ( order @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Orderings_Oord_280,axiom,
! [A10: $tType] : ( ord @ ( filter @ A10 ) ) ).
thf(tcon_Filter_Ofilter___Orderings_Obot_281,axiom,
! [A10: $tType] : ( bot @ ( filter @ A10 ) ) ).
thf(tcon_Option_Ooption___Nat_Osize_282,axiom,
! [A10: $tType] : ( size @ ( option @ A10 ) ) ).
thf(tcon_Complex_Ocomplex___Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct_283,axiom,
semiri1453513574482234551roduct @ complex ).
thf(tcon_Complex_Ocomplex___Topological__Spaces_Ofirst__countable__topology_284,axiom,
topolo3112930676232923870pology @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Oreal__normed__div__algebra_285,axiom,
real_V8999393235501362500lgebra @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Oreal__normed__algebra__1_286,axiom,
real_V2822296259951069270ebra_1 @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Osemiring__no__zero__divisors__cancel_287,axiom,
semiri6575147826004484403cancel @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Oreal__normed__algebra_288,axiom,
real_V4412858255891104859lgebra @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Oreal__normed__vector_289,axiom,
real_V822414075346904944vector @ complex ).
thf(tcon_Complex_Ocomplex___Topological__Spaces_Otopological__space_290,axiom,
topolo4958980785337419405_space @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Oreal__normed__field_291,axiom,
real_V3459762299906320749_field @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Oreal__div__algebra_292,axiom,
real_V5047593784448816457lgebra @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Ouniformity__dist_293,axiom,
real_V768167426530841204y_dist @ complex ).
thf(tcon_Complex_Ocomplex___Limits_Otopological__comm__monoid__add_294,axiom,
topolo5987344860129210374id_add @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Osemiring__1__no__zero__divisors_295,axiom,
semiri2026040879449505780visors @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Oreal__algebra__1_296,axiom,
real_V2191834092415804123ebra_1 @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Ocomplete__space_297,axiom,
real_V8037385150606011577_space @ complex ).
thf(tcon_Complex_Ocomplex___Limits_Otopological__semigroup__mult_298,axiom,
topolo4211221413907600880p_mult @ complex ).
thf(tcon_Complex_Ocomplex___Topological__Spaces_Ouniform__space_299,axiom,
topolo7287701948861334536_space @ complex ).
thf(tcon_Complex_Ocomplex___Topological__Spaces_Operfect__space_300,axiom,
topolo8386298272705272623_space @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Osemiring__no__zero__divisors_301,axiom,
semiri3467727345109120633visors @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Ometric__space_302,axiom,
real_V7819770556892013058_space @ complex ).
thf(tcon_Complex_Ocomplex___Limits_Otopological__ab__group__add_303,axiom,
topolo1287966508704411220up_add @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Oreal__vector_304,axiom,
real_V4867850818363320053vector @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Ocancel__ab__semigroup__add_305,axiom,
cancel2418104881723323429up_add @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Oring__1__no__zero__divisors_306,axiom,
ring_15535105094025558882visors @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Oreal__field_307,axiom,
real_V7773925162809079976_field @ complex ).
thf(tcon_Complex_Ocomplex___Limits_Otopological__monoid__add_308,axiom,
topolo6943815403480290642id_add @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Ocancel__comm__monoid__add_309,axiom,
cancel1802427076303600483id_add @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Ocomm__semiring__1__cancel_310,axiom,
comm_s4317794764714335236cancel @ complex ).
thf(tcon_Complex_Ocomplex___Limits_Otopological__group__add_311,axiom,
topolo1633459387980952147up_add @ complex ).
thf(tcon_Complex_Ocomplex___Topological__Spaces_Ot2__space_312,axiom,
topological_t2_space @ complex ).
thf(tcon_Complex_Ocomplex___Topological__Spaces_Ot1__space_313,axiom,
topological_t1_space @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Ocancel__semigroup__add_314,axiom,
cancel_semigroup_add @ complex ).
thf(tcon_Complex_Ocomplex___Real__Vector__Spaces_Obanach_315,axiom,
real_Vector_banach @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Oab__semigroup__mult_316,axiom,
ab_semigroup_mult @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Osemiring__1__cancel_317,axiom,
semiring_1_cancel @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Ocomm__monoid__mult_318,axiom,
comm_monoid_mult @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Oab__semigroup__add_319,axiom,
ab_semigroup_add @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Ocomm__monoid__add_320,axiom,
comm_monoid_add @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Ocomm__semiring__1_321,axiom,
comm_semiring_1 @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Ocomm__semiring__0_322,axiom,
comm_semiring_0 @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Osemigroup__mult_323,axiom,
semigroup_mult @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Osemidom__divide_324,axiom,
semidom_divide @ complex ).
thf(tcon_Complex_Ocomplex___Num_Osemiring__numeral_325,axiom,
semiring_numeral @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Osemigroup__add_326,axiom,
semigroup_add @ complex ).
thf(tcon_Complex_Ocomplex___Fields_Ofield__abs__sgn_327,axiom,
field_abs_sgn @ complex ).
thf(tcon_Complex_Ocomplex___Fields_Odivision__ring_328,axiom,
division_ring @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Ocomm__semiring_329,axiom,
comm_semiring @ complex ).
thf(tcon_Complex_Ocomplex___Nat_Osemiring__char__0_330,axiom,
semiring_char_0 @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Oab__group__add_331,axiom,
ab_group_add @ complex ).
thf(tcon_Complex_Ocomplex___Fields_Ofield__char__0_332,axiom,
field_char_0 @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Ozero__neq__one_333,axiom,
zero_neq_one @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Oidom__abs__sgn_334,axiom,
idom_abs_sgn @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Omonoid__mult_335,axiom,
monoid_mult @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Oidom__divide_336,axiom,
idom_divide @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Ocomm__ring__1_337,axiom,
comm_ring_1 @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Omonoid__add_338,axiom,
monoid_add @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Osemiring__1_339,axiom,
semiring_1 @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Osemiring__0_340,axiom,
semiring_0 @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Ogroup__add_341,axiom,
group_add @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Omult__zero_342,axiom,
mult_zero @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Ocomm__ring_343,axiom,
comm_ring @ complex ).
thf(tcon_Complex_Ocomplex___Num_Oneg__numeral_344,axiom,
neg_numeral @ complex ).
thf(tcon_Complex_Ocomplex___Nat_Oring__char__0_345,axiom,
ring_char_0 @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Osemiring_346,axiom,
semiring @ complex ).
thf(tcon_Complex_Ocomplex___Fields_Oinverse_347,axiom,
inverse @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Osemidom_348,axiom,
semidom @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Ouminus_349,axiom,
uminus @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Oring__1_350,axiom,
ring_1 @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Ominus_351,axiom,
minus @ complex ).
thf(tcon_Complex_Ocomplex___Fields_Ofield_352,axiom,
field @ complex ).
thf(tcon_Complex_Ocomplex___Power_Opower_353,axiom,
power @ complex ).
thf(tcon_Complex_Ocomplex___Num_Onumeral_354,axiom,
numeral @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Ozero_355,axiom,
zero @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Oplus_356,axiom,
plus @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Oring_357,axiom,
ring @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Oidom_358,axiom,
idom @ complex ).
thf(tcon_Complex_Ocomplex___Groups_Oone_359,axiom,
one @ complex ).
thf(tcon_Complex_Ocomplex___Rings_Odvd_360,axiom,
dvd @ complex ).
thf(tcon_Extended__Nat_Oenat___Conditionally__Complete__Lattices_Oconditionally__complete__linorder_361,axiom,
condit6923001295902523014norder @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Countable__Complete__Lattices_Ocountable__complete__distrib__lattice_362,axiom,
counta4013691401010221786attice @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_363,axiom,
condit1219197933456340205attice @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Countable__Complete__Lattices_Ocountable__complete__lattice_364,axiom,
counta3822494911875563373attice @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Complete__Lattices_Ocomplete__distrib__lattice_365,axiom,
comple592849572758109894attice @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Ostrict__ordered__ab__semigroup__add_366,axiom,
strict9044650504122735259up_add @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Ostrict__ordered__comm__monoid__add_367,axiom,
strict7427464778891057005id_add @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Ocanonically__ordered__monoid__add_368,axiom,
canoni5634975068530333245id_add @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Lattices_Obounded__semilattice__sup__bot_369,axiom,
bounde4967611905675639751up_bot @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Lattices_Obounded__semilattice__inf__top_370,axiom,
bounde4346867609351753570nf_top @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Complete__Lattices_Ocomplete__linorder,axiom,
comple5582772986160207858norder @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Olinordered__ab__semigroup__add_371,axiom,
linord4140545234300271783up_add @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Complete__Lattices_Ocomplete__lattice_372,axiom,
comple6319245703460814977attice @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Olinordered__nonzero__semiring_373,axiom,
linord181362715937106298miring @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Osemiring__no__zero__divisors_374,axiom,
semiri3467727345109120633visors @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Oordered__ab__semigroup__add_375,axiom,
ordere6658533253407199908up_add @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Oordered__comm__monoid__add_376,axiom,
ordere6911136660526730532id_add @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Lattices_Obounded__lattice__top_377,axiom,
bounded_lattice_top @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Lattices_Obounded__lattice__bot_378,axiom,
bounded_lattice_bot @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Oordered__comm__semiring_379,axiom,
ordere2520102378445227354miring @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Complete__Partial__Order_Occpo_380,axiom,
comple9053668089753744459l_ccpo @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Lattices_Osemilattice__sup_381,axiom,
semilattice_sup @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Lattices_Osemilattice__inf_382,axiom,
semilattice_inf @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Lattices_Odistrib__lattice_383,axiom,
distrib_lattice @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Lattices_Obounded__lattice_384,axiom,
bounded_lattice @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Oab__semigroup__mult_385,axiom,
ab_semigroup_mult @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Ocomm__monoid__mult_386,axiom,
comm_monoid_mult @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Oab__semigroup__add_387,axiom,
ab_semigroup_add @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Oordered__semiring_388,axiom,
ordered_semiring @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Ocomm__monoid__add_389,axiom,
comm_monoid_add @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Ocomm__semiring__1_390,axiom,
comm_semiring_1 @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Ocomm__semiring__0_391,axiom,
comm_semiring_0 @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Osemigroup__mult_392,axiom,
semigroup_mult @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Num_Osemiring__numeral_393,axiom,
semiring_numeral @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Osemigroup__add_394,axiom,
semigroup_add @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Ozero__less__one_395,axiom,
zero_less_one @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Ocomm__semiring_396,axiom,
comm_semiring @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Orderings_Owellorder_397,axiom,
wellorder @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Orderings_Oorder__top_398,axiom,
order_top @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Orderings_Oorder__bot_399,axiom,
order_bot @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Nat_Osemiring__char__0_400,axiom,
semiring_char_0 @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Ozero__neq__one_401,axiom,
zero_neq_one @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Orderings_Opreorder_402,axiom,
preorder @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Orderings_Olinorder_403,axiom,
linorder @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Omonoid__mult_404,axiom,
monoid_mult @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Omonoid__add_405,axiom,
monoid_add @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Osemiring__1_406,axiom,
semiring_1 @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Osemiring__0_407,axiom,
semiring_0 @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Lattices_Olattice_408,axiom,
lattice @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Omult__zero_409,axiom,
mult_zero @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Orderings_Oorder_410,axiom,
order @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Osemiring_411,axiom,
semiring @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Orderings_Oord_412,axiom,
ord @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Orderings_Obot_413,axiom,
bot @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Ominus_414,axiom,
minus @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Power_Opower_415,axiom,
power @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Num_Onumeral_416,axiom,
numeral @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Ozero_417,axiom,
zero @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Oplus_418,axiom,
plus @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Groups_Oone_419,axiom,
one @ extended_enat ).
thf(tcon_Extended__Nat_Oenat___Rings_Odvd_420,axiom,
dvd @ extended_enat ).
thf(tcon_Product__Type_Oprod___Topological__Spaces_Otopological__space_421,axiom,
! [A10: $tType,A29: $tType] :
( ( ( topolo4958980785337419405_space @ A10 )
& ( topolo4958980785337419405_space @ A29 ) )
=> ( topolo4958980785337419405_space @ ( product_prod @ A10 @ A29 ) ) ) ).
thf(tcon_Product__Type_Oprod___Topological__Spaces_Ot2__space_422,axiom,
! [A10: $tType,A29: $tType] :
( ( ( topological_t2_space @ A10 )
& ( topological_t2_space @ A29 ) )
=> ( topological_t2_space @ ( product_prod @ A10 @ A29 ) ) ) ).
thf(tcon_Product__Type_Oprod___Topological__Spaces_Ot1__space_423,axiom,
! [A10: $tType,A29: $tType] :
( ( ( topological_t1_space @ A10 )
& ( topological_t1_space @ A29 ) )
=> ( topological_t1_space @ ( product_prod @ A10 @ A29 ) ) ) ).
thf(tcon_Product__Type_Oprod___Nat_Osize_424,axiom,
! [A10: $tType,A29: $tType] : ( size @ ( product_prod @ A10 @ A29 ) ) ).
thf(tcon_Product__Type_Ounit___Conditionally__Complete__Lattices_Oconditionally__complete__linorder_425,axiom,
condit6923001295902523014norder @ product_unit ).
thf(tcon_Product__Type_Ounit___Countable__Complete__Lattices_Ocountable__complete__distrib__lattice_426,axiom,
counta4013691401010221786attice @ product_unit ).
thf(tcon_Product__Type_Ounit___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_427,axiom,
condit1219197933456340205attice @ product_unit ).
thf(tcon_Product__Type_Ounit___Countable__Complete__Lattices_Ocountable__complete__lattice_428,axiom,
counta3822494911875563373attice @ product_unit ).
thf(tcon_Product__Type_Ounit___Complete__Lattices_Ocomplete__distrib__lattice_429,axiom,
comple592849572758109894attice @ product_unit ).
thf(tcon_Product__Type_Ounit___Lattices_Obounded__semilattice__sup__bot_430,axiom,
bounde4967611905675639751up_bot @ product_unit ).
thf(tcon_Product__Type_Ounit___Lattices_Obounded__semilattice__inf__top_431,axiom,
bounde4346867609351753570nf_top @ product_unit ).
thf(tcon_Product__Type_Ounit___Complete__Lattices_Ocomplete__linorder_432,axiom,
comple5582772986160207858norder @ product_unit ).
thf(tcon_Product__Type_Ounit___Complete__Lattices_Ocomplete__lattice_433,axiom,
comple6319245703460814977attice @ product_unit ).
thf(tcon_Product__Type_Ounit___Boolean__Algebras_Oboolean__algebra_434,axiom,
boolea8198339166811842893lgebra @ product_unit ).
thf(tcon_Product__Type_Ounit___Lattices_Obounded__lattice__top_435,axiom,
bounded_lattice_top @ product_unit ).
thf(tcon_Product__Type_Ounit___Lattices_Obounded__lattice__bot_436,axiom,
bounded_lattice_bot @ product_unit ).
thf(tcon_Product__Type_Ounit___Complete__Partial__Order_Occpo_437,axiom,
comple9053668089753744459l_ccpo @ product_unit ).
thf(tcon_Product__Type_Ounit___Lattices_Osemilattice__sup_438,axiom,
semilattice_sup @ product_unit ).
thf(tcon_Product__Type_Ounit___Lattices_Osemilattice__inf_439,axiom,
semilattice_inf @ product_unit ).
thf(tcon_Product__Type_Ounit___Lattices_Odistrib__lattice_440,axiom,
distrib_lattice @ product_unit ).
thf(tcon_Product__Type_Ounit___Lattices_Obounded__lattice_441,axiom,
bounded_lattice @ product_unit ).
thf(tcon_Product__Type_Ounit___Orderings_Owellorder_442,axiom,
wellorder @ product_unit ).
thf(tcon_Product__Type_Ounit___Orderings_Oorder__top_443,axiom,
order_top @ product_unit ).
thf(tcon_Product__Type_Ounit___Orderings_Oorder__bot_444,axiom,
order_bot @ product_unit ).
thf(tcon_Product__Type_Ounit___Orderings_Opreorder_445,axiom,
preorder @ product_unit ).
thf(tcon_Product__Type_Ounit___Orderings_Olinorder_446,axiom,
linorder @ product_unit ).
thf(tcon_Product__Type_Ounit___Lattices_Olattice_447,axiom,
lattice @ product_unit ).
thf(tcon_Product__Type_Ounit___Orderings_Oorder_448,axiom,
order @ product_unit ).
thf(tcon_Product__Type_Ounit___Orderings_Oord_449,axiom,
ord @ product_unit ).
thf(tcon_Product__Type_Ounit___Orderings_Obot_450,axiom,
bot @ product_unit ).
thf(tcon_Product__Type_Ounit___Groups_Ouminus_451,axiom,
uminus @ product_unit ).
thf(tcon_Product__Type_Ounit___Groups_Ominus_452,axiom,
minus @ product_unit ).
thf(tcon_VEBT__Definitions_OVEBT___Nat_Osize_453,axiom,
size @ vEBT_VEBT ).
% Helper facts (4)
thf(help_If_3_1_T,axiom,
! [P2: $o] :
( ( P2 = $true )
| ( P2 = $false ) ) ).
thf(help_If_2_1_T,axiom,
! [A: $tType,X: A,Y: A] :
( ( if @ A @ $false @ X @ Y )
= Y ) ).
thf(help_If_1_1_T,axiom,
! [A: $tType,X: A,Y: A] :
( ( if @ A @ $true @ X @ Y )
= X ) ).
thf(help_fChoice_1_1_T,axiom,
! [A: $tType,P2: A > $o] :
( ( P2 @ ( fChoice @ A @ P2 ) )
= ( ? [X8: A] : ( P2 @ X8 ) ) ) ).
% Conjectures (1)
thf(conj_0,conjecture,
? [Y3: nat] : ( vEBT_V8194947554948674370ptions @ ( nth @ vEBT_VEBT @ ( list_update @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) @ ( vEBT_vebt_insert @ ( nth @ vEBT_VEBT @ treeList @ ( vEBT_VEBT_high @ xa @ na ) ) @ ( vEBT_VEBT_low @ xa @ na ) ) ) @ i ) @ Y3 ) ).
%------------------------------------------------------------------------------